diff src/luan/lib/BasicLib.java @ 30:8d8f4f5caef4

minor git-svn-id: https://luan-java.googlecode.com/svn/trunk@31 21e917c8-12df-6dd8-5cb6-c86387c605b9
author fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9>
date Fri, 07 Dec 2012 20:22:19 +0000
parents 9bc66d09ea48
children 0cdc1da466ee
line wrap: on
line diff
--- a/src/luan/lib/BasicLib.java	Fri Dec 07 09:33:31 2012 +0000
+++ b/src/luan/lib/BasicLib.java	Fri Dec 07 20:22:19 2012 +0000
@@ -7,11 +7,6 @@
 import java.lang.reflect.Method;
 import java.util.Iterator;
 import java.util.Map;
-import org.parboiled.Parboiled;
-import org.parboiled.errors.ErrorUtils;
-import org.parboiled.parserunners.ReportingParseRunner;
-import org.parboiled.parserunners.TracingParseRunner;
-import org.parboiled.support.ParsingResult;
 import luan.Lua;
 import luan.LuaState;
 import luan.LuaTable;
@@ -19,9 +14,7 @@
 import luan.LuaFunction;
 import luan.LuaJavaFunction;
 import luan.LuaException;
-import luan.interp.LuaParser;
-import luan.interp.Expressions;
-import luan.interp.Chunk;
+import luan.interp.LuaCompiler;
 
 
 public class BasicLib {
@@ -58,22 +51,7 @@
 	}
 
 	public static LuaFunction load(LuaState lua,String ld) throws LuaException {
-		LuaParser parser = Parboiled.createParser(LuaParser.class);
-		ParsingResult<?> result = new ReportingParseRunner(parser.Target()).run(ld);
-//		ParsingResult<?> result = new TracingParseRunner(parser.Target()).run(ld);
-		if( result.hasErrors() )
-			throw new LuaException( ErrorUtils.printParseErrors(result) );
-		Object resultValue = result.resultValue;
-		if( resultValue instanceof Expressions ) {
-			final Expressions expressions = (Expressions)resultValue;
-			return new LuaFunction() {
-				public Object[] call(LuaState lua,Object... args) throws LuaException {
-					return expressions.eval(lua);
-				}
-			};
-		}
-		Chunk chunk = (Chunk)resultValue;
-		return chunk.newClosure(lua);
+		return LuaCompiler.compile(lua,ld);
 	}
 
 	public static String readAll(Reader in)