Mercurial Hosting > luan
changeset 237:97d175772fed
implement mmake
git-svn-id: https://luan-java.googlecode.com/svn/trunk@238 21e917c8-12df-6dd8-5cb6-c86387c605b9
author | fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9> |
---|---|
date | Mon, 06 Oct 2014 04:07:56 +0000 (2014-10-06) |
parents | 1fada5587469 |
children | 55b4b077e5cc |
files | core/src/luan/impl/ForStmt.java core/src/luan/modules/IoLuan.java core/src/luan/modules/Utils.java dist/jars/luan-core-trunk.jar dist/jars/luan-logging-trunk.jar dist/jars/luan-lucene-trunk.jar dist/jars/luan-mail-trunk.jar dist/jars/luan-web-trunk.jar dist/scripts/luan.sh dist/scripts/mmake.luan dist/scripts/mmake.sh |
diffstat | 11 files changed, 68 insertions(+), 5 deletions(-) [+] |
line wrap: on
line diff
--- a/core/src/luan/impl/ForStmt.java Sun Oct 05 09:11:10 2014 +0000 +++ b/core/src/luan/impl/ForStmt.java Mon Oct 06 04:07:56 2014 +0000 @@ -22,8 +22,8 @@ } @Override public void eval(LuanStateImpl luan) throws LuanException { - LuanFunction iter = luan.bit(se).checkFunction( iterExpr.eval(luan) ); LuanBit bit = luan.bit(iterExpr.se()); + LuanFunction iter = bit.checkFunction( iterExpr.eval(luan) ); String name = iterExpr.se().text(); try { while(true) {
--- a/core/src/luan/modules/IoLuan.java Sun Oct 05 09:11:10 2014 +0000 +++ b/core/src/luan/modules/IoLuan.java Mon Oct 06 04:07:56 2014 +0000 @@ -367,7 +367,7 @@ } public boolean exists() { - return Utils.exists(file); + return file.exists(); } @Override LuanTable table() {
--- a/core/src/luan/modules/Utils.java Sun Oct 05 09:11:10 2014 +0000 +++ b/core/src/luan/modules/Utils.java Mon Oct 06 04:07:56 2014 +0000 @@ -51,7 +51,7 @@ copyAll(in,out); return out.toByteArray(); } - +/* public static boolean exists(File file) { try { return file.exists() && file.getName().equals(file.getCanonicalFile().getName()); @@ -59,12 +59,12 @@ throw new RuntimeException(e); } } - +*/ public static File toFile(String path) { if( path.contains("//") ) return null; File file = new File(path); - return exists(file) ? file : null; + return file.exists() ? file : null; } public static URL toUrl(String path) {
--- a/dist/scripts/luan.sh Sun Oct 05 09:11:10 2014 +0000 +++ b/dist/scripts/luan.sh Mon Oct 06 04:07:56 2014 +0000 @@ -1,5 +1,7 @@ +CURRDIR=`pwd` cd `dirname $0`/../.. HOME=`pwd` +cd $CURRDIR . luan-cp.sh $HOME
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/dist/scripts/mmake.luan Mon Oct 06 04:07:56 2014 +0000 @@ -0,0 +1,54 @@ +import "Table" +import "Io" +import "String" +import "Java" +import "java.util.Date" + +compiler = Table.concat( { "javac -g -encoding UTF8", ... }, " " ) + +function mmake(dir) + local java = {} + local dirs = {} + for _, file in ipairs(dir.children()) do + local name = file.name() + if name.match ".java$" ~= nil then + java[#java+1] = name.sub(1,-6) + end + if file.is_directory() and mmake(file) then + dirs[#dirs+1] = name + end + end + if #java == 0 and #dirs == 0 then + return false; + end + local out = dir.child("Makefile").text_writer() + out.write( header() ) + for _, s in ipairs(java) do + out.write( "\\\n\t\t", s , ".class" ) + end + for _, s in ipairs(dirs) do + out.write( "\n\tcd ", s, "; make all" ) + end + out.write "\n\nclean:\n\trm -f *.class\n" + for _, s in ipairs(dirs) do + out.write( "\tcd ", s, "; make clean\n" ) + end + out.close() + print(dir.to_string()) + return true +end + + +function header() + return %> +# Makefile created on <%=Date.new()%> by Mmake + +.SUFFIXES: .java .class + +.java.class: + javac -g -encoding UTF8 $< + +all: <% +end + +mmake(Io.File ".")