X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=src%2Forg%2Fxwt%2FXWT.java;h=8c9debbbda3eca5553f8014b3fef91ce2681af8a;hb=e8442c40f5b8c03a4e6993cbcc9ce64dddab6a90;hp=1b875ad5b6ba89f52e10a88d0b1254acd6277b5e;hpb=77f51cd3e157cf6fd2ae85ce774444bb85ea7b81;p=org.ibex.core.git diff --git a/src/org/xwt/XWT.java b/src/org/xwt/XWT.java index 1b875ad..8c9debb 100644 --- a/src/org/xwt/XWT.java +++ b/src/org/xwt/XWT.java @@ -13,6 +13,8 @@ import org.bouncycastle.util.encoders.Base64; public final class XWT extends JS.Obj { public static final XWT singleton = new XWT(); + private final JS xwtMath = new XWTMath(); + private final JS xwtString = new XWTString(); /** each key is a string representing a filename which the user has already given XWT permission to write to */ private static Hashtable safeFiles = new Hashtable(); @@ -47,38 +49,39 @@ public final class XWT extends JS.Obj { } private XWT() { - put("maxdim", new Integer(Short.MAX_VALUE)); - put("origin", Main.origin); - put("altKeyName", Platform.altKeyName()); - put("screenWidth", new Integer(Platform.getScreenWidth())); - put("screenHeight", new Integer(Platform.getScreenHeight())); - put("fileSeparator", File.separator); - put("homeDir", System.getProperty("user.home")); - put("tempDir", System.getProperty("java.io.tempdir")); - put("math", org.xwt.js.JS.Math); - - put("newBrowserWindow", new JS.Callable() { public Object call(JS.Array args) throws JS.Exn { + super.put("maxdim", new Integer(Short.MAX_VALUE)); + super.put("origin", Main.origin); + super.put("altKeyName", Platform.altKeyName()); + super.put("screenWidth", new Integer(Platform.getScreenWidth())); + super.put("screenHeight", new Integer(Platform.getScreenHeight())); + super.put("fileSeparator", File.separator); + super.put("homeDir", System.getProperty("user.home")); + super.put("tempDir", System.getProperty("java.io.tempdir")); + super.put("math", xwtMath); + super.put("string", xwtString); + + super.put("newBrowserWindow", new JS.Callable() { public Object call(JS.Array args) throws JS.Exn { if (args.length() != 1 || args.elementAt(0) == null) return null; Platform.newBrowserWindow(args.elementAt(0).toString()); return null; }}); - put("parseFloat", new JS.Callable() { public Object call(JS.Array args) throws JS.Exn { + super.put("parseFloat", new JS.Callable() { public Object call(JS.Array args) throws JS.Exn { if (args.length() != 1 || args.elementAt(0) == null) return null; return new Float(args.elementAt(0).toString()); }}); - put("parseInt", new JS.Callable() { public Object call(JS.Array args) throws JS.Exn { + super.put("parseInt", new JS.Callable() { public Object call(JS.Array args) throws JS.Exn { if (args.length() != 1 || args.elementAt(0) == null) return null; return new Float(args.elementAt(0).toString()); }}); - put("yield", new JS.Callable() { public Object call(JS.Array args) throws JS.Exn { + super.put("yield", new JS.Callable() { public Object call(JS.Array args) throws JS.Exn { sleep(0); return null; }}); - put("theme", new JS.Callable() { public Object call(JS.Array args) throws JS.Exn { + super.put("theme", new JS.Callable() { public Object call(JS.Array args) throws JS.Exn { if (args.length() != 2) return null; if (args.elementAt(0) == null || args.elementAt(1) == null) return null; for(int i=1; i 2) return null; if (args.elementAt(0) == null || (args.length() == 2 && args.elementAt(1) == null)) return null; String font = args.length() == 1 ? Platform.getDefaultFont() : args.elementAt(0).toString(); @@ -145,7 +146,7 @@ public final class XWT extends JS.Obj { else return new Integer(xwf.stringWidth(text)); }}); - put("textheight", new JS.Callable() { public Object call(JS.Array args) throws JS.Exn { + super.put("textheight", new JS.Callable() { public Object call(JS.Array args) throws JS.Exn { if (args.length() > 1) return null; if (args.length() == 1 && args.elementAt(0) == null) return null; String font = args.length() == 0 || args.elementAt(0) == null ? Platform.getDefaultFont() : args.elementAt(0).toString(); @@ -154,7 +155,7 @@ public final class XWT extends JS.Obj { else return new Integer(xwf.getMaxAscent() + xwf.getMaxDescent()); }}); - put("newBox", new JS.Callable() { public Object call(JS.Array args) throws JS.Exn { + super.put("newBox", new JS.Callable() { public Object call(JS.Array args) throws JS.Exn { if (args.length() > 0) Log.log(XWT.class, "DEPRECATED: xwt.newBox() with multiple arguments is deprecated; use xwt.newBox().apply()"); JS.Callable callback = null; for(int i=1; i 1 && args.elementAt(1) instanceof JS.Callable ? (JS.Callable)args.elementAt(1) : null); @@ -357,12 +358,32 @@ public final class XWT extends JS.Obj { mythread.go.block(); } } + + private static class XWTMath extends JS.Obj { + public XWTMath() { + JS gs = new JS.GlobalScope(); + put("isNaN",gs.get("isNaN")); + put("isFinite",gs.get("isFinite")); + put("NaN",gs.get("NaN")); + put("Infinity",gs.get("Infinity")); + setSeal(true); + } + public Object get(Object key) { + Object ret = super.get(key); + if(ret == null) ret = JS.Math.get(key); + return ret; + } + } + private static class XWTString extends JS.Obj { + public XWTString() { + JS gs = new JS.GlobalScope(); + put("parseInt",gs.get("parseInt")); + put("parseFloat",gs.get("parseFloat")); + put("decodeURI",gs.get("decodeURI")); + put("decodeURIComponent",gs.get("decodeURIComponent")); + put("encodeURI",gs.get("encodeURI")); + put("encodeURIComponent",gs.get("encodeURIComponent")); + setSeal(true); + } + } } - - - - - - - -