X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=src%2Forg%2Fxwt%2FXWT.java;fp=src%2Forg%2Fxwt%2FXWT.java;h=3f4cc541479a35342fccbc3c653de11a77a19e3f;hb=2c0ae10e1f1d99d1661b798e479d2d4e68f523d2;hp=270a3fe421da7d5bdb130fbf3068c9943a90b454;hpb=68c7a72f76129359a3a029b1f34411665ebc3ab8;p=org.ibex.core.git diff --git a/src/org/xwt/XWT.java b/src/org/xwt/XWT.java index 270a3fe..3f4cc54 100644 --- a/src/org/xwt/XWT.java +++ b/src/org/xwt/XWT.java @@ -28,7 +28,7 @@ public final class XWT extends JS { String key; Sub(String key) { this.key = key; } public String toString() { return "XWTSUB " + key; } - public void put(Object key, Object val) { XWT.this.put(this.key + "." + key, val); } + public void put(Object key, Object val) throws JSExn { XWT.this.put(this.key + "." + key, val); } public Object get(Object key) throws JSExn { return XWT.this.get(this.key + "." + key); } public Object call(Object a0, Object a1, Object a2, Object[] rest, int nargs) throws JSExn { return XWT.this.callMethod(this.key, a0, a1, a2, rest, nargs); @@ -87,6 +87,7 @@ public final class XWT extends JS { case "graft": return METHOD; case "ui.browser": return METHOD; case "clone": return METHOD; + case "log.print": return METHOD; case "log.println": return METHOD; case "log.dump": return METHOD; case "regexp": return METHOD; @@ -103,59 +104,84 @@ public final class XWT extends JS { return super.get(name); } - public void put(Object name, final Object value) { + public void put(Object name, final Object value) throws JSExn { //#switch(name) - case "thread": Scheduler.add((JSFunction)value); - case "ui.clipboard": Platform.setClipBoard((String)value); - case "ui.frame": Platform.createSurface((Box)value, true, true); - case "ui.window": Platform.createSurface((Box)value, false, true); + case "thread": Scheduler.add((JSFunction)value); return; + case "ui.clipboard": Platform.setClipBoard((String)value); return; + case "ui.frame": Platform.createSurface((Box)value, true, true); return; + case "ui.window": Platform.createSurface((Box)value, false, true); return; case "undocumented.internal.proxyAuthorization": HTTP.Proxy.Authorization.authorization = value.toString(); - HTTP.Proxy.Authorization.waitingForUser.release(); + HTTP.Proxy.Authorization.waitingForUser.release(); return; //#end + + throw new JSExn("attempted to put unknown property: xwt."+name); } public Object callMethod(Object name, Object a, Object b, Object c, Object[] rest, int nargs) throws JSExn { - if (name.equals("date")) return new JSDate(a, b, c, rest, nargs); - else if (nargs == 0 && name.equals("thread.yield")) { sleep(0); return null; } - else if (nargs == 2) { - //#switch(name) - case "res.watch": return new Res.ProgressWatcher((Res)a, (JSFunction)b); - case "soap": /* return new SOAP((String)a, "", (String)b, null); */ - case "apply": Template.getTemplate((Res)b).apply((Box)a, XWT.this); return a; - //#end - - /* - } else if (nargs == 3 && name.equals("soap")) { - if (name.equals("soap")) - return new SOAP((String)a, "", (String)b, (String)c); - */ - - } else if (nargs == 1) { + try { //#switch(name) - case "ui.browser": Platform.newBrowserWindow((String)a); return null; - case "clone": return new XWT((Res)a); - case "res.unzip": return new Res.Zip((Res)a); - case "res.uncab": return new Res.Cab((Res)a); - case "res.cache": try { return new Res.CachedRes((Res)a, "resources", true); } - catch (Res.NotCacheableException e) { throw new JSExn("this resource cannot be cached"); } - case "res.url": return url2res((String)a); - case "thread.sleep": sleep(JS.toInt(a)); return null; - case "log.println": Log.logJS(this, a== null ? "**null**" : a.toString()); return null; - case "log.dump": Log.recursiveLog("","",a); return null; - case "regexp": return new JSRegexp(a, null); - case "rpc.xml": return new XMLRPC((String)a, ""); - case "rpc.soap": /* return new SOAP((String)a, "", null, null); */ - case "crypto.rsa": /* FEATURE */ break; - case "crypto.md5": /* FEATURE */ break; - case "crypto.sha1": /* FEATURE */ break; - case "crypto.rc4": /* FEATURE */ break; - case "stream.parse.html": /* FEATURE */ break; - case "stream.parse.xml": /* FEATURE */ break; - case "stream.parse.utf8": /* FEATURE */ break; + case "date": return new JSDate(a, b, c, rest, nargs); + case "rpc.soap": return null;//new SOAP((String)a, "", (String)b, (String)c); + case "graft": + if (a instanceof Box) throw new JSExn("can't graft onto Boxes"); + if (a instanceof String) throw new JSExn("can't graft onto Strings"); + if (a instanceof Number) throw new JSExn("can't graft onto Numbers"); + if (a instanceof Res) return new Res.Graft((Res)a, b, c); + // FEATURE: grafting onto JS + throw new JSExn("cannot graft onto "+a.getClass()); //#end + + switch (nargs) { + case 0: + //#switch(name) + case "thread.yield": sleep(0); return null; + //#end + break; + case 1: + //#switch(name) + case "ui.browser": Platform.newBrowserWindow((String)a); return null; + case "clone": return new XWT((Res)a); + case "res.unzip": return new Res.Zip((Res)a); + case "res.uncab": return new Res.Cab((Res)a); + case "res.cache": try { return new Res.CachedRes((Res)a, "resources", true); } + catch (Res.NotCacheableException e) { throw new JSExn("this resource cannot be cached"); } + case "res.url": return url2res((String)a); + case "thread.sleep": sleep(JS.toInt(a)); return null; + case "log.print": Log.logJS(this, a== null ? "**null**" : a.toString()); return null; + case "log.println": Log.logJS(this, a== null ? "**null**" : a.toString()); return null; + case "log.dump": Log.recursiveLog("","",a); return null; + case "regexp": return new JSRegexp(a, null); + case "rpc.xml": return new XMLRPC((String)a, ""); + case "crypto.rsa": /* FEATURE */ return null; + case "crypto.md5": /* FEATURE */ return null; + case "crypto.sha1": /* FEATURE */ return null; + case "crypto.rc4": /* FEATURE */ return null; + case "stream.parse.html": /* FEATURE */ return null; + case "stream.parse.xml": /* FEATURE */ return null; + case "stream.parse.utf8": /* FEATURE */ return null; + //#end + break; + case 2: + //#switch(name) + case "res.watch": return new Res.ProgressWatcher((Res)a, (JSFunction)b); + case "apply": + if (b instanceof Res) Template.getTemplate((Res)b).apply((Box)a, XWT.this); + else { + JS to = (JS)a, from = (JS)b; Object k; + for (Enumeration e = from.keys(); e.hasMoreElements();) { + k = e.nextElement(); to.put(k, from.get(k)); + } + } + return a; + //#end + break; + } + } catch (RuntimeException e) { + throw new JSExn("invalid argument for xwt object method "+name+"()"); } - return null; + + throw new JSExn("invalid number of arguments for xwt object method "+name+"()"); } public Res url2res(String url) throws JSExn {