minor bug fixes from moving interfaces
[org.ibex.js.git] / src / org / ibex / js / JSDate.java
index dc6d839..5e5eaaf 100644 (file)
@@ -44,7 +44,8 @@ import java.text.DateFormat;
  * @author Mike McCabe
  * @author Adam Megacz (many modifications
  */
-public class JSDate extends JS {
+public class JSDate extends JS.Immutable {
+    private static final JS.Method METHOD = new JS.Method();
 
     public JSDate() {
         if (thisTimeZone == null) {
@@ -55,75 +56,73 @@ public class JSDate extends JS {
         }
     }
 
-    String coerceToString() { return date_format(date, FORMATSPEC_FULL); }
+    public String coerceToString() { return date_format(date, FORMATSPEC_FULL); }
 
-    public JS callMethod(JS method, JS a0, JS a1, JS a2, JS[] rest, int nargs) throws JSExn {
-        switch(nargs) {
+    public JS call(JS method, JS[] args) throws JSExn {
+        switch(args.length) {
             case 0: {
-                //#switch(JS.toString(method))
-                case "toString": return JS.S(date_format(date, FORMATSPEC_FULL));
-                case "toTimeString": return JS.S(date_format(date, FORMATSPEC_TIME));
-                case "toDateString": return JS.S(date_format(date, FORMATSPEC_DATE));
-                case "toLocaleString": return JS.S(toLocaleString(date));
-                case "toLocaleTimeString": return JS.S(toLocaleTimeString(date));
-                case "toLocaleDateString": return JS.S(toLocaleDateString(date));
-                case "toUTCString": return JS.S(toUTCString(date));
-                case "valueOf": return N(this.date);
-                case "getTime": return N(this.date);
-                case "getYear": return N(getYear(date));
-                case "getFullYear": return N(YearFromTime(LocalTime(date)));
-                case "getUTCFullYear": return N(YearFromTime(date));
-                case "getMonth": return N(MonthFromTime(LocalTime(date)));
-                case "getUTCMonth": return N(MonthFromTime(date));
-                case "getDate": return N(DateFromTime(LocalTime(date)));
-                case "getUTCDate": return N(DateFromTime(date));
-                case "getDay": return N(WeekDay(LocalTime(date)));
-                case "getUTCDay": return N(WeekDay(date));
-                case "getHours": return N(HourFromTime(LocalTime(date)));
-                case "getUTCHours": return N(HourFromTime(date));
-                case "getMinutes": return N(MinFromTime(LocalTime(date)));
-                case "getUTCMinutes": return N(MinFromTime(date));
-                case "getSeconds": return N(SecFromTime(LocalTime(date)));
-                case "getUTCSeconds": return N(SecFromTime(date));
-                case "getMilliseconds": return N(msFromTime(LocalTime(date)));
-                case "getUTCMilliseconds": return N(msFromTime(date));
-                case "getTimezoneOffset": return N(getTimezoneOffset(date));
+                //#switch(Script.toString(method))
+                case "toString": return Script.S(date_format(date, FORMATSPEC_FULL));
+                case "toTimeString": return Script.S(date_format(date, FORMATSPEC_TIME));
+                case "toDateString": return Script.S(date_format(date, FORMATSPEC_DATE));
+                case "toLocaleString": return Script.S(toLocaleString(date));
+                case "toLocaleTimeString": return Script.S(toLocaleTimeString(date));
+                case "toLocaleDateString": return Script.S(toLocaleDateString(date));
+                case "toUTCString": return Script.S(toUTCString(date));
+                case "valueOf": return Script.N(this.date);
+                case "getTime": return Script.N(this.date);
+                case "getYear": return Script.N(getYear(date));
+                case "getFullYear": return Script.N(YearFromTime(LocalTime(date)));
+                case "getUTCFullYear": return Script.N(YearFromTime(date));
+                case "getMonth": return Script.N(MonthFromTime(LocalTime(date)));
+                case "getUTCMonth": return Script.N(MonthFromTime(date));
+                case "getDate": return Script.N(DateFromTime(LocalTime(date)));
+                case "getUTCDate": return Script.N(DateFromTime(date));
+                case "getDay": return Script.N(WeekDay(LocalTime(date)));
+                case "getUTCDay": return Script.N(WeekDay(date));
+                case "getHours": return Script.N(HourFromTime(LocalTime(date)));
+                case "getUTCHours": return Script.N(HourFromTime(date));
+                case "getMinutes": return Script.N(MinFromTime(LocalTime(date)));
+                case "getUTCMinutes": return Script.N(MinFromTime(date));
+                case "getSeconds": return Script.N(SecFromTime(LocalTime(date)));
+                case "getUTCSeconds": return Script.N(SecFromTime(date));
+                case "getMilliseconds": return Script.N(msFromTime(LocalTime(date)));
+                case "getUTCMilliseconds": return Script.N(msFromTime(date));
+                case "getTimezoneOffset": return Script.N(getTimezoneOffset(date));
                 //#end
-                return super.callMethod(method, a0, a1, a2, rest, nargs);
+                return super.call(method, args);
             }
             case 1: {
-                //#switch(JS.toString(method))
-                case "setTime": return N(this.setTime(toDouble(a0)));
-                case "setYear": return N(this.setYear(toDouble(a0)));
+                //#switch(Script.toString(method))
+                case "setTime": return Script.N(this.setTime(Script.toDouble(args[0])));
+                case "setYear": return Script.N(this.setYear(Script.toDouble(args[0])));
                 //#end
                 // fall through
             }
             default: {
-                JS[] args = new JS[nargs];
-                for(int i=0; i<nargs; i++) args[i] = i==0 ? a0 : i==1 ? a1 : i==2 ? a2 : rest[i-3];
-                //#switch(JS.toString(method))
-                case "setMilliseconds": return N(this.makeTime(args, 1, true));
-                case "setUTCMilliseconds": return N(this.makeTime(args, 1, false));
-                case "setSeconds": return N(this.makeTime(args, 2, true));
-                case "setUTCSeconds": return N(this.makeTime(args, 2, false));
-                case "setMinutes": return N(this.makeTime(args, 3, true));
-                case "setUTCMinutes": return N(this.makeTime(args, 3, false));
-                case "setHours": return N(this.makeTime(args, 4, true));
-                case "setUTCHours": return N(this.makeTime(args, 4, false));
-                case "setDate": return N(this.makeDate(args, 1, true));
-                case "setUTCDate": return N(this.makeDate(args, 1, false));
-                case "setMonth": return N(this.makeDate(args, 2, true));
-                case "setUTCMonth": return N(this.makeDate(args, 2, false));
-                case "setFullYear": return N(this.makeDate(args, 3, true));
-                case "setUTCFullYear": return N(this.makeDate(args, 3, false));
+                //#switch(Script.toString(method))
+                case "setMilliseconds": return Script.N(this.makeTime(args, 1, true));
+                case "setUTCMilliseconds": return Script.N(this.makeTime(args, 1, false));
+                case "setSeconds": return Script.N(this.makeTime(args, 2, true));
+                case "setUTCSeconds": return Script.N(this.makeTime(args, 2, false));
+                case "setMinutes": return Script.N(this.makeTime(args, 3, true));
+                case "setUTCMinutes": return Script.N(this.makeTime(args, 3, false));
+                case "setHours": return Script.N(this.makeTime(args, 4, true));
+                case "setUTCHours": return Script.N(this.makeTime(args, 4, false));
+                case "setDate": return Script.N(this.makeDate(args, 1, true));
+                case "setUTCDate": return Script.N(this.makeDate(args, 1, false));
+                case "setMonth": return Script.N(this.makeDate(args, 2, true));
+                case "setUTCMonth": return Script.N(this.makeDate(args, 2, false));
+                case "setFullYear": return Script.N(this.makeDate(args, 3, true));
+                case "setUTCFullYear": return Script.N(this.makeDate(args, 3, false));
                 //#end
             }
         }
-        return super.callMethod(method, a0, a1, a2, rest, nargs);
+        return super.call(method, args);
     }
 
     public JS get(JS key) throws JSExn {
-        //#switch(JS.toString(key))
+        //#switch(Script.toString(key))
         case "toString": return METHOD;
         case "toTimeString": return METHOD;
         case "toDateString": return METHOD;
@@ -539,7 +538,7 @@ public class JSDate extends JS {
                 if (d != d || Double.isInfinite(d)) {
                     return Double.NaN;
                 }
-                array[loop] = toDouble(args[loop]);
+                array[loop] = Script.toDouble(args[loop]);
             } else {
                 array[loop] = 0;
             }
@@ -558,7 +557,7 @@ public class JSDate extends JS {
                               array[3], array[4], array[5], array[6]);
         d = TimeClip(d);
         return d;
-        //        return N(d);
+        //        return Script.N(d);
     }
 
     /*
@@ -888,35 +887,34 @@ public class JSDate extends JS {
         return result.toString();
     }
 
-    private static double _toNumber(JS o) throws JSExn { return JS.toDouble(o); }
-    private static double _toNumber(JS[] o, int index) throws JSExn { return JS.toDouble(o[index]); }
-    private static double toDouble(double d) { return d; }
+    private static double _toNumber(JS o) throws JSExn { return Script.toDouble(o); }
+    private static double _toNumber(JS[] o, int index) throws JSExn { return Script.toDouble(o[index]); }
 
-    public JSDate(JS a0, JS a1, JS a2, JS[] rest, int nargs) throws JSExn {
+    public JSDate(JS[] args) throws JSExn {
 
         JSDate obj = this;
-        switch (nargs) {
+        switch (args.length) {
             case 0: {
                 obj.date = Now();
                 return;
             }
             case 1: {
                 double date;
-                if(isString(a0))
-                    date = date_parseString(JS.toString(a0));
+                if(Script.isString(args[0]))
+                    date = date_parseString(Script.toString(args[0]));
                 else
-                    date = _toNumber(a0);
+                    date = _toNumber(args[0]);
                 obj.date = TimeClip(date);
                 return;
             }
             default: {
                 // multiple arguments; year, month, day etc.
                 double array[] = new double[MAXARGS];
-                array[0] = toDouble(a0);
-                array[1] = toDouble(a1);
-                if (nargs >= 2) array[2] = toDouble(a2);
-                for(int i=0; i<nargs; i++) {
-                    double d = _toNumber(i==0?a0:i==1?a1:i==2?a2:rest[i-3]);
+                array[0] = Script.toDouble(args[0]);
+                array[1] = Script.toDouble(args[1]);
+                if (args.length >= 2) array[2] = Script.toDouble(args[2]);
+                for (int i=0; i < args.length; i++) {
+                    double d = _toNumber(args[i]);
                     if (d != d || Double.isInfinite(d)) {
                         obj.date = Double.NaN;
                         return;
@@ -1083,7 +1081,6 @@ public class JSDate extends JS {
                 this.date = Double.NaN;
                 return this.date;
             }
-            conv[i] = toDouble(conv[i]);
         }
 
         if (local)
@@ -1154,7 +1151,6 @@ public class JSDate extends JS {
                 this.date = Double.NaN;
                 return this.date;
             }
-            conv[i] = toDouble(conv[i]);
         }
 
         /* return NaN if date is NaN and we're not setting the year,