Skip to content

Commit

Permalink
fix: revert '+' syntax optimize
Browse files Browse the repository at this point in the history
  • Loading branch information
0x7Fancy committed Jan 22, 2024
1 parent 74f8e13 commit 9c1e7a9
Showing 1 changed file with 3 additions and 22 deletions.
25 changes: 3 additions & 22 deletions grammars/f1_g4_translate.py
Original file line number Diff line number Diff line change
Expand Up @@ -75,30 +75,11 @@ def esc_token(self, t):
t = t.replace('\t', '\\t')
return t

def rule_to_s(self, key, rule, grammar):
# feat: add 'directly head/tail recursion' optimized syntax '+'
if len(rule) == 0:
return ''

# head recursion
recursion = False
if rule[0] == key:
rule = rule[1:]
recursion = True
# tail recursion
if rule[-1] == key:
rule = rule[:-1]
recursion = True

# append rules
data = ' '.join(["'%s'" % self.esc_token(t)
def rule_to_s(self, rule, grammar):
return ' '.join(["'%s'" % self.esc_token(t)
if t not in grammar else self.to_key(t)
for t in rule])

if recursion:
data = "(%s)+" % data
return data

def translate(self):
lines = ['grammar Grammar;']
entries = '\n | '.join([self.to_key(entry_k) + ' EOF' for entry_k in self.entry_keys])
Expand All @@ -108,7 +89,7 @@ def translate(self):
;''' % entries)
for k in self.grammar_keys:
rules = self.grammar[k]
v = '\n | '.join([self.rule_to_s(k, rule, self.grammar)
v = '\n | '.join([self.rule_to_s(rule, self.grammar)
for rule in rules])
lines.append('''\
%s
Expand Down

0 comments on commit 9c1e7a9

Please sign in to comment.