aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/nivis/interpreter.py
diff options
context:
space:
mode:
author简律纯 <i@jyunko.cn>2024-02-25 12:00:16 +0800
committer简律纯 <i@jyunko.cn>2024-02-25 12:00:16 +0800
commite2c1c1911e117245551a612499d02eacabbbe5d8 (patch)
tree91c98463bdc1397667ae8d13acb56d83ff347c6e /nivis/interpreter.py
parent1199a75378efcaf756e2027ecc2530c6d97bc95c (diff)
downloadTRPGNivis-e2c1c1911e117245551a612499d02eacabbbe5d8.tar.gz
TRPGNivis-e2c1c1911e117245551a612499d02eacabbbe5d8.zip
refactor: rename nivis-python to nivis
Diffstat (limited to 'nivis/interpreter.py')
-rw-r--r--nivis/interpreter.py76
1 files changed, 76 insertions, 0 deletions
diff --git a/nivis/interpreter.py b/nivis/interpreter.py
new file mode 100644
index 0000000..6322180
--- /dev/null
+++ b/nivis/interpreter.py
@@ -0,0 +1,76 @@
+from .lexer import Token
+
+
+__all__ = ["Interpreter"]
+
+
+class Interpreter:
+ """
+ A class representing an interpreter for Psi code.
+
+ Args:
+ ast: The abstract syntax tree (AST) of the code to be interpreted.
+
+ Returns:
+ None
+
+ Example:
+ ```python
+ interpreter = Interpreter(ast)
+ interpreter.interpret()
+ ```
+ """
+
+ def __init__(self, ast):
+ """
+ Initializes an Interpreter object.
+
+ Args:
+ ast: The abstract syntax tree (AST) of the code to be interpreted.
+
+ Returns:
+ None
+ """
+ self.ast = ast
+
+ def interpret(self):
+ """
+ Interprets the code represented by the AST.
+
+ Returns:
+ The result of the interpretation.
+ """
+ return self.interpret_expr(self.ast)
+
+ def interpret_expr(self, node):
+ """
+ Interprets an expression node in the AST.
+
+ Args:
+ node: The expression node to be interpreted.
+
+ Returns:
+ The result of the interpretation.
+ """
+ if isinstance(node, Token):
+ return node.value
+ elif isinstance(node, list):
+ for expr in node:
+ result = self.interpret_expr(expr)
+ if result is not None:
+ return result
+
+ def interpret_condition(self, node):
+ """
+ Interprets a condition node in the AST.
+
+ Args:
+ node: The condition node to be interpreted.
+
+ Returns:
+ The result of the interpretation.
+ """
+ variable = self.interpret_expr(node[0])
+ value = self.interpret_expr(node[2])
+
+ return variable == value