Mercurial Hosting > luan
changeset 1277:5ba660381bd5
fix Io.print()
author | Franklin Schmidt <fschmidt@gmail.com> |
---|---|
date | Tue, 11 Dec 2018 03:38:43 -0700 (2018-12-11) |
parents | 623dfe0e2e73 |
children | d83f6cc558de |
files | conv.txt src/luan/cmd_line.luan src/luan/host/main.luan src/luan/modules/Io.luan src/luan/modules/TableLuan.java src/luan/modules/http/tools/Shell.luan website/src/manual.html.luan |
diffstat | 7 files changed, 29 insertions(+), 6 deletions(-) [+] |
line wrap: on
line diff
--- a/conv.txt Mon Dec 10 15:04:09 2018 -0700 +++ b/conv.txt Tue Dec 11 03:38:43 2018 -0700 @@ -1,3 +1,4 @@ +"Io.print()" "Luan.values" remove "as_table"
--- a/src/luan/cmd_line.luan Mon Dec 10 15:04:09 2018 -0700 +++ b/src/luan/cmd_line.luan Tue Dec 11 03:38:43 2018 -0700 @@ -4,6 +4,8 @@ local load_file = Luan.load_file or error() local try = Luan.try or error() local Table = require "luan:Table.luan" +local pack = Table.pack or error() +local unpack = Table.unpack or error() local Io = require "luan:Io.luan" local print = Io.print or error() @@ -21,7 +23,10 @@ try { function() local main_file = load_file(file) - print( main_file( Table.unpack(Luan.arg) ) ) + local rtn = pack( main_file( unpack(Luan.arg) ) ) + if rtn.n > 0 then + print( unpack(rtn) ) + end end catch = function(e) -- java(); e.java.printStackTrace();
--- a/src/luan/host/main.luan Mon Dec 10 15:04:09 2018 -0700 +++ b/src/luan/host/main.luan Tue Dec 11 03:38:43 2018 -0700 @@ -5,7 +5,6 @@ local ipairs = Luan.ipairs or error() local try = Luan.try or error() local Io = require "luan:Io.luan" -local print = Io.print or error() local Rpc = require "luan:Rpc.luan" local Thread = require "luan:Thread.luan" local String = require "luan:String.luan"
--- a/src/luan/modules/Io.luan Mon Dec 10 15:04:09 2018 -0700 +++ b/src/luan/modules/Io.luan Tue Dec 11 03:38:43 2018 -0700 @@ -28,6 +28,7 @@ local values = Luan.values or error() local load = Luan.load or error() local Table = require "luan:Table.luan" +local pack = Table.pack or error() local unpack = Table.unpack or error() local String = require "luan:String.luan" local encode = String.encode or error() @@ -49,6 +50,8 @@ if #list > 0 then list[#list] = '\n' out.write( unpack(list) ) + else + out.write('\n') end end @@ -101,7 +104,10 @@ fn = load(line,"stdin",env) end } - Io.print( fn() ) + local rtn = pack( fn() ) + if rtn.n > 0 then + Io.print( unpack(rtn) ) + end end catch = function(e) Io.print(e)
--- a/src/luan/modules/TableLuan.java Mon Dec 10 15:04:09 2018 -0700 +++ b/src/luan/modules/TableLuan.java Tue Dec 11 03:38:43 2018 -0700 @@ -92,7 +92,13 @@ @LuanMethod public static Object[] unpack(LuanTable tbl,Integer iFrom,Integer iTo) throws LuanException { int from = iFrom!=null ? iFrom : 1; - int to = iTo!=null ? iTo : tbl.length(); + int to; + if( iTo != null ) { + to = iTo; + } else { + Integer n = Luan.asInteger( tbl.get("n") ); + to = n!=null ? n : tbl.length(); + } List<Object> list = new ArrayList<Object>(); for( int i=from; i<=to; i++ ) { list.add( tbl.get(i) );
--- a/src/luan/modules/http/tools/Shell.luan Mon Dec 10 15:04:09 2018 -0700 +++ b/src/luan/modules/http/tools/Shell.luan Tue Dec 11 03:38:43 2018 -0700 @@ -6,6 +6,9 @@ local try = Luan.try or error() local String = require "luan:String.luan" local concat = String.concat or error() +local Table = require "luan:Table.luan" +local pack = Table.pack or error() +local unpack = Table.unpack or error() local Time = require "luan:Time.luan" local Thread = require "luan:Thread.luan" local Io = require "luan:Io.luan" @@ -51,7 +54,10 @@ line = load(cmd,"<web_shell>",env) end } - print( line() ) + local rtn = pack( line() ) + if rtn.n > 0 then + print( unpack(rtn) ) + end end catch = function(e) Io.print_to(Io.stderr,e)
--- a/website/src/manual.html.luan Mon Dec 10 15:04:09 2018 -0700 +++ b/website/src/manual.html.luan Tue Dec 11 03:38:43 2018 -0700 @@ -2751,7 +2751,7 @@ </pre> <p> -By default, <code>i</code> is 1 and <code>j</code> is <code>#list</code>. +By default, <code>i</code> is 1 and <code>j</code> is <code>list.n or #list</code>.