X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=src%2Forg%2Fxwt%2FXWT.java;h=c5f7a133ef874689e9a86de4fa869142024c4399;hb=6a96430e10e27fc1de5754cb5add705f929dd109;hp=3c4d99f55cdf0905334ee4d582d323aec356e0e8;hpb=f3ad5161a913d512a977ebab0767b27fa463f012;p=org.ibex.core.git diff --git a/src/org/xwt/XWT.java b/src/org/xwt/XWT.java index 3c4d99f..c5f7a13 100644 --- a/src/org/xwt/XWT.java +++ b/src/org/xwt/XWT.java @@ -50,9 +50,15 @@ public final class XWT extends JS.Obj { else return rr.get(name); } - public void put(Object name, Object value) { - if (name.equals("thread") && value != null && value instanceof JS.Callable) ThreadMessage.newthread((JS.Callable)value); - else if (name.equals("clipboard")) Platform.setClipBoard(value.toString()); + public void put(Object name, final Object value) { + if (name.equals("thread") && value != null && (value instanceof JS.Callable || value instanceof JS.CompiledFunction)) { + Scheduler.add(new Scheduler.Task() { public Object call(Object arg) { + new JS.Thread((CompiledFunction)value).resume(); + return null; + } }); + } else if (name.equals("clipboard")) Platform.setClipBoard(value.toString()); + else if (name.equals("frame")) Platform.createSurface((Box)value, true, true); + else if (name.equals("window")) Platform.createSurface((Box)value, false, true); else if (name.equals("proxyAuthorization")) { HTTP.Proxy.Authorization.authorization = value.toString(); HTTP.Proxy.Authorization.waitingForUser.release(); @@ -80,9 +86,13 @@ public final class XWT extends JS.Obj { return new Res.Graft((Res)args.elementAt(0), args.elementAt(1), args.elementAt(2)); return new JS.Graft((JS)args.elementAt(0), args.elementAt(1), args.elementAt(2)); + } else if (method.equals("unzip")) { + if (checkOnly) return Boolean.TRUE; + return new Res.Zip((Res)args.elementAt(0)); + } else if (method.equals("watchProgress")) { if (checkOnly) return Boolean.TRUE; - return new Res.ProgressWatcher((Res)args.elementAt(0), (JS.Callable)args.elementAt(1)); + return new Res.ProgressWatcher((Res)args.elementAt(0), (JS.CompiledFunction)args.elementAt(1)); } else if (method.equals("yield")) { if (checkOnly) return Boolean.TRUE; @@ -108,6 +118,12 @@ public final class XWT extends JS.Obj { if (checkOnly) return Boolean.TRUE; return new Regexp(args); + } else if (method.equals("apply")) { + if (checkOnly) return Boolean.TRUE; + Box b = (Box)args.elementAt(0); + Template.getTemplate((Res)args.elementAt(1)).apply(b, null, this); + return b; + } else if (method.equals("xmlrpc")) { if (checkOnly) return Boolean.TRUE; if (args.length() != 1 || args.elementAt(0) == null) return null; @@ -219,20 +235,22 @@ public final class XWT extends JS.Obj { } } - public static void sleep(int i) { - java.lang.Thread thread = java.lang.Thread.currentThread(); - if (!(thread instanceof ThreadMessage)) { - if (Log.on) Log.log(XWT.class, "cannot sleep() or yield() in the foreground thread"); - } else { - ThreadMessage mythread = (ThreadMessage)thread; - mythread.done.release(); - if (i > 0) try { java.lang.Thread.sleep(i); } catch (Exception e) { } - Message.Q.add(mythread); - mythread.go.block(); - } + public static void sleep(final int i) { + final JS.Thread jsthread = JS.Thread.current(); + final long currentTime = System.currentTimeMillis(); + final Scheduler.Task task = new Scheduler.Task() { public Object call(Object arg) { + if (System.currentTimeMillis() - currentTime < i) { + Scheduler.add(this); + } else { + jsthread.resume(); + } + return null; + } }; + jsthread.pause(); + Scheduler.add(task); } - private static class XWTMath extends JS.Obj { + private static class XWTMath extends org.xwt.js.Math { public XWTMath() { JS gs = new JS.GlobalScope(); put("isNaN",gs.get("isNaN"));