changeset 661:1bbb08c0d8f1

compile LocalFunctionStmt
author Franklin Schmidt <fschmidt@gmail.com>
date Wed, 06 Apr 2016 21:19:30 -0600 (2016-04-07)
parents e064377994b2
children ee00a619eec1
files core/src/luan/impl/LuanParser.java
diffstat 1 files changed, 7 insertions(+), 9 deletions(-) [+]
line wrap: on
line diff
--- a/core/src/luan/impl/LuanParser.java	Wed Apr 06 21:06:29 2016 -0600
+++ b/core/src/luan/impl/LuanParser.java	Wed Apr 06 21:19:30 2016 -0600
@@ -249,7 +249,7 @@
 		StmtString stmt;
 		if( (stmt=ReturnStmt()) != null
 			|| (stmt=FunctionStmt()) != null
-			|| (stmt=stmtStr(LocalFunctionStmt())) != null
+			|| (stmt=LocalFunctionStmt()) != null
 			|| (stmt=BreakStmt()) != null
 			|| (stmt=ForStmt()) != null
 			|| (stmt=DoStmt()) != null
@@ -357,14 +357,16 @@
 		return parser.success( var.set(new ExpString(fnDef)) );
 	}
 
-	private Stmt LocalFunctionStmt() throws ParseException {
+	private StmtString LocalFunctionStmt() throws ParseException {
 		parser.begin();
 		if( !(Keyword("local",In.NOTHING) && Keyword("function",In.NOTHING)) )
 			return parser.failure(null);
 		String name = RequiredName(In.NOTHING);
 		addSymbol( name );
 		FnDef fnDef = RequiredFunction(In.NOTHING);
-		return parser.success( new SetStmt( new SetLocalVar(symbolsSize()-1), fnDef ) );
+		Settable s = new SetLocalVar(symbolsSize()-1);
+		String code = new SettableString(s).code + ".set(luan," + new ExpString(fnDef).code + ");\n";
+		return parser.success( new StmtString(code) );
 	}
 
 	private StmtString BreakStmt() throws ParseException {
@@ -1563,13 +1565,13 @@
 
 	private static class StmtString {
 		final String code;
-
+/*
 		StmtString(Stmt stmt) {
 			if( stmt==null )  throw new NullPointerException();
 			int i = LuanImpl.addStmt(stmt);
 			code = "LuanImpl.getStmt(" + i + ").eval(luan);\n";
 		}
-
+*/
 		StmtString(String code) {
 			this.code = code;
 			if( code.contains("LuanParser") )  throw new RuntimeException("\n"+code);
@@ -1611,10 +1613,6 @@
 		return stmtStr==null ? null : stmtStr.toStmt();
 	}
 
-	private static StmtString stmtStr(Stmt stmt) {
-		return stmt==null ? null : new StmtString(stmt);
-	}
-
 
 	private static class SettableString {
 		final String code;