Mercurial Hosting > luan
diff src/luan/lib/BasicLib.java @ 108:3c404a296995
make Package module more standard;
return _ENV by default;
add "import" statement;
git-svn-id: https://luan-java.googlecode.com/svn/trunk@109 21e917c8-12df-6dd8-5cb6-c86387c605b9
author | fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9> |
---|---|
date | Fri, 23 May 2014 03:21:54 +0000 |
parents | b1e87f1bcc13 |
children | 219e05867366 |
line wrap: on
line diff
--- a/src/luan/lib/BasicLib.java Mon May 19 09:17:57 2014 +0000 +++ b/src/luan/lib/BasicLib.java Fri May 23 03:21:54 2014 +0000 @@ -10,7 +10,6 @@ import luan.LuanState; import luan.LuanTable; import luan.LuanFunction; -import luan.LuanLoader; import luan.LuanJavaFunction; import luan.LuanException; import luan.LuanSource; @@ -22,11 +21,10 @@ public static final String NAME = "Basic"; - public static final LuanLoader LOADER = new LuanLoader() { - @Override protected void load(LuanState luan) { + public static final LuanFunction LOADER = new LuanFunction() { + @Override public Object[] call(LuanState luan,Object[] args) { LuanTable module = new LuanTable(); - LuanTable global = new LuanTable(); - module.put( LuanState._G, global ); + LuanTable global = luan.global(); try { global.put( "assert", new LuanJavaFunction(BasicLib.class.getMethod("assert_",LuanState.class,Object.class,String.class),null) ); add( global, "assert_boolean", LuanState.class, Boolean.TYPE ); @@ -34,12 +32,12 @@ add( global, "assert_number", LuanState.class, Number.class ); add( global, "assert_string", LuanState.class, String.class ); add( global, "assert_table", LuanState.class, LuanTable.class ); - add( global, "do_file", LuanState.class, String.class, LuanTable.class ); + add( global, "do_file", LuanState.class, String.class ); add( global, "error", LuanState.class, Object.class ); add( global, "get_metatable", LuanState.class, Object.class ); add( global, "ipairs", LuanState.class, LuanTable.class ); - add( global, "load", LuanState.class, String.class, String.class, LuanTable.class ); - add( global, "load_file", LuanState.class, String.class, LuanTable.class ); + add( global, "load", LuanState.class, String.class, String.class, Boolean.class ); + add( global, "load_file", LuanState.class, String.class ); add( global, "pairs", LuanState.class, LuanTable.class ); add( global, "print", LuanState.class, new Object[0].getClass() ); add( global, "raw_equal", Object.class, Object.class ); @@ -55,7 +53,7 @@ } catch(NoSuchMethodException e) { throw new RuntimeException(e); } - luan.loaded().put(NAME,module); + return new Object[]{module}; } }; @@ -76,22 +74,25 @@ return Luan.type(obj); } - public static LuanFunction load(LuanState luan,String text,String sourceName,LuanTable env) throws LuanException { - return LuanCompiler.compile(luan,new LuanSource(sourceName,text),env); + public static LuanFunction load(LuanState luan,String text,String sourceName,Boolean interactive) throws LuanException { + if( interactive!=null && interactive ) + return LuanCompiler.compileInteractive(luan,new LuanSource(sourceName,text)); + else + return LuanCompiler.compileModule(luan,new LuanSource(sourceName,text)); } - public static LuanFunction load_file(LuanState luan,String fileName,LuanTable env) throws LuanException { + public static LuanFunction load_file(LuanState luan,String fileName) throws LuanException { try { String src = fileName==null ? Utils.readAll(new InputStreamReader(System.in)) : Utils.read(new File(fileName)); - return load(luan,src,fileName,env); + return load(luan,src,fileName,false); } catch(IOException e) { throw luan.JAVA.exception(e); } } - public static Object[] do_file(LuanState luan,String fileName,LuanTable env) throws LuanException { - LuanFunction fn = load_file(luan,fileName,env); + public static Object[] do_file(LuanState luan,String fileName) throws LuanException { + LuanFunction fn = load_file(luan,fileName); return luan.JAVA.call(fn,null); }