Mercurial Hosting > luan
changeset 1283:503bde9a7c80
add luan.require() and table.call()
author | Franklin Schmidt <fschmidt@gmail.com> |
---|---|
date | Fri, 21 Dec 2018 09:12:09 -0700 (2018-12-21) |
parents | 2531942abaf3 |
children | 1b46c8e6c647 |
files | src/luan/LuanException.java src/luan/LuanState.java src/luan/LuanTable.java src/luan/modules/Boot.luan src/luan/modules/PackageLuan.java src/luan/modules/http/HttpServicer.java src/luan/modules/http/LuanHandler.java |
diffstat | 7 files changed, 43 insertions(+), 52 deletions(-) [+] |
line wrap: on
line diff
--- a/src/luan/LuanException.java Thu Dec 20 17:44:34 2018 -0700 +++ b/src/luan/LuanException.java Fri Dec 21 09:12:09 2018 -0700 @@ -33,27 +33,10 @@ public LuanTable table(LuanState luan) { if( table==null ) { - table = new LuanTable(luan); - table.rawPut( "java", this ); - LuanTable metatable = new LuanTable(luan); - table.setMetatable(metatable); try { - table.rawPut( "get_message", new LuanJavaFunction( - LuanException.class.getMethod( "getMessage" ), this - ) ); - table.rawPut( "throw", new LuanJavaFunction( - LuanException.class.getMethod( "throwThis" ), this - ) ); - table.rawPut( "get_stack_trace_string", new LuanJavaFunction( - LuanException.class.getMethod( "getLuanStackTraceString" ), this - ) ); - table.rawPut( "get_java_stack_trace_string", new LuanJavaFunction( - LuanException.class.getMethod( "getJavaStackTraceString" ), this - ) ); - metatable.rawPut( "__to_string", new LuanJavaFunction( - LuanException.class.getMethod( "__to_string", LuanTable.class ), this - ) ); - } catch(NoSuchMethodException e) { + LuanTable Boot = (LuanTable)luan.require("luan:Boot.luan"); + table = (LuanTable)Boot.call( "new_error_table", this ); + } catch(LuanException e) { throw new RuntimeException(e); } } @@ -64,10 +47,6 @@ throw this; } - public String __to_string(LuanTable ignore) { - return getLuanStackTraceString(); - } - public String getJavaStackTraceString() { return getJavaStackTraceString(this); }
--- a/src/luan/LuanState.java Thu Dec 20 17:44:34 2018 -0700 +++ b/src/luan/LuanState.java Fri Dec 21 09:12:09 2018 -0700 @@ -14,6 +14,7 @@ import luan.impl.LuanCompiler; import luan.modules.BasicLuan; import luan.modules.JavaLuan; +import luan.modules.PackageLuan; public final class LuanState implements LuanCloneable { @@ -56,15 +57,13 @@ onClose.onClose(c); } - public final Object eval(String cmd,Object... args) throws LuanException { + public Object eval(String cmd,Object... args) throws LuanException { return Luan.load(cmd,"eval").call(this,args); } -/* - public final Object eval(String cmd,LuanTable env) throws LuanException { - LuanFunction fn = BasicLuan.load(this,cmd,"eval",env,true); - return fn.call(this); + + public Object require(String modName) throws LuanException { + return PackageLuan.require(this,modName); } -*/ public String toString(Object obj) throws LuanException { if( obj instanceof LuanTable ) {
--- a/src/luan/LuanTable.java Thu Dec 20 17:44:34 2018 -0700 +++ b/src/luan/LuanTable.java Fri Dec 21 09:12:09 2018 -0700 @@ -512,4 +512,8 @@ super.finalize(); } + public Object call(String fnName,Object... args) throws LuanException { + LuanFunction fn = Luan.checkFunction(get(fnName)); + return fn.call(luan,args); + } }
--- a/src/luan/modules/Boot.luan Thu Dec 20 17:44:34 2018 -0700 +++ b/src/luan/modules/Boot.luan Fri Dec 21 09:12:09 2018 -0700 @@ -4,6 +4,7 @@ local BasicLuan = require "java:luan.modules.BasicLuan" local new_error = BasicLuan.new_error local ipairs = BasicLuan.ipairs +local set_metatable = BasicLuan.set_metatable local StringLuan = require "java:luan.modules.StringLuan" local match = StringLuan.match -- String.match local IoLuan = require "java:luan.modules.IoLuan" @@ -185,4 +186,22 @@ end +local error_mt = {} + +function error_mt.__to_string(t) + return t.java.getLuanStackTraceString() +end + +function Boot.new_error_table(ex) -- for LuanException.java + local this = {} + set_metatable(this,error_mt) + this.java = ex + this.get_message = ex.getMessage + this.throw = ex.throwThis + this.get_stack_trace_string = ex.getLuanStackTraceString + this.get_java_stack_trace_string = ex.getLuanStackTraceString + return this +end + + return Boot
--- a/src/luan/modules/PackageLuan.java Thu Dec 20 17:44:34 2018 -0700 +++ b/src/luan/modules/PackageLuan.java Fri Dec 21 09:12:09 2018 -0700 @@ -87,9 +87,8 @@ } static String read(LuanState luan,String uri) throws LuanException { - LuanTable boot = (LuanTable)PackageLuan.require(luan,"luan:Boot.luan"); - LuanFunction read = (LuanFunction)boot.get("read"); - return (String)Luan.first(read.call(luan,new Object[]{uri})); + LuanTable boot = (LuanTable)luan.require("luan:Boot.luan"); + return (String)Luan.first(boot.call("read",uri)); } public static void enableLoad(LuanState luan,String... mods) throws LuanException {
--- a/src/luan/modules/http/HttpServicer.java Thu Dec 20 17:44:34 2018 -0700 +++ b/src/luan/modules/http/HttpServicer.java Fri Dec 21 09:12:09 2018 -0700 @@ -33,9 +33,8 @@ LuanCloner cloner = new LuanCloner(LuanCloner.Type.INCREMENTAL); luan = (LuanState)cloner.clone(luan); } - LuanTable module = (LuanTable)PackageLuan.require(luan,"luan:http/Http.luan"); - LuanFunction fn = (LuanFunction)module.rawGet("handle_error"); - return (Response)fn.call( luan, new Object[]{request,e.table(luan)} ); + LuanTable module = (LuanTable)luan.require("luan:http/Http.luan"); + return (Response)module.call( "handle_error", request, e.table(luan) ); } private static Response serviceLuan(LuanState luan,Request request,String modName) @@ -55,21 +54,13 @@ fn = (LuanFunction)cloner.get(mod); } - LuanTable module = (LuanTable)PackageLuan.require(luan,"luan:http/Http.luan"); - - // request - LuanFunction newRequestFn = (LuanFunction)module.rawGet("new_request"); - newRequestFn.call( luan, new Object[]{request} ); - - // response - LuanFunction newResponseFn = (LuanFunction)module.rawGet("new_response"); - newResponseFn.call(luan); + LuanTable module = (LuanTable)luan.require("luan:http/Http.luan"); + module.call( "new_request", request ); + module.call( "new_response" ); fn.call(luan); - LuanFunction finishFn = (LuanFunction)module.rawGet("finish"); - Response response = (Response)finishFn.call(luan); - return response; + return (Response)module.call( "finish" ); } private HttpServicer() {} // never
--- a/src/luan/modules/http/LuanHandler.java Thu Dec 20 17:44:34 2018 -0700 +++ b/src/luan/modules/http/LuanHandler.java Fri Dec 21 09:12:09 2018 -0700 @@ -55,9 +55,9 @@ loggerRoot = ""; logger = LoggerFactory.getLogger(loggerRoot+LuanHandler.class.getName()); try { - LuanTable Http = (LuanTable)PackageLuan.require(luanInit,"luan:http/Http.luan"); - Http.rawPut( "reset_luan", new LuanJavaFunction(resetLuanMethod,this) ); - Http.rawPut( "eval_in_root", new LuanJavaFunction(evalInRootMethod,this) ); + LuanTable Http = (LuanTable)luanInit.require("luan:http/Http.luan"); + Http.put( "reset_luan", new LuanJavaFunction(resetLuanMethod,this) ); + Http.put( "eval_in_root", new LuanJavaFunction(evalInRootMethod,this) ); } catch(LuanException e) { throw new RuntimeException(e); } @@ -136,7 +136,7 @@ LuanState luan = currentLuan; synchronized(luan) { PackageLuan.enableLoad(luan,"luan:Rpc.luan"); - LuanTable rpc = (LuanTable)PackageLuan.require(luan,"luan:Rpc.luan"); + LuanTable rpc = (LuanTable)luan.require("luan:Rpc.luan"); LuanTable fns = (LuanTable)rpc.get("functions"); fn = (LuanFunction)fns.get(fnName); if( fn == null )