Jacek Caban : jscript: Added Number.valueOf implementation.

Alexandre Julliard julliard at winehq.org
Sat Oct 18 13:38:40 CDT 2008


Module: wine
Branch: master
Commit: f30de9b9fc454c8cb76c26854f6e1089837ab1cb
URL:    http://source.winehq.org/git/wine.git/?a=commit;h=f30de9b9fc454c8cb76c26854f6e1089837ab1cb

Author: Jacek Caban <jacek at codeweavers.com>
Date:   Fri Oct 17 17:04:45 2008 -0500

jscript: Added Number.valueOf implementation.

---

 dlls/jscript/number.c     |   29 +++++++++++++++++------------
 dlls/jscript/tests/api.js |    9 +++++++++
 2 files changed, 26 insertions(+), 12 deletions(-)

diff --git a/dlls/jscript/number.c b/dlls/jscript/number.c
index 598de42..d909cdb 100644
--- a/dlls/jscript/number.c
+++ b/dlls/jscript/number.c
@@ -105,8 +105,18 @@ static HRESULT Number_toPrecision(DispatchEx *dispex, LCID lcid, WORD flags, DIS
 static HRESULT Number_valueOf(DispatchEx *dispex, LCID lcid, WORD flags, DISPPARAMS *dp,
         VARIANT *retv, jsexcept_t *ei, IServiceProvider *sp)
 {
-    FIXME("\n");
-    return E_NOTIMPL;
+    TRACE("\n");
+
+    if(!is_class(dispex, JSCLASS_NUMBER)) {
+        FIXME("throw TypeError\n");
+        return E_FAIL;
+    }
+
+    if(retv) {
+        NumberInstance *number = (NumberInstance*)dispex;
+        *retv = number->num;
+    }
+    return S_OK;
 }
 
 static HRESULT Number_hasOwnProperty(DispatchEx *dispex, LCID lcid, WORD flags, DISPPARAMS *dp,
@@ -198,19 +208,13 @@ static HRESULT NumberConstr_value(DispatchEx *dispex, LCID lcid, WORD flags, DIS
     case DISPATCH_CONSTRUCT: {
         DispatchEx *obj;
 
-        switch(arg_cnt(dp)) {
-        case 0:
-            V_VT(&num) = VT_I4;
-            V_I4(&num) = 0;
-            break;
-        case 1:
+        if(arg_cnt(dp)) {
             hres = to_number(dispex->ctx, get_arg(dp, 0), ei, &num);
             if(FAILED(hres))
                 return hres;
-            break;
-        default:
-            FIXME("unimplemented args\n");
-            return E_NOTIMPL;
+        }else {
+            V_VT(&num) = VT_I4;
+            V_I4(&num) = 0;
         }
 
         hres = create_number(dispex->ctx, &num, &obj);
@@ -258,6 +262,7 @@ HRESULT create_number_constr(script_ctx_t *ctx, DispatchEx **ret)
     if(FAILED(hres))
         return hres;
 
+    V_VT(&number->num) = VT_I4;
     hres = create_builtin_function(ctx, NumberConstr_value, PROPF_CONSTR, &number->dispex, ret);
 
     jsdisp_release(&number->dispex);
diff --git a/dlls/jscript/tests/api.js b/dlls/jscript/tests/api.js
index 3bb3ddf..602b7df 100644
--- a/dlls/jscript/tests/api.js
+++ b/dlls/jscript/tests/api.js
@@ -362,6 +362,15 @@ ok(Number() === 0, "Number() = " + Number());
 ok(Number(false) === 0, "Number(false) = " + Number(false));
 ok(Number("43") === 43, "Number('43') = " + Number("43"));
 
+tmp = (new Number(1)).valueOf();
+ok(tmp === 1, "(new Number(1)).valueOf = " + tmp);
+tmp = (new Number(1,2)).valueOf();
+ok(tmp === 1, "(new Number(1,2)).valueOf = " + tmp);
+tmp = (new Number()).valueOf();
+ok(tmp === 0, "(new Number()).valueOf = " + tmp);
+tmp = Number.prototype.valueOf();
+ok(tmp === 0, "Number.prototype.valueOf = " + tmp);
+
 tmp = Math.min(1);
 ok(tmp === 1, "Math.min(1) = " + tmp);
 




More information about the wine-cvs mailing list