aboutsummaryrefslogtreecommitdiff
path: root/interpreter.py
diff options
context:
space:
mode:
authorJussi Pakkanen <jpakkane@gmail.com>2013-07-27 17:15:22 +0300
committerJussi Pakkanen <jpakkane@gmail.com>2013-07-27 17:15:22 +0300
commit782021d65ee0f928f0d0b08b51068a32171e9801 (patch)
tree6d2e1aa7a41bfbf2fe433ff3b743d46d93e28cc1 /interpreter.py
parent6a5a9a384842870f9a54ffeb3a828e57eafdec08 (diff)
downloadmeson-782021d65ee0f928f0d0b08b51068a32171e9801.zip
meson-782021d65ee0f928f0d0b08b51068a32171e9801.tar.gz
meson-782021d65ee0f928f0d0b08b51068a32171e9801.tar.bz2
Can do logical or.
Diffstat (limited to 'interpreter.py')
-rw-r--r--interpreter.py17
1 files changed, 17 insertions, 0 deletions
diff --git a/interpreter.py b/interpreter.py
index eb04fbb..aa7a0f9 100644
--- a/interpreter.py
+++ b/interpreter.py
@@ -843,6 +843,8 @@ class Interpreter():
return cur
elif isinstance(cur, nodes.AndStatement):
return self.evaluate_andstatement(cur)
+ elif isinstance(cur, nodes.OrStatement):
+ return self.evaluate_orstatement(cur)
else:
raise InvalidCode("Unknown statement.")
@@ -1247,6 +1249,21 @@ class Interpreter():
raise InterpreterException('Second argument to "and" is not a boolean.')
return r
+ def evaluate_orstatement(self, cur):
+ l = self.evaluate_statement(cur.left)
+ if isinstance(l, nodes.BoolStatement):
+ l = l.get_value()
+ if not isinstance(l, bool):
+ raise InterpreterException('First argument to "or" is not a boolean.')
+ if l:
+ return True
+ r = self.evaluate_statement(cur.right)
+ if isinstance(r, nodes.BoolStatement):
+ r = r.get_value()
+ if not isinstance(r, bool):
+ raise InterpreterException('Second argument to "or" is not a boolean.')
+ return r
+
def evaluate_arraystatement(self, cur):
(arguments, kwargs) = self.reduce_arguments(cur.get_args())
if len(kwargs) > 0: