Mercurial Hosting > luan
changeset 427:dae264ad6a7b
fix LuanTable.put() to use metatables
author | Franklin Schmidt <fschmidt@gmail.com> |
---|---|
date | Fri, 01 May 2015 19:29:07 -0600 (2015-05-02) |
parents | 23a93c118042 |
children | df95199ca4c0 |
files | core/src/luan/LuanMeta.java core/src/luan/LuanPropertyMeta.java core/src/luan/LuanTable.java core/src/luan/impl/SetTableEntry.java core/src/luan/impl/TableExpr.java core/src/luan/modules/BasicLuan.java core/src/luan/modules/HtmlLuan.java core/src/luan/modules/IoLuan.java core/src/luan/modules/JavaLuan.java core/src/luan/modules/PackageLuan.java core/src/luan/modules/PickleClient.java core/src/luan/modules/PickleCon.java core/src/luan/modules/PickleServer.java core/src/luan/modules/TableLuan.java lucene/src/luan/modules/lucene/LuceneDocument.java lucene/src/luan/modules/lucene/LuceneIndex.java lucene/src/luan/modules/lucene/LuceneSearcher.java lucene/src/luan/modules/lucene/LuceneWriter.java web/src/luan/modules/web/HttpServicer.java |
diffstat | 19 files changed, 137 insertions(+), 133 deletions(-) [+] |
line wrap: on
line diff
--- a/core/src/luan/LuanMeta.java Fri May 01 18:44:20 2015 -0600 +++ b/core/src/luan/LuanMeta.java Fri May 01 19:29:07 2015 -0600 @@ -53,11 +53,11 @@ public LuanTable newMetatable() { LuanTable mt = new LuanTable(); - mt.put( "__index", this ); - mt.put( "__pairs", this ); - mt.put( "__tostring", this ); + mt.rawPut( "__index", this ); + mt.rawPut( "__pairs", this ); + mt.rawPut( "__tostring", this ); if( canNewindex() ) - mt.put( "__newindex", this ); + mt.rawPut( "__newindex", this ); return mt; }
--- a/core/src/luan/LuanPropertyMeta.java Fri May 01 18:44:20 2015 -0600 +++ b/core/src/luan/LuanPropertyMeta.java Fri May 01 19:29:07 2015 -0600 @@ -64,9 +64,9 @@ @Override public LuanTable newMetatable() { LuanTable mt = super.newMetatable(); - mt.put( "get", new LuanTable() ); - mt.put( "set", new LuanTable() ); - mt.put( "type", "property" ); + mt.rawPut( "get", new LuanTable() ); + mt.rawPut( "set", new LuanTable() ); + mt.rawPut( "type", "property" ); return mt; }
--- a/core/src/luan/LuanTable.java Fri May 01 18:44:20 2015 -0600 +++ b/core/src/luan/LuanTable.java Fri May 01 19:29:07 2015 -0600 @@ -126,7 +126,31 @@ return map.get(key); } - public void put(Object key,Object val) { + public void put(LuanState luan,Object key,Object value) throws LuanException { + Object h = getHandler("__newindex"); + if( h==null || rawGet(key)!=null ) { + rawPut(key,value); + return; + } + if( h instanceof LuanFunction ) { + LuanFunction fn = (LuanFunction)h; + luan.call(fn,"__newindex",new Object[]{this,key,value}); + return; + } + if( h instanceof LuanMeta ) { + LuanMeta meta = (LuanMeta)h; + meta.__newindex(luan,this,key,value); + return; + } + if( h instanceof LuanTable ) { + LuanTable tbl = (LuanTable)h; + tbl.put(luan,key,value); + return; + } + throw luan.exception("invalid type "+Luan.type(h)+" for metamethod __newindex"); + } + + public void rawPut(Object key,Object val) { Integer iT = Luan.asInteger(key); if( iT != null ) { int i = iT - 1;
--- a/core/src/luan/impl/SetTableEntry.java Fri May 01 18:44:20 2015 -0600 +++ b/core/src/luan/impl/SetTableEntry.java Fri May 01 19:29:07 2015 -0600 @@ -25,29 +25,9 @@ private void newindex(LuanStateImpl luan,Object t,Object key,Object value) throws LuanException { if( t instanceof LuanTable ) { - LuanTable table = (LuanTable)t; - Object h = table.getHandler("__newindex"); - if( h==null || table.rawGet(key)!=null ) { - try { - table.put(key,value); - } catch(IllegalArgumentException e) { - throw luan.bit(se).exception(e); - } catch(UnsupportedOperationException e) { - throw luan.bit(se).exception(e); - } - return; - } - if( h instanceof LuanFunction ) { - LuanFunction fn = (LuanFunction)h; - luan.bit(se).call(fn,"__newindex",new Object[]{t,key,value}); - return; - } - if( h instanceof LuanMeta ) { - LuanMeta meta = (LuanMeta)h; - meta.__newindex(luan,table,key,value); - return; - } - newindex(luan,h,key,value); + LuanTable tbl = (LuanTable)t; + tbl.put(luan,key,value); + return; } if( t != null && luan.currentEnvironment().hasJava() ) JavaLuan.__newindex(luan,t,key,value);
--- a/core/src/luan/impl/TableExpr.java Fri May 01 18:44:20 2015 -0600 +++ b/core/src/luan/impl/TableExpr.java Fri May 01 19:29:07 2015 -0600 @@ -30,16 +30,16 @@ @Override public Object eval(LuanStateImpl luan) throws LuanException { LuanTable table = new LuanTable(); for( Field field : fields ) { - table.put( field.key.eval(luan), field.value.eval(luan) ); + table.rawPut( field.key.eval(luan), field.value.eval(luan) ); } Object obj = expressions.eval(luan); if( obj instanceof Object[] ) { Object[] a = (Object[])obj; for( int i=0; i<a.length; i++ ) { - table.put( i+1, a[i] ); + table.rawPut( i+1, a[i] ); } } else { - table.put( 1, obj ); + table.rawPut( 1, obj ); } return table; }
--- a/core/src/luan/modules/BasicLuan.java Fri May 01 18:44:20 2015 -0600 +++ b/core/src/luan/modules/BasicLuan.java Fri May 01 19:29:07 2015 -0600 @@ -110,7 +110,7 @@ } public static LuanTable raw_set(LuanTable table,Object index,Object value) { - table.put(index,value); + table.rawPut(index,value); return table; }
--- a/core/src/luan/modules/HtmlLuan.java Fri May 01 18:44:20 2015 -0600 +++ b/core/src/luan/modules/HtmlLuan.java Fri May 01 19:29:07 2015 -0600 @@ -141,23 +141,23 @@ static LuanTable comment(String text) { LuanTable tbl = new LuanTable(); - tbl.put("type","comment"); - tbl.put("text",text); + tbl.rawPut("type","comment"); + tbl.rawPut("text",text); return tbl; } static LuanTable cdata(String text) { LuanTable tbl = new LuanTable(); - tbl.put("type","cdata"); - tbl.put("text",text); + tbl.rawPut("type","cdata"); + tbl.rawPut("text",text); return tbl; } static LuanTable textContainer(LuanTable tag,String text) { LuanTable tbl = new LuanTable(); - tbl.put("type","container"); - tbl.put("tag",tag); - tbl.put("text",text); + tbl.rawPut("type","container"); + tbl.rawPut("tag",tag); + tbl.rawPut("text",text); return tbl; } @@ -171,12 +171,12 @@ static LuanTable parseTag(String text) { LuanTable tbl = new LuanTable(); - tbl.put("type","tag"); + tbl.rawPut("type","tag"); if( text.endsWith("/") ) { text = text.substring(0,text.length()-1); - tbl.put("is_empty",true); + tbl.rawPut("is_empty",true); } else { - tbl.put("is_empty",false); + tbl.rawPut("is_empty",false); } int len = text.length(); int i = 0; @@ -192,9 +192,9 @@ i2++; } String name = text.substring(i,i2).toLowerCase(); - tbl.put("name",name); + tbl.rawPut("name",name); LuanTable attributes = new LuanTable(); - tbl.put("attributes",attributes); + tbl.rawPut("attributes",attributes); i = i2; while( i<len && Character.isWhitespace(text.charAt(i)) ) i++; while( i<len ) { @@ -213,11 +213,11 @@ if( attrValue.indexOf('<') != -1 || attrValue.indexOf('>') != -1 ) throw new BadTag("invalid attribute value: "+attrValue); attrValue = unquote(attrValue); - attributes.put(attrName,attrValue); + attributes.rawPut(attrName,attrValue); i = i2; while( i<len && Character.isWhitespace(text.charAt(i)) ) i++; } else { - attributes.put(attrName,true); + attributes.rawPut(attrName,true); } } return tbl;
--- a/core/src/luan/modules/IoLuan.java Fri May 01 18:44:20 2015 -0600 +++ b/core/src/luan/modules/IoLuan.java Fri May 01 19:29:07 2015 -0600 @@ -38,7 +38,7 @@ public final class IoLuan { private static void add(LuanTable t,String method,Class<?>... parameterTypes) throws NoSuchMethodException { - t.put( method, new LuanJavaFunction(IoLuan.class.getMethod(method,parameterTypes),null) ); + t.rawPut( method, new LuanJavaFunction(IoLuan.class.getMethod(method,parameterTypes),null) ); } public static String read_console_line(String prompt) throws IOException { @@ -88,10 +88,10 @@ private static LuanTable writer(LuanWriter luanWriter) { LuanTable writer = new LuanTable(); try { - writer.put( "write", new LuanJavaFunction( + writer.rawPut( "write", new LuanJavaFunction( LuanWriter.class.getMethod( "write", LuanState.class, new Object[0].getClass() ), luanWriter ) ); - writer.put( "close", new LuanJavaFunction( + writer.rawPut( "close", new LuanJavaFunction( LuanWriter.class.getMethod( "close" ), luanWriter ) ); } catch(NoSuchMethodException e) { @@ -104,10 +104,10 @@ public static LuanTable binaryWriter(final OutputStream out) { LuanTable writer = new LuanTable(); try { - writer.put( "write", new LuanJavaFunction( + writer.rawPut( "write", new LuanJavaFunction( OutputStream.class.getMethod( "write", new byte[0].getClass() ), out ) ); - writer.put( "close", new LuanJavaFunction( + writer.rawPut( "close", new LuanJavaFunction( OutputStream.class.getMethod( "close" ), out ) ); } catch(NoSuchMethodException e) { @@ -206,22 +206,22 @@ public LuanTable table() { LuanTable tbl = new LuanTable(); try { - tbl.put( "to_string", new LuanJavaFunction( + tbl.rawPut( "to_string", new LuanJavaFunction( LuanIn.class.getMethod( "to_string" ), this ) ); - tbl.put( "read_text", new LuanJavaFunction( + tbl.rawPut( "read_text", new LuanJavaFunction( LuanIn.class.getMethod( "read_text" ), this ) ); - tbl.put( "read_binary", new LuanJavaFunction( + tbl.rawPut( "read_binary", new LuanJavaFunction( LuanIn.class.getMethod( "read_binary" ), this ) ); - tbl.put( "read_lines", new LuanJavaFunction( + tbl.rawPut( "read_lines", new LuanJavaFunction( LuanIn.class.getMethod( "read_lines" ), this ) ); - tbl.put( "read_blocks", new LuanJavaFunction( + tbl.rawPut( "read_blocks", new LuanJavaFunction( LuanIn.class.getMethod( "read_blocks", Integer.class ), this ) ); - tbl.put( "exists", new LuanJavaFunction( + tbl.rawPut( "exists", new LuanJavaFunction( LuanIn.class.getMethod( "exists" ), this ) ); } catch(NoSuchMethodException e) { @@ -286,13 +286,13 @@ @Override public LuanTable table() { LuanTable tbl = super.table(); try { - tbl.put( "write", new LuanJavaFunction( + tbl.rawPut( "write", new LuanJavaFunction( LuanIO.class.getMethod( "write", LuanState.class, Object.class ), this ) ); - tbl.put( "text_writer", new LuanJavaFunction( + tbl.rawPut( "text_writer", new LuanJavaFunction( LuanIO.class.getMethod( "text_writer" ), this ) ); - tbl.put( "binary_writer", new LuanJavaFunction( + tbl.rawPut( "binary_writer", new LuanJavaFunction( LuanIO.class.getMethod( "binary_writer" ), this ) ); } catch(NoSuchMethodException e) { @@ -373,7 +373,7 @@ @Override public LuanTable table() { LuanTable tbl = super.table(); try { - tbl.put( "post", new LuanJavaFunction( + tbl.rawPut( "post", new LuanJavaFunction( LuanUrl.class.getMethod( "post", String.class ), this ) ); } catch(NoSuchMethodException e) { @@ -444,40 +444,40 @@ @Override public LuanTable table() { LuanTable tbl = super.table(); try { - tbl.put( "name", new LuanJavaFunction( + tbl.rawPut( "name", new LuanJavaFunction( File.class.getMethod( "getName" ), file ) ); - tbl.put( "is_directory", new LuanJavaFunction( + tbl.rawPut( "is_directory", new LuanJavaFunction( File.class.getMethod( "isDirectory" ), file ) ); - tbl.put( "is_file", new LuanJavaFunction( + tbl.rawPut( "is_file", new LuanJavaFunction( File.class.getMethod( "isFile" ), file ) ); - tbl.put( "delete", new LuanJavaFunction( + tbl.rawPut( "delete", new LuanJavaFunction( File.class.getMethod( "delete" ), file ) ); - tbl.put( "mkdir", new LuanJavaFunction( + tbl.rawPut( "mkdir", new LuanJavaFunction( File.class.getMethod( "mkdir" ), file ) ); - tbl.put( "mkdirs", new LuanJavaFunction( + tbl.rawPut( "mkdirs", new LuanJavaFunction( File.class.getMethod( "mkdirs" ), file ) ); - tbl.put( "last_modified", new LuanJavaFunction( + tbl.rawPut( "last_modified", new LuanJavaFunction( File.class.getMethod( "lastModified" ), file ) ); - tbl.put( "child", new LuanJavaFunction( + tbl.rawPut( "child", new LuanJavaFunction( LuanFile.class.getMethod( "child", LuanState.class, String.class ), this ) ); - tbl.put( "children", new LuanJavaFunction( + tbl.rawPut( "children", new LuanJavaFunction( LuanFile.class.getMethod( "children", LuanState.class ), this ) ); - tbl.put( "parent", new LuanJavaFunction( + tbl.rawPut( "parent", new LuanJavaFunction( LuanFile.class.getMethod( "parent", LuanState.class ), this ) ); - tbl.put( "rename_to", new LuanJavaFunction( + tbl.rawPut( "rename_to", new LuanJavaFunction( LuanFile.class.getMethod( "rename_to", String.class ), this ) ); - tbl.put( "canonical", new LuanJavaFunction( + tbl.rawPut( "canonical", new LuanJavaFunction( LuanFile.class.getMethod( "canonical", LuanState.class ), this ) ); } catch(NoSuchMethodException e) { @@ -627,10 +627,10 @@ @Override public LuanTable table() { LuanTable tbl = super.table(); try { - tbl.put( "Pickle_client", new LuanJavaFunction( + tbl.rawPut( "Pickle_client", new LuanJavaFunction( LuanSocket.class.getMethod( "Pickle_client", LuanState.class ), this ) ); - tbl.put( "run_pickle_server", new LuanJavaFunction( + tbl.rawPut( "run_pickle_server", new LuanJavaFunction( LuanSocket.class.getMethod( "run_pickle_server", LuanState.class ), this ) ); } catch(NoSuchMethodException e) { @@ -685,7 +685,7 @@ } public static void setSecurity(LuanState luan,Security s) { - luan.registry().put(SECURITY_KEY,s); + luan.registry().rawPut(SECURITY_KEY,s); } private void IoLuan() {} // never
--- a/core/src/luan/modules/JavaLuan.java Fri May 01 18:44:20 2015 -0600 +++ b/core/src/luan/modules/JavaLuan.java Fri May 01 19:29:07 2015 -0600 @@ -471,7 +471,7 @@ } public static void setSecurity(LuanState luan,Security s) { - luan.registry().put(SECURITY_KEY,s); + luan.registry().rawPut(SECURITY_KEY,s); } }
--- a/core/src/luan/modules/PackageLuan.java Fri May 01 18:44:20 2015 -0600 +++ b/core/src/luan/modules/PackageLuan.java Fri May 01 19:29:07 2015 -0600 @@ -27,7 +27,7 @@ LuanTable tbl = (LuanTable)luan.registry().rawGet("Package.loaded"); if( tbl == null ) { tbl = new LuanTable(); - luan.registry().put("Package.loaded",tbl); + luan.registry().rawPut("Package.loaded",tbl); } return tbl; } @@ -56,7 +56,7 @@ ); mod = result!=null ? result : env; } - loaded.put(modName,mod); + loaded.rawPut(modName,mod); } return mod; }
--- a/core/src/luan/modules/PickleClient.java Fri May 01 18:44:20 2015 -0600 +++ b/core/src/luan/modules/PickleClient.java Fri May 01 19:29:07 2015 -0600 @@ -39,11 +39,11 @@ public Object call(Object... args) throws LuanException, IOException { con.write(args); Object[] result; - con.env.put("_reversed_pickle",_reversed_pickle); + con.env.rawPut("_reversed_pickle",_reversed_pickle); try { result = Luan.array(con.read()); } finally { - con.env.put("_reversed_pickle",null); + con.env.rawPut("_reversed_pickle",null); } boolean ok = (boolean)result[0]; if( ok ) { @@ -66,13 +66,13 @@ LuanTable table() { LuanTable tbl = new LuanTable(); try { - tbl.put( "pickle", new LuanJavaFunction( + tbl.rawPut( "pickle", new LuanJavaFunction( PickleCon.class.getMethod( "pickle", Object.class ), con ) ); - tbl.put( "call", new LuanJavaFunction( + tbl.rawPut( "call", new LuanJavaFunction( PickleClient.class.getMethod( "call", new Object[0].getClass() ), this ) ); - tbl.put( "close", new LuanJavaFunction( + tbl.rawPut( "close", new LuanJavaFunction( PickleCon.class.getMethod( "close" ), con ) ); } catch(NoSuchMethodException e) {
--- a/core/src/luan/modules/PickleCon.java Fri May 01 18:44:20 2015 -0600 +++ b/core/src/luan/modules/PickleCon.java Fri May 01 19:29:07 2015 -0600 @@ -56,14 +56,14 @@ } public Object read() throws IOException, LuanException { - env.put("_read_binary",_read_binary); + env.rawPut("_read_binary",_read_binary); try { src = readString(); LuanFunction fn = BasicLuan.load(luan,src,"pickle-reader",env,false); return luan.call(fn); } finally { - env.put("_binaries",null); - env.put("_read_binary",null); + env.rawPut("_binaries",null); + env.rawPut("_read_binary",null); } }
--- a/core/src/luan/modules/PickleServer.java Fri May 01 18:44:20 2015 -0600 +++ b/core/src/luan/modules/PickleServer.java Fri May 01 19:29:07 2015 -0600 @@ -73,10 +73,10 @@ Object old_unreverse_pickle = env.rawGet("_unreverse_pickle"); try { try { - io.put("reverse_pickle", new LuanJavaFunction( + io.rawPut("reverse_pickle", new LuanJavaFunction( PickleServer.class.getMethod( "reverse_pickle", LuanFunction.class ), this ) ); - env.put("_unreverse_pickle", new LuanJavaFunction( + env.rawPut("_unreverse_pickle", new LuanJavaFunction( PickleServer.class.getMethod( "_unreverse_pickle" ), this ) ); } catch(NoSuchMethodException e) { @@ -100,8 +100,8 @@ } } } finally { - io.put("reverse_pickle",old_reverse_pickle); - env.put("_unreverse_pickle",old_unreverse_pickle); + io.rawPut("reverse_pickle",old_reverse_pickle); + env.rawPut("_unreverse_pickle",old_unreverse_pickle); } }
--- a/core/src/luan/modules/TableLuan.java Fri May 01 18:44:20 2015 -0600 +++ b/core/src/luan/modules/TableLuan.java Fri May 01 19:29:07 2015 -0600 @@ -90,10 +90,10 @@ } else if( !hasNull ) { tbl.add(v); } else { - tbl.put(i+1,v); + tbl.rawPut(i+1,v); } } - tbl.put( "n", args.length ); + tbl.rawPut( "n", args.length ); return tbl; }
--- a/lucene/src/luan/modules/lucene/LuceneDocument.java Fri May 01 18:44:20 2015 -0600 +++ b/lucene/src/luan/modules/lucene/LuceneDocument.java Fri May 01 19:29:07 2015 -0600 @@ -92,17 +92,17 @@ name = newName; BytesRef br = ifld.binaryValue(); if( br != null ) { - table.put(name,br.bytes); + table.rawPut(name,br.bytes); continue; } Number n = ifld.numericValue(); if( n != null ) { - table.put(name,n); + table.rawPut(name,n); continue; } String s = ifld.stringValue(); if( s != null ) { - table.put(name,s); + table.rawPut(name,s); continue; } throw luan.exception("invalid field type for "+ifld);
--- a/lucene/src/luan/modules/lucene/LuceneIndex.java Fri May 01 18:44:20 2015 -0600 +++ b/lucene/src/luan/modules/lucene/LuceneIndex.java Fri May 01 19:29:07 2015 -0600 @@ -132,8 +132,8 @@ if( id > idLim ) { idLim += idBatch; LuanTable doc = new LuanTable(); - doc.put( "type", "next_id" ); - doc.put( FLD_NEXT_ID, idLim ); + doc.rawPut( "type", "next_id" ); + doc.rawPut( FLD_NEXT_ID, idLim ); writer.updateDocument(newTerm("type","next_id"),toLucene(luan,doc)); } return rtn;
--- a/lucene/src/luan/modules/lucene/LuceneSearcher.java Fri May 01 18:44:20 2015 -0600 +++ b/lucene/src/luan/modules/lucene/LuceneSearcher.java Fri May 01 19:29:07 2015 -0600 @@ -137,7 +137,7 @@ } private void add(LuanTable t,String method,Class<?>... parameterTypes) throws NoSuchMethodException { - t.put( method, new LuanJavaFunction(LuceneSearcher.class.getMethod(method,parameterTypes),this) ); + t.rawPut( method, new LuanJavaFunction(LuceneSearcher.class.getMethod(method,parameterTypes),this) ); } LuanTable table() {
--- a/lucene/src/luan/modules/lucene/LuceneWriter.java Fri May 01 18:44:20 2015 -0600 +++ b/lucene/src/luan/modules/lucene/LuceneWriter.java Fri May 01 19:29:07 2015 -0600 @@ -63,7 +63,7 @@ String id = (String)doc.get(luan,"id"); if( id == null ) { id = nextId(luan); - doc.put("id",id); + doc.put(luan,"id",id); addDocument(luan,doc); } else { updateDocument(luan,index.newTerm("id",id),doc); @@ -73,7 +73,7 @@ // luan private void add(LuanTable t,String method,Class<?>... parameterTypes) throws NoSuchMethodException { - t.put( method, new LuanJavaFunction(LuceneWriter.class.getMethod(method,parameterTypes),this) ); + t.rawPut( method, new LuanJavaFunction(LuceneWriter.class.getMethod(method,parameterTypes),this) ); } LuanTable table() {
--- a/web/src/luan/modules/web/HttpServicer.java Fri May 01 18:44:20 2015 -0600 +++ b/web/src/luan/modules/web/HttpServicer.java Fri May 01 19:29:07 2015 -0600 @@ -74,9 +74,9 @@ LuanTable module = (LuanTable)PackageLuan.require(luan,"luan:web/Http"); HttpServicer lib = new HttpServicer(request,response); try { - module.put( "request", lib.requestTable() ); - module.put( "response", lib.responseTable() ); - module.put( "session", lib.sessionTable() ); + module.put( luan, "request", lib.requestTable() ); + module.put( luan, "response", lib.responseTable() ); + module.put( luan, "session", lib.sessionTable() ); /* module.put( "write", new LuanJavaFunction( HttpServicer.class.getMethod( "text_write", LuanState.class, new Object[0].getClass() ), lib @@ -119,7 +119,7 @@ private LuanTable requestTable() throws NoSuchMethodException { LuanTable tbl = LuanPropertyMeta.INSTANCE.newTable(); LuanTable getters = LuanPropertyMeta.INSTANCE.getters(tbl); - tbl.put("java",request); + tbl.rawPut("java",request); LuanTable parameters = new NameMeta() { @Override Object get(String name) { @@ -135,7 +135,7 @@ } }.newTable(); - tbl.put( "parameters", parameters ); + tbl.rawPut( "parameters", parameters ); add( tbl, "get_parameter_values", String.class ); LuanTable headers = new NameMeta() { @@ -152,23 +152,23 @@ } }.newTable(); - tbl.put( "headers", headers ); - getters.put( "method", new LuanJavaFunction( + tbl.rawPut( "headers", headers ); + getters.rawPut( "method", new LuanJavaFunction( HttpServletRequest.class.getMethod( "getMethod" ), request ) ); - getters.put( "path", new LuanJavaFunction( + getters.rawPut( "path", new LuanJavaFunction( HttpServletRequest.class.getMethod( "getRequestURI" ), request ) ); - getters.put( "server_name", new LuanJavaFunction( + getters.rawPut( "server_name", new LuanJavaFunction( HttpServletRequest.class.getMethod( "getServerName" ), request ) ); - getters.put( "url", new LuanJavaFunction( + getters.rawPut( "url", new LuanJavaFunction( HttpServicer.class.getMethod( "getURL" ), this ) ); - getters.put( "query_string", new LuanJavaFunction( + getters.rawPut( "query_string", new LuanJavaFunction( HttpServicer.class.getMethod( "getQueryString" ), this ) ); - getters.put( "remote_address", new LuanJavaFunction( + getters.rawPut( "remote_address", new LuanJavaFunction( HttpServletRequest.class.getMethod( "getRemoteAddr" ), request ) ); LuanTable cookies = new LuanMeta() { @@ -202,7 +202,7 @@ } }.newTable(); - tbl.put( "cookies", cookies ); + tbl.rawPut( "cookies", cookies ); String contentType = request.getContentType(); if( contentType!=null && contentType.startsWith("multipart/form-data") ) { @@ -221,9 +221,9 @@ value = new String(part.getBytes()); } else { LuanTable partTbl = LuanPropertyMeta.INSTANCE.newTable(); - partTbl.put("filename",filename); - partTbl.put("content_type",part.getContentType()); - LuanPropertyMeta.INSTANCE.getters(partTbl).put( "content", new LuanFunction() { + partTbl.rawPut("filename",filename); + partTbl.rawPut("content_type",part.getContentType()); + LuanPropertyMeta.INSTANCE.getters(partTbl).rawPut( "content", new LuanFunction() { @Override public Object call(LuanState luan,Object[] args) throws LuanException { try { InputStream in = part.getInputStream(); @@ -237,7 +237,7 @@ } ); value = partTbl; } - parameters.put(name,value); + parameters.rawPut(name,value); Object old = map.get(name); if( old == null ) { map.put(name,value); @@ -251,8 +251,8 @@ map.put(name,new Object[]{old,value}); } } - tbl.put( "parameters", parameters ); - tbl.put( "get_parameter_values", new LuanFunction() { + tbl.rawPut( "parameters", parameters ); + tbl.rawPut( "get_parameter_values", new LuanFunction() { @Override public Object call(LuanState luan,Object[] args) throws LuanException { return args.length==0 ? null : map.get(args[0]); } @@ -271,7 +271,7 @@ LuanTable tbl = LuanPropertyMeta.INSTANCE.newTable(); LuanTable getters = LuanPropertyMeta.INSTANCE.getters(tbl); LuanTable setters = LuanPropertyMeta.INSTANCE.setters(tbl); - tbl.put("java",response); + tbl.rawPut("java",response); add( tbl, "send_redirect", String.class ); add( tbl, "send_error", Integer.TYPE, String.class ); LuanTable headers = new NameMeta() { @@ -309,26 +309,26 @@ } }.newTable(); - tbl.put( "headers", headers ); - getters.put( "content_type", new LuanJavaFunction( + tbl.rawPut( "headers", headers ); + getters.rawPut( "content_type", new LuanJavaFunction( HttpServletResponse.class.getMethod( "getContentType" ), response ) ); - setters.put( "content_type", new LuanJavaFunction( + setters.rawPut( "content_type", new LuanJavaFunction( HttpServletResponse.class.getMethod( "setContentType", String.class ), response ) ); - getters.put( "character_encoding", new LuanJavaFunction( + getters.rawPut( "character_encoding", new LuanJavaFunction( HttpServletResponse.class.getMethod( "getCharacterEncoding" ), response ) ); - setters.put( "character_encoding", new LuanJavaFunction( + setters.rawPut( "character_encoding", new LuanJavaFunction( HttpServletResponse.class.getMethod( "setCharacterEncoding", String.class ), response ) ); add( tbl, "text_writer" ); add( tbl, "set_cookie", String.class, String.class, Boolean.TYPE, String.class ); add( tbl, "remove_cookie", String.class, String.class ); - getters.put( "status", new LuanJavaFunction( + getters.rawPut( "status", new LuanJavaFunction( HttpServletResponse.class.getMethod( "getStatus" ), response ) ); - setters.put( "status", new LuanJavaFunction( + setters.rawPut( "status", new LuanJavaFunction( HttpServletResponse.class.getMethod( "setStatus", Integer.TYPE ), response ) ); return tbl; @@ -362,12 +362,12 @@ } }.newTable(); - tbl.put( "attributes", attributes ); + tbl.rawPut( "attributes", attributes ); return tbl; } private void add(LuanTable t,String method,Class<?>... parameterTypes) throws NoSuchMethodException { - t.put( method, new LuanJavaFunction(HttpServicer.class.getMethod(method,parameterTypes),this) ); + t.rawPut( method, new LuanJavaFunction(HttpServicer.class.getMethod(method,parameterTypes),this) ); } /* public void text_write(LuanState luan,Object... args) throws LuanException, IOException {