diff options
author | Jussi Pakkanen <jpakkane@gmail.com> | 2016-08-01 21:08:04 +0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2016-08-01 21:08:04 +0300 |
commit | 657f357fc6ac0d97d30c940f9919b0021902a608 (patch) | |
tree | 09d212abc005a89626b4ed5353711efa69864b41 /mesonbuild/mparser.py | |
parent | 58ad092ff36dfe209b0f4da13f90705d42e4b9ea (diff) | |
parent | b382abdd2c307d0716353013022df5039991ac1f (diff) | |
download | meson-657f357fc6ac0d97d30c940f9919b0021902a608.zip meson-657f357fc6ac0d97d30c940f9919b0021902a608.tar.gz meson-657f357fc6ac0d97d30c940f9919b0021902a608.tar.bz2 |
Merge pull request #605 from mesonbuild/ternary
Added ternary operator support
Diffstat (limited to 'mesonbuild/mparser.py')
-rw-r--r-- | mesonbuild/mparser.py | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/mesonbuild/mparser.py b/mesonbuild/mparser.py index fd720fb..2f0eb2d 100644 --- a/mesonbuild/mparser.py +++ b/mesonbuild/mparser.py @@ -67,6 +67,7 @@ class Lexer: ('lt', re.compile(r'<')), ('ge', re.compile(r'>=')), ('gt', re.compile(r'>')), + ('questionmark', re.compile(r'\?')), ] def lex(self, code): @@ -282,6 +283,14 @@ class IfNode(): self.condition = condition self.block = block +class TernaryNode(): + def __init__(self, lineno, colno, condition, trueblock, falseblock): + self.lineno = lineno + self.colno = colno + self.condition = condition + self.trueblock = trueblock + self.falseblock = falseblock + class ArgumentNode(): def __init__(self, token): self.lineno = token.lineno @@ -344,6 +353,7 @@ class Parser: def __init__(self, code): self.stream = Lexer().lex(code) self.getsym() + self.in_ternary = False def getsym(self): try: @@ -383,6 +393,16 @@ class Parser: raise ParseException('Assignment target must be an id.', left.lineno, left.colno) return AssignmentNode(left.lineno, left.colno, left.value, value) + elif self.accept('questionmark'): + if self.in_ternary: + raise ParseException('Nested ternary operators are not allowed.', + left.lineno, left.colno) + self.in_ternary = True + trueblock = self.e1() + self.expect('colon') + falseblock = self.e1() + self.in_ternary = False + return TernaryNode(left.lineno, left.colno, left, trueblock, falseblock) return left def e2(self): |