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();
-
public Object get(Object name) {
if (name.equals("alt")) return Surface.alt ? Boolean.TRUE : Boolean.FALSE;
- else if (name.equals("rr")) return rr;
else if (name.equals("box")) return new Box();
else if (name.equals("control")) return Surface.control ? Boolean.TRUE : Boolean.FALSE;
else if (name.equals("shift")) return Surface.shift ? Boolean.TRUE : Boolean.FALSE;
else if (name.equals("tempDir")) return System.getProperty("java.io.tempdir");
else if (name.equals("math")) return xwtMath;
else if (name.equals("string")) return xwtString;
- else if (name.equals("parseInt")) return xwtString.get("parseInt");
- else if (name.equals("parseFloat")) return xwtString.get("parseFloat");
else if (name.equals("button")) {
if (Surface.button1 && !Surface.button2 && !Surface.button3) return new Integer(1);
- else if (!Surface.button1 && Surface.button2 && !Surface.button3) return new Integer(1);
- else if (!Surface.button1 && !Surface.button2 && Surface.button3) return new Integer(1);
+ else if (!Surface.button1 && Surface.button2 && !Surface.button3) return new Integer(2);
+ else if (!Surface.button1 && !Surface.button2 && Surface.button3) return new Integer(3);
else return new Integer(0);
}
else return rr.get(name);
}
- public void put(Object name, final Object value) {
- if (name.equals("thread") && value != null && (value instanceof JS.Callable || value instanceof JS.CompiledFunction)) {
+ public Object put(Object name, final Object value) {
+ if (name.equals("thread") && value != null && (value instanceof JS.Callable || value instanceof Function)) {
Scheduler.add(new Scheduler.Task() { public void perform() {
- new JS.Thread((CompiledFunction)value).resume();
+ new JS.Context((Function)value, null).resume();
} });
} else if (name.equals("clipboard")) Platform.setClipBoard(value.toString());
else if (name.equals("frame")) Platform.createSurface((Box)value, true, true);
else if (name.equals("proxyAuthorization")) {
HTTP.Proxy.Authorization.authorization = value.toString();
HTTP.Proxy.Authorization.waitingForUser.release();
- } else super.put(name, value);
+ } else return super.put(name, value);
+ return null;
}
public Object callMethod(Object method, JS.Array args, boolean checkOnly) {
if (checkOnly) return Boolean.TRUE;
return new Res.Zip((Res)args.elementAt(0));
+ } else if (method.equals("uncab")) {
+ if (checkOnly) return Boolean.TRUE;
+ return new Res.Cab((Res)args.elementAt(0));
+
} else if (method.equals("watchProgress")) {
if (checkOnly) return Boolean.TRUE;
- return new Res.ProgressWatcher((Res)args.elementAt(0), (JS.CompiledFunction)args.elementAt(1));
+ return new Res.ProgressWatcher((Res)args.elementAt(0), (Function)args.elementAt(1));
} else if (method.equals("yield")) {
if (checkOnly) return Boolean.TRUE;
- sleep(0);
- return null;
+ return sleep(0);
} else if (method.equals("load")) {
if (checkOnly) return Boolean.TRUE;
if (checkOnly) return Boolean.TRUE;
if (args != null && (args.length() != 1 || args.elementAt(0) == null)) return null;
int i = args == null ? 0 : Box.stoi(args.elementAt(0).toString());
- sleep(i);
- return null;
-
- } else if (method.equals("openFile")) {
- if (checkOnly) return Boolean.TRUE;
- if (args.length() != 1) return null;
- String file = Platform.fileDialog(args.elementAt(0).toString(), false);
- return file == null ? null : new Res.File(file);
-
- } else if (method.equals("saveFile") || method.equals("saveFileAs")) {
- if (checkOnly) return Boolean.TRUE;
- if (args.length() != 2) return null;
- if (!(args.elementAt(1) instanceof Res)) return null;
- String file = args.elementAt(0).toString();
- if (method.equals("saveFileAs") ||
- safeFiles.get(Platform.isCaseSensitive() ? file : file.toLowerCase()) == null) {
- file = Platform.fileDialog(file, true);
- // FIXME: throw exception here
- if (file == null) return null;
- safeFiles.put(Platform.isCaseSensitive() ? file : file.toLowerCase(), new Object());
- }
- try {
- InputStream is = ((Res)args.elementAt(1)).getInputStream();
- FileOutputStream out = new FileOutputStream(file);
- byte[] buffer = new byte[1024 * 16];
- while(true) {
- int numread = is.read(buffer, 0, buffer.length);
- if (numread == -1) break;
- out.write(buffer, 0, numread);
- }
- is.close();
- out.close();
- return null;
- } catch (IOException e) {
- if (Log.on) Log.log(XWT.class, "IO Exception while writing a ByteStream to a file");
- if (Log.on) Log.log(XWT.class, e);
- throw new JS.Exn("error while writing a Resource to a file");
- }
+ return sleep(i);
} else if (method.equals("parseHTML")) {
if (checkOnly) return Boolean.TRUE;
}
}
- public static void sleep(final int i) {
- final JS.Thread jsthread = JS.Thread.current();
+ public static Object sleep(final int i) {
+ final JS.Context jsthread = JS.Context.current();
final long currentTime = System.currentTimeMillis();
final Scheduler.Task task = new Scheduler.Task() { public void perform() {
+ // FIXME: don't busy-wait
if (System.currentTimeMillis() - currentTime < i) Scheduler.add(this);
else jsthread.resume();
} };
- jsthread.pause();
Scheduler.add(task);
+ return JS.Context.pause;
}
private static class XWTMath extends org.xwt.js.Math {
}
public Object get(Object key) {
Object ret = super.get(key);
- if(ret == null) ret = JS.Math.get(key);
+ if(ret == null) ret = org.xwt.js.Math.singleton.get(key);
return ret;
}
}