changeset 265:454a486d9c19

allow IO on files that don't exist git-svn-id: https://luan-java.googlecode.com/svn/trunk@266 21e917c8-12df-6dd8-5cb6-c86387c605b9
author fschmidt@gmail.com <fschmidt@gmail.com@21e917c8-12df-6dd8-5cb6-c86387c605b9>
date Wed, 29 Oct 2014 16:26:42 +0000 (2014-10-29)
parents 9e0d4452e649
children 4dca283b9b74
files core/src/luan/modules/BasicLuan.java core/src/luan/modules/IoLuan.java core/src/luan/modules/PackageLuan.java
diffstat 3 files changed, 41 insertions(+), 14 deletions(-) [+]
line wrap: on
line diff
--- a/core/src/luan/modules/BasicLuan.java	Wed Oct 29 03:50:59 2014 +0000
+++ b/core/src/luan/modules/BasicLuan.java	Wed Oct 29 16:26:42 2014 +0000
@@ -74,11 +74,12 @@
 	}
 
 	public static LuanFunction load_file(LuanState luan,String fileName) throws LuanException {
-		LuanTable t = fileName==null ? IoLuan.stdin.table() : IoLuan.get(luan,fileName,false);
-		if( t == null )
+		if( fileName == null )
+			fileName = "stdin:";
+		LuanFunction fn = PackageLuan.loader(luan,fileName,false);
+		if( fn == null )
 			throw luan.exception( "file '"+fileName+"' not found" );
-		LuanFunction loader = (LuanFunction)t.get("loader");
-		return (LuanFunction)Luan.first(luan.call(loader,new Object[]{fileName}));
+		return fn;
 	}
 
 	public static Object do_file(LuanState luan,String fileName) throws LuanException {
--- a/core/src/luan/modules/IoLuan.java	Wed Oct 29 03:50:59 2014 +0000
+++ b/core/src/luan/modules/IoLuan.java	Wed Oct 29 16:26:42 2014 +0000
@@ -18,6 +18,7 @@
 import java.io.DataInputStream;
 import java.io.DataOutputStream;
 import java.io.IOException;
+import java.io.FileNotFoundException;
 import java.net.URL;
 import java.net.Socket;
 import java.net.ServerSocket;
@@ -210,11 +211,22 @@
 			try {
 				String src = read_text();
 				return BasicLuan.load(luan,src,name,null,false);
+			} catch(FileNotFoundException e) {
+				return null;
 			} catch(IOException e) {
 				throw luan.exception(e);
 			}
 		}
 
+		public boolean exists() throws IOException {
+			try {
+				inputStream().close();
+				return true;
+			} catch(FileNotFoundException e) {
+				return false;
+			}
+		}
+
 		LuanTable table() {
 			LuanTable tbl = Luan.newTable();
 			try {
@@ -236,6 +248,9 @@
 				tbl.put( "loader", new LuanJavaFunction(
 					LuanIn.class.getMethod( "loader", LuanState.class, String.class ), this
 				) );
+				tbl.put( "exists", new LuanJavaFunction(
+					LuanIn.class.getMethod( "exists" ), this
+				) );
 			} catch(NoSuchMethodException e) {
 				throw new RuntimeException(e);
 			}
@@ -260,6 +275,10 @@
 		@Override public byte[] read_binary() throws IOException {
 			return Utils.readAll(System.in);
 		}
+
+		@Override public boolean exists() {
+			return true;
+		}
 	};
 
 	public static abstract class LuanIO extends LuanIn {
@@ -365,7 +384,7 @@
 			return list;
 		}
 
-		public boolean exists() {
+		@Override public boolean exists() {
 			return file.exists();
 		}
 
@@ -375,9 +394,6 @@
 				tbl.put( "name", new LuanJavaFunction(
 					File.class.getMethod( "getName" ), file
 				) );
-				tbl.put( "exists", new LuanJavaFunction(
-					LuanFile.class.getMethod( "exists" ), this
-				) );
 				tbl.put( "is_directory", new LuanJavaFunction(
 					File.class.getMethod( "isDirectory" ), file
 				) );
@@ -413,8 +429,6 @@
 		if( Boolean.TRUE.equals(loading) )
 			name += ".luan";
 		File file = new File(name);
-		if( !file.exists() )
-			return null;
 		return new LuanFile(file).table();
 	}
 
@@ -504,6 +518,11 @@
 		return classpath( luan, "luan/modules/" + path, loading );
 	}
 
+	public static LuanTable stdin(LuanState luan) throws LuanException {
+		LuanTable io = (LuanTable)PackageLuan.loaded(luan).get("luan:Io");
+		return (LuanTable)io.get("stdin");
+	}
+
 	private static LuanTable newProtocols() {
 		LuanTable protocols = Luan.newTable();
 		try {
@@ -516,6 +535,7 @@
 				IoLuan.class.getMethod( "_class", LuanState.class, String.class, Boolean.class ), null
 			) );
 			add( protocols, "luan", LuanState.class, String.class, Boolean.class );
+			add( protocols, "stdin", LuanState.class );
 		} catch(NoSuchMethodException e) {
 			throw new RuntimeException(e);
 		}
--- a/core/src/luan/modules/PackageLuan.java	Wed Oct 29 03:50:59 2014 +0000
+++ b/core/src/luan/modules/PackageLuan.java	Wed Oct 29 16:26:42 2014 +0000
@@ -87,13 +87,19 @@
 		return mod;
 	}
 
-	public static Object[] search(LuanState luan,String modName) throws LuanException {
-		LuanTable t = IoLuan.get(luan,modName,true);
+	static LuanFunction loader(LuanState luan,String name,boolean loading) throws LuanException {
+		LuanTable t = IoLuan.get(luan,name,loading);
 		if( t == null )
 			return null;
 		LuanFunction loader = (LuanFunction)t.get("loader");
-		LuanFunction fn = (LuanFunction)Luan.first(luan.call(loader,new Object[]{modName}));
-		return new Object[]{fn,modName};
+		if( loader == null )
+			return null;
+		return (LuanFunction)Luan.first(luan.call(loader,new Object[]{name}));
+	}
+
+	public static Object[] search(LuanState luan,String modName) throws LuanException {
+		LuanFunction fn = loader(luan,modName,true);
+		return fn==null ? null : new Object[]{fn,modName};
 	}