2003/10/20 03:37:11
[org.ibex.core.git] / src / org / xwt / Main.java
index 9febf7c..4f1c6ac 100644 (file)
@@ -60,31 +60,49 @@ public class Main {
         Platform.forceLoad();
         if (Log.on) for(int i=0; i<args.length; i++) Log.log(Main.class, "argument " + i + ": " + args[i]);
 
-        builtin = new Res.Zip(new Res.IS(Platform.getBuiltinInputStream()));
+        Res zip = new Res() { public InputStream getInputStream(String path) { return Platform.getBuiltinInputStream(); } };
+        builtin = new Res.Zip(zip);
 
         String initialTemplateName = args.length > startargs + 1 ? args[startargs + 1] : "main";
         initialTemplateName = initialTemplateName.replace('/', '.');
         origin = args[startargs];
 
+        Res rr;
+        final String initialTemplate;
+
         if (origin.startsWith("http://") || origin.startsWith("https://")) {
             originHost = origin.substring(origin.indexOf('/') + 2);
             originHost = originHost.substring(0, originHost.indexOf('/') == -1 ? originHost.length() : originHost.indexOf('/'));
             if (originHost.indexOf('@') != -1) originHost = originHost.substring(originHost.indexOf('@') + 1);
             originAddr = InetAddress.getByName(originHost);
+            rr = builtin;
+            initialTemplate = "org/xwt/builtin/splash.xwt";
         } else {
             // HACK because MSIE turns \'s into /'s in file URLs... argh!!
             if (Platform.platform.getClass().getName().endsWith("Win32")) origin = origin.replace('/', '\\');
-            if (!new File(origin).isDirectory()) origin += "!";
-            origin = "file:" + origin;
+            final String final_origin = origin;
+            rr = new Res.File(origin);
+            if (!new File(origin).isDirectory()) rr = new Res.Zip(rr);
+            initialTemplate = initialTemplateName;
         }
 
-        // FIXME put the splash screen back in
         if (Log.on) Log.log(Main.class, "loading xwar");
+        final XWT xwt = new XWT(rr);
+        final Res final_rr = rr;
 
-        Res rr = Res.stringToRes(origin);
-        Template.getTemplate(((Res)rr.get(initialTemplateName)).addExtension(".xwt")).apply(new Box(), null, 0, 0, rr);
-
-        Message.Q.startQ();
+        new Thread(new Runnable() { 
+            public void run() {
+                Message.Q.startQ();
+                ThreadMessage.newthread(new JS.Callable() {
+                        public Object call(JS.Array args) {
+                            Template.getTemplate(((Res)final_rr.get(initialTemplate))).apply(new Box(), null, xwt);
+                            return null;
+                        }
+                    });
+            }
+        }).start();
+        
+        Platform.running();
     }
 
 }