aboutsummaryrefslogtreecommitdiff
path: root/mesonbuild/interpreter.py
diff options
context:
space:
mode:
authorJussi Pakkanen <jpakkane@gmail.com>2016-06-19 21:56:09 +0300
committerJussi Pakkanen <jpakkane@gmail.com>2016-08-01 20:46:40 +0300
commitd90fcb4048f720a238cbb350164ec8f63d1eec60 (patch)
treeac64eb1624beed298bacf50b27cdca0cc57d454b /mesonbuild/interpreter.py
parent4f6be39d2668713c6c5b9d7bba06a58553f68887 (diff)
downloadmeson-d90fcb4048f720a238cbb350164ec8f63d1eec60.zip
meson-d90fcb4048f720a238cbb350164ec8f63d1eec60.tar.gz
meson-d90fcb4048f720a238cbb350164ec8f63d1eec60.tar.bz2
Created ternary operator. Closes #538.
Diffstat (limited to 'mesonbuild/interpreter.py')
-rw-r--r--mesonbuild/interpreter.py12
1 files changed, 12 insertions, 0 deletions
diff --git a/mesonbuild/interpreter.py b/mesonbuild/interpreter.py
index 5201be2..fddc3c0 100644
--- a/mesonbuild/interpreter.py
+++ b/mesonbuild/interpreter.py
@@ -1323,6 +1323,8 @@ class Interpreter():
return self.evaluate_plusassign(cur)
elif isinstance(cur, mparser.IndexNode):
return self.evaluate_indexing(cur)
+ elif isinstance(cur, mparser.TernaryNode):
+ return self.evaluate_ternary(cur)
elif self.is_elementary_type(cur):
return cur
else:
@@ -2401,6 +2403,16 @@ class Interpreter():
if not isinstance(node.elseblock, mparser.EmptyNode):
self.evaluate_codeblock(node.elseblock)
+ def evaluate_ternary(self, node):
+ assert(isinstance(node, mparser.TernaryNode))
+ result = self.evaluate_statement(node.condition)
+ if not isinstance(result, bool):
+ raise InterpreterException('Ternary condition is not boolean.')
+ if result:
+ return self.evaluate_statement(node.trueblock)
+ else:
+ return self.evaluate_statement(node.falseblock)
+
def evaluate_foreach(self, node):
assert(isinstance(node, mparser.ForeachClauseNode))
varname = node.varname.value