aboutsummaryrefslogtreecommitdiffstats
path: root/src/com/craftinginterpreters/lox/LoxFunction.java
diff options
context:
space:
mode:
authorGravatar Tom Willemse2021-06-12 12:17:43 -0700
committerGravatar Tom Willemse2021-06-12 12:17:43 -0700
commit958ba22a570594ed2ce60d24cd082ce3b8a6b89a (patch)
tree81c48eb2de22314be24449b2333d84e465d2c8f6 /src/com/craftinginterpreters/lox/LoxFunction.java
parente62d1a209e352306f36879dadd85773167e06246 (diff)
downloadcrafting-interpreters-958ba22a570594ed2ce60d24cd082ce3b8a6b89a.tar.gz
crafting-interpreters-958ba22a570594ed2ce60d24cd082ce3b8a6b89a.zip
12.7 Constructors and Initializers
Diffstat (limited to 'src/com/craftinginterpreters/lox/LoxFunction.java')
-rw-r--r--src/com/craftinginterpreters/lox/LoxFunction.java11
1 files changed, 9 insertions, 2 deletions
diff --git a/src/com/craftinginterpreters/lox/LoxFunction.java b/src/com/craftinginterpreters/lox/LoxFunction.java
index 371b822..07dd727 100644
--- a/src/com/craftinginterpreters/lox/LoxFunction.java
+++ b/src/com/craftinginterpreters/lox/LoxFunction.java
@@ -5,8 +5,10 @@ import java.util.List;
class LoxFunction implements LoxCallable {
private final Stmt.Function declaration;
private final Environment closure;
+ private final boolean isInitializer;
- LoxFunction(Stmt.Function declaration, Environment closure) {
+ LoxFunction(Stmt.Function declaration, Environment closure, boolean isInitializer) {
+ this.isInitializer = isInitializer;
this.closure = closure;
this.declaration = declaration;
}
@@ -14,7 +16,7 @@ class LoxFunction implements LoxCallable {
LoxFunction bind(LoxInstance instance) {
Environment environment = new Environment(closure);
environment.define("this", instance);
- return new LoxFunction(declaration, environment);
+ return new LoxFunction(declaration, environment, isInitializer);
}
@Override
@@ -33,8 +35,13 @@ class LoxFunction implements LoxCallable {
try {
interpreter.executeBlock(declaration.body, environment);
} catch (Return returnValue) {
+ if (isInitializer)
+ return closure.getAt(0, "this");
return returnValue.value;
}
+
+ if (isInitializer)
+ return closure.getAt(0, "this");
return null;
}