X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=src%2Forg%2Fxwt%2Fjs%2FJS.java;h=05251b87334ee959341b7572499a6a953f28091f;hb=2fa20bbe798c44d0443d7b80d8dbcf7eb13fff4a;hp=6c9448dfa41a9230104d6e177fc378f696538fe8;hpb=6076f07a78d5e01a53304b0ae9df97273a0688fe;p=org.ibex.core.git diff --git a/src/org/xwt/js/JS.java b/src/org/xwt/js/JS.java index 6c9448d..05251b8 100644 --- a/src/org/xwt/js/JS.java +++ b/src/org/xwt/js/JS.java @@ -6,25 +6,23 @@ import java.io.*; import java.util.*; /** - * The public API for the JS engine; JS itself is actually a class - * implementing the minimal amount of functionality for an Object - * which can be manipulated by JavaScript code. + * The public API for the JS engine. JS itself is actually a class + * implementing the absolute minimal amount of functionality for an + * Object which can be manipulated by JavaScript code. The static + * methods, fields, and inner classes of JS define the publicly + * visible API for the XWT JavaScript engine; code outside this + * package should never depend on anything not defined in this file. */ public abstract class JS { + // Public Helper Methods ////////////////////////////////////////////////////////////////////// - // Static Methods ////////////////////////////////////////////////////////////////////// - - private static Hashtable currentFunction = new Hashtable(); - public static Function getCurrentFunction() { return (Function)currentFunction.get(Thread.currentThread()); } - public static String getCurrentFunctionSourceName() { return getCurrentFunctionSourceName(Thread.currentThread()); } - public static String getFileAndLine() { return getCurrentFunctionSourceName() + ":" + getCurrentFunction().getLine(); } - public static String getCurrentFunctionSourceName(Thread t) { - Function f = (Function)currentFunction.get(t); - if (f == null) return "null"; - return f.getSourceName(); + /** parse and compile a function */ + public static CompiledFunction parse(String sourceName, int firstLine, Reader sourceCode) throws IOException { + return new CompiledFunction(sourceName, firstLine, sourceCode, null); } + /** coerce an object to a Boolean */ public static boolean toBoolean(Object o) { if (o == null) return false; if (o instanceof Boolean) return ((Boolean)o).booleanValue(); @@ -32,8 +30,13 @@ public abstract class JS { return true; } + /** coerce an object to a Long */ public static long toLong(Object o) { return toNumber(o).longValue(); } + + /** coerce an object to a Double */ public static double toDouble(Object o) { return toNumber(o).doubleValue(); } + + /** coerce an object to a Number */ public static Number toNumber(Object o) { if (o == null) return new Long(0); if (o instanceof Number) return ((Number)o); @@ -55,9 +58,9 @@ public abstract class JS { public boolean coerceToBoolean() { throw new Error("you cannot coerce a " + this.getClass().getName() + " into a Boolean"); } - // Subclasses ///////////////////////////////////////////////////////////////////////// + // Inner Classes ///////////////////////////////////////////////////////////////////////// - /** A slightly more featureful version of JS */ + /** A sensible implementation of the abstract methods in the JS class */ public static class Obj extends JS { private Hash entries = new Hash(); private boolean sealed = false; @@ -69,169 +72,49 @@ public abstract class JS { public Object[] keys() { return(entries.keys()); } } - /** An exception which can be thrown and caught by JavaScripts */ + /** An exception which can be thrown and caught by JavaScript code */ public static class Exn extends RuntimeException { private Object js = null; public Exn(Object js) { this.js = js; } - public String toString() { return "JS.Exn: " + js.toString(); } + public String toString() { return "JS.Exn: " + js; } public String getMessage() { return toString(); } public Object getObject() { return js; } } - /** A JavaScript Array */ - public static class Array extends Obj { - private Vec vec = new Vec(); + /** The publicly-visible face of JavaScript Array objects */ + public static class Array extends ArrayImpl { public Array() { } - public Array(int size) { vec.setSize(size); } - private static int intVal(Object o) { - if (o instanceof Number) { - int intVal = ((Number)o).intValue(); - if (intVal == ((Number)o).doubleValue()) return intVal; - return Integer.MIN_VALUE; - } - if (!(o instanceof String)) return Integer.MIN_VALUE; - String s = (String)o; - for(int i=0; i '9') return Integer.MIN_VALUE; - return Integer.parseInt(s); - } - public Object get(Object key) throws JS.Exn { - // FIXME: HACK! - if (key.equals("cascade")) return org.xwt.Trap.cascadeFunction; - if (key.equals("trapee")) return org.xwt.Trap.currentTrapee(); - if (key.equals("length")) return new Long(vec.size()); - int i = intVal(key); - if (i == Integer.MIN_VALUE) return super.get(key); - try { - return vec.elementAt(i); - } catch (ArrayIndexOutOfBoundsException e) { - throw new JS.Exn(e.getMessage()); - } - } - public void put(Object key, Object val) { - if (key.equals("length")) vec.setSize(toNumber(val).intValue()); - int i = intVal(key); - if (i == Integer.MIN_VALUE) super.put(key, val); - else { - if (i >= vec.size()) vec.setSize(i+1); - vec.setElementAt(val, i); - } - } - public Object[] keys() { - Object[] sup = super.keys(); - Object[] ret = new Object[vec.size() + 1 + sup.length]; - System.arraycopy(sup, 0, ret, vec.size(), sup.length); - for(int i=0; i