2003/07/09 03:03:36
[org.ibex.core.git] / src / org / xwt / js / GlobalScopeImpl.java
1 package org.xwt.js;
2
3 class GlobalScopeImpl extends JS.Scope {
4     private final static Double NaN = new Double(Double.NaN);
5     private final static Double POSITIVE_INFINITY = new Double(Double.POSITIVE_INFINITY);
6     
7     public GlobalScopeImpl(JS.Scope parent) {
8         super(parent);
9     }
10     public Object get(Object key) {
11         if(key.equals("NaN")) return NaN;
12         if(key.equals("Infinity")) return POSITIVE_INFINITY;
13         if(key.equals("undefined")) return null;
14         return super.get(key);
15     }
16     public Object callMethod(Object method, JS.Array args, boolean checkOnly) {
17         if(method.equals("parseInt")) {
18             if(checkOnly) return Boolean.TRUE;
19             return parseInt(args);
20         } else if(method.equals("parseFloat")) {
21             if(checkOnly) return Boolean.TRUE;
22             return parseFloat(args);
23         } else if(method.equals("isNaN")) {
24             if(checkOnly) return Boolean.TRUE;
25             return isNaN(args);
26         } else if(method.equals("isFinite")) {
27             if(checkOnly) return Boolean.TRUE;
28             return isFinite(args);
29         } else if(method.equals("decodeURI")) {
30             if(checkOnly) return Boolean.TRUE;
31             return decodeURI(args);
32         } else if(method.equals("decodeURIComponent")) {
33             if(checkOnly) return Boolean.TRUE;
34             return decodeURIComponent(args);
35         } else if(method.equals("encodeURI")) {
36             if(checkOnly) return Boolean.TRUE;
37             return encodeURI(args);
38         } else if(method.equals("encodeURIComponent")) {
39             if(checkOnly) return Boolean.TRUE;
40             return encodeURIComponent(args);
41         } else if(method.equals("stringFromCharCode")) {
42             if(checkOnly) return Boolean.TRUE;
43             return stringFromCharCode(args);
44         }
45         return super.callMethod(method,args,checkOnly);
46     }
47     private Object stringFromCharCode(JS.Array args) {
48         char buf[] = new char[args.length()];
49         for(int i=0;i<args.length();i++)
50             buf[i] = (char)(JS.toInt(args.elementAt(i)) & 0xffff);
51         return new String(buf);
52     }
53     private Object parseInt(JS.Array args) {
54         String s = args.length() > 0 ? args.elementAt(0).toString() : "";
55         int radix = args.length() > 1 ? toInt(args.elementAt(1)) : 0;
56         int start = 0;
57         int length = s.length();
58         int sign = 1;
59         long n = 0;
60         if(radix != 0 && (radix < 2 || radix > 36)) return NaN;
61         while(start < length && Character.isWhitespace(s.charAt(start))) start++;
62         if((length >= start+1) && (s.charAt(start) == '+' || s.charAt(start) == '-')) {
63             sign = s.charAt(start) == '+' ? 1 : -1;
64             start++;
65         }
66         if(radix == 0 && length >= start+1 && s.charAt(start) == '0') {
67             start++;
68             if(length >= start+1 && (s.charAt(start) == 'x' || s.charAt(start) == 'X')) {
69                 start++;
70                 radix = 16;
71             } else {
72                 radix = 8;
73                 if(length == start || Character.digit(s.charAt(start+1),8)==-1) return new Integer(0);
74             }
75         }
76         if(radix == 0) radix = 10;
77         if(length == start || Character.digit(s.charAt(start),radix) == -1) return NaN;
78         // try the fast way first
79         try {
80             String s2 = start == 0 ? s : s.substring(start);
81             return new Integer(sign*Integer.parseInt(s2,radix));
82         } catch(NumberFormatException e) { }
83         // fall through to a slower but emca-compliant method
84         for(int i=start;i<length;i++) {
85             int digit = Character.digit(s.charAt(i),radix);
86             if(digit < 0) break;
87             n = n*radix + digit;
88             if(n < 0) return NaN; // overflow;
89         }
90         if(n <= Integer.MAX_VALUE) return new Integer(sign*(int)n);
91         return new Long((long)sign*n);
92     }
93     private Object parseFloat(JS.Array args) {
94         String s = args.length() > 0 ? args.elementAt(0).toString() : "";
95         int start = 0;
96         int length = s.length();
97         while(start < length && Character.isWhitespace(s.charAt(0))) start++;
98         int end = length;
99         // as long as the string has no trailing garbage,this is fast, its slow with
100         // trailing garbage
101         while(start < end) {
102             try {
103                 return new Double(s.substring(start,length));
104             } catch(NumberFormatException e) { }
105             end--;
106         }
107         return NaN;
108     }
109     private Object isNaN(JS.Array args) {
110         double d = args.length() > 0 ? toDouble(args.elementAt(0)) : Double.NaN;
111         return d == d ? Boolean.FALSE : Boolean.TRUE;
112     }
113     private Object isFinite(JS.Array args) {
114         double d = args.length() > 0 ? toDouble(args.elementAt(0)) : Double.NaN;
115         return (d == d && !Double.isInfinite(d)) ? Boolean.TRUE : Boolean.FALSE;
116     }
117     private Object decodeURI(JS.Array args) {
118         throw new JS.Exn("decodeURI is unimplemented");
119     }
120     private Object decodeURIComponent(JS.Array args) {
121         throw new JS.Exn("decodeURIComponent is unimplemented");
122     }
123     private Object encodeURI(JS.Array args) {
124         throw new JS.Exn("encodeURI is unimplemented");
125     }
126     private Object encodeURIComponent(JS.Array args) {
127         throw new JS.Exn("encodeURIComponent is unimplemented");
128     }
129 }