X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=src%2Forg%2Fxwt%2FMain.java;h=6bae13c133fa875b5be84eca2d445b26b8c0e4dd;hb=163ff4c57ec557bb8615f80e875f045cdfbad696;hp=25fc8e2cc0ed2fbc6fda01278c0f21db3e5d4559;hpb=6b010667b40641fdb82925e56466f847f721ef1f;p=org.ibex.core.git diff --git a/src/org/xwt/Main.java b/src/org/xwt/Main.java index 25fc8e2..6bae13c 100644 --- a/src/org/xwt/Main.java +++ b/src/org/xwt/Main.java @@ -1,4 +1,4 @@ -// Copyright 2003 Adam Megacz, see the COPYING file for licensing [GPL] +// Copyright 2004 Adam Megacz, see the COPYING file for licensing [GPL] package org.xwt; import java.net.*; @@ -24,18 +24,15 @@ public class Main { public static java.net.InetAddress originAddr = null; public static String originHost = null; public static String origin = null; - - public static Res builtin = null; + + public static final Stream builtin = new Stream.Zip(new Stream.Builtin()); + public static Picture scarImage = null; public static void printUsage() { System.err.println("Usage: xwt [-s] [-v] [-l /] source-location [initial-template]"); System.err.println(""); System.err.println("Options:"); - // FEATURE: reintroduce - //System.err.println(" -s show rendering activity with red rectangles"); System.err.println(" -v verbose logging"); - // FEATURE: reintroduce - //System.err.println(" -l serve logs via HTTP on 127.0.0.1:/"); System.err.println(""); System.err.println("Source-location is one of the following:"); System.err.println(" - the path to an xwar file"); @@ -46,46 +43,49 @@ public class Main { Runtime.getRuntime().exit(-1); } - /** common entry point */ public static void main(String[] args) throws Exception { int startargs = 0; while (true) { if (startargs > args.length - 1) printUsage(); else if (args[startargs].equals("-v")) Log.verbose = true; - else if (args[startargs].equals("-l")) startargs++; else break; startargs++; } Platform.forceLoad(); - if (Log.on) for(int i=0; i startargs + 1 ? args[startargs + 1] : "main"; - initialTemplateName = initialTemplateName.replace('/', '.'); + initialTemplateName = initialTemplateName.replace('.', '/'); + initialTemplateName += ".xwt"; origin = args[startargs]; + Stream 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; + rr = new Stream.File(origin); + if (!new File(origin).isDirectory()) rr = new Stream.Zip(rr); + initialTemplate = initialTemplateName; } - // FIXME put the splash screen back in - if (Log.on) Log.log(Main.class, "loading xwar"); + if (Log.on) Log.info(Main.class, "loading xwar"); + final XWT xwt = new XWT(rr); + final JS final_rr = (JS)xwt.get(""); - Res rr = Res.stringToRes(origin, true); - XWT xwt = new XWT(rr); - Template.getTemplate(((Res)rr.get(initialTemplateName)).addExtension(".xwt")).apply(new Box(), null, xwt); + scarImage = + Picture.load((Stream)Main.builtin.get("org/xwt/builtin/scar.png"), + new Scheduler.Task() { public void perform() throws Exception { + new Template(Stream.getInputStream(final_rr.get(initialTemplate)), xwt).apply(new Box()); + } }); - Message.Q.startQ(); + Scheduler.init(); } - }