Mercurial Hosting > luan
changeset 29:9bc66d09ea48
CmdLine improvements
git-svn-id: https://luan-java.googlecode.com/svn/trunk@30 21e917c8-12df-6dd8-5cb6-c86387c605b9
author | fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9> |
---|---|
date | Fri, 07 Dec 2012 09:33:31 +0000 (2012-12-07) |
parents | df923e5835b2 |
children | 8d8f4f5caef4 |
files | src/luan/CmdLine.java src/luan/lib/BasicLib.java |
diffstat | 2 files changed, 82 insertions(+), 25 deletions(-) [+] |
line wrap: on
line diff
--- a/src/luan/CmdLine.java Fri Dec 07 05:49:17 2012 +0000 +++ b/src/luan/CmdLine.java Fri Dec 07 09:33:31 2012 +0000 @@ -1,31 +1,61 @@ package luan; +import java.io.InputStreamReader; import java.util.Arrays; import java.util.Scanner; import luan.lib.BasicLib; public class CmdLine { + static final String version = "Luan 0.0"; public static void main(String[] args) throws Exception { LuaState lua = new LuaState(); BasicLib.register(lua); boolean interactive = false; + boolean showVersion = false; int i = 0; - while( i < args.length ) { - String arg = args[i]; - if( !arg.startsWith("-") ) - break; - if( arg.equals("-i") ) { - interactive = true; - } else { - throw new RuntimeException("invalid option: "+arg); + if( args.length == 0 ) { + interactive = true; + showVersion = true; + } else { + while( i < args.length ) { + String arg = args[i++]; + if( !arg.startsWith("-") || arg.equals("--") ) + break; + if( arg.equals("-i") ) { + interactive = true; + } else if( arg.equals("-v") ) { + showVersion = true; + } else if( arg.equals("-e") ) { + if( i == args.length ) + error("'-e' needs argument"); + String cmd = args[i++]; + try { + LuaFunction fn = BasicLib.load(lua,cmd); + fn.call(lua); + } catch(LuaException e) { + System.err.println("command line error: "+e.getMessage()); + System.exit(-1); + } + } else if( arg.equals("-") ) { + String cmd = BasicLib.readAll(new InputStreamReader(System.in)); + try { + LuaFunction fn = BasicLib.load(lua,cmd); + fn.call(lua); + } catch(LuaException e) { + System.err.println(e.getMessage()); + System.exit(-1); + } + System.exit(0); + } else { + error("unrecognized option '"+arg+"'"); + } } - i++; } - if( i == args.length ) { - interactive = true; - } else { + if( showVersion ) + System.out.println(version); + if( i < args.length ) { String file = args[i++]; Object[] varArgs = new Object[args.length-1]; System.arraycopy(args,1,varArgs,0,varArgs.length); @@ -35,18 +65,32 @@ } lua.env().set("arg",argsTable); try { - LuaFunction fn = BasicLib.loadFile(lua,file); + LuaFunction fn = BasicLib.loadfile(lua,file); fn.call(lua,varArgs); } catch(LuaException e) { -// System.out.println(e.getMessage()); +// System.err.println(e.getMessage()); e.printStackTrace(); - return; + System.exit(-1); } } if( interactive ) interactive(lua); } + private static void error(String msg) { + System.err.println(msg); + System.err.println("usage: java luan.CmdLine [options] [script [args]]"); + System.err.println("Available options are:"); + System.err.println(" -e stat execute string 'stat'"); + System.err.println(" -i enter interactive mode after executing 'script'"); +// System.err.println(" -l name require library 'name'"); + System.err.println(" -v show version information"); +// System.err.println(" -E ignore environment variables"); + System.err.println(" -- stop handling options"); + System.err.println(" - stop handling options and execute stdin"); + System.exit(-1); + } + static void interactive(LuaState lua) { while( true ) { System.out.print("> ");
--- a/src/luan/lib/BasicLib.java Fri Dec 07 05:49:17 2012 +0000 +++ b/src/luan/lib/BasicLib.java Fri Dec 07 09:33:31 2012 +0000 @@ -1,5 +1,7 @@ package luan.lib; +import java.io.File; +import java.io.Reader; import java.io.FileReader; import java.io.IOException; import java.lang.reflect.Method; @@ -29,7 +31,7 @@ add( t, "print", new Object[0].getClass() ); add( t, "type", Object.class ); add( t, "load", LuaState.class, String.class ); - add( t, "loadFile", LuaState.class, String.class ); + add( t, "loadfile", LuaState.class, String.class ); add( t, "pairs", LuaTable.class ); add( t, "ipairs", LuaTable.class ); } @@ -74,19 +76,30 @@ return chunk.newClosure(lua); } - public static String readFile(String fileName) throws IOException { - StringBuilder sb = new StringBuilder(); - FileReader in = new FileReader(fileName); - char[] buf = new char[8192]; + public static String readAll(Reader in) + throws IOException + { + char[] a = new char[8192]; + StringBuilder buf = new StringBuilder(); int n; - while( (n=in.read(buf)) != -1 ) { - sb.append(buf,0,n); + while( (n=in.read(a)) != -1 ) { + buf.append(a,0,n); } - return sb.toString(); + return buf.toString(); } - public static LuaFunction loadFile(LuaState lua,String fileName) throws LuaException,IOException { - return load(lua,readFile(fileName)); + public static String read(File file) + throws IOException + { + Reader in = new FileReader(file); + String s = readAll(in); + in.close(); + return s; + } + + + public static LuaFunction loadfile(LuaState lua,String fileName) throws LuaException,IOException { + return load(lua,read(new File(fileName))); } private static class TableIter {