2 * Copyright 2008 Jacek Caban for CodeWeavers
4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Lesser General Public
6 * License as published by the Free Software Foundation; either
7 * version 2.1 of the License, or (at your option) any later version.
9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Lesser General Public License for more details.
14 * You should have received a copy of the GNU Lesser General Public
15 * License along with this library; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
21 #include "wine/debug.h"
23 WINE_DEFAULT_DEBUG_CHANNEL(jscript
);
31 static const WCHAR toStringW
[] = {'t','o','S','t','r','i','n','g',0};
32 static const WCHAR toLocaleStringW
[] = {'t','o','L','o','c','a','l','e','S','t','r','i','n','g',0};
33 static const WCHAR toFixedW
[] = {'t','o','F','i','x','e','d',0};
34 static const WCHAR toExponentialW
[] = {'t','o','E','x','p','o','n','e','n','t','i','a','l',0};
35 static const WCHAR toPrecisionW
[] = {'t','o','P','r','e','c','i','s','i','o','n',0};
36 static const WCHAR valueOfW
[] = {'v','a','l','u','e','O','f',0};
37 static const WCHAR hasOwnPropertyW
[] = {'h','a','s','O','w','n','P','r','o','p','e','r','t','y',0};
38 static const WCHAR propertyIsEnumerableW
[] =
39 {'p','r','o','p','e','r','t','y','I','s','E','n','u','m','e','r','a','b','l','e',0};
40 static const WCHAR isPrototypeOfW
[] = {'i','s','P','r','o','t','o','t','y','p','e','O','f',0};
42 /* ECMA-262 3rd Edition 15.7.4.2 */
43 static HRESULT
Number_toString(DispatchEx
*dispex
, LCID lcid
, WORD flags
, DISPPARAMS
*dp
,
44 VARIANT
*retv
, jsexcept_t
*ei
, IServiceProvider
*sp
)
46 NumberInstance
*number
;
52 if(!is_class(dispex
, JSCLASS_NUMBER
)) {
53 FIXME("throw TypeError\n");
57 number
= (NumberInstance
*)dispex
;
59 if(arg_cnt(dp
) != 0) {
60 FIXME("unsupported args\n");
64 hres
= to_string(dispex
->ctx
, &number
->num
, ei
, &str
);
77 static HRESULT
Number_toLocaleString(DispatchEx
*dispex
, LCID lcid
, WORD flags
, DISPPARAMS
*dp
,
78 VARIANT
*retv
, jsexcept_t
*ei
, IServiceProvider
*sp
)
84 static HRESULT
Number_toFixed(DispatchEx
*dispex
, LCID lcid
, WORD flags
, DISPPARAMS
*dp
,
85 VARIANT
*retv
, jsexcept_t
*ei
, IServiceProvider
*sp
)
91 static HRESULT
Number_toExponential(DispatchEx
*dispex
, LCID lcid
, WORD flags
, DISPPARAMS
*dp
,
92 VARIANT
*retv
, jsexcept_t
*ei
, IServiceProvider
*sp
)
98 static HRESULT
Number_toPrecision(DispatchEx
*dispex
, LCID lcid
, WORD flags
, DISPPARAMS
*dp
,
99 VARIANT
*retv
, jsexcept_t
*ei
, IServiceProvider
*sp
)
105 static HRESULT
Number_valueOf(DispatchEx
*dispex
, LCID lcid
, WORD flags
, DISPPARAMS
*dp
,
106 VARIANT
*retv
, jsexcept_t
*ei
, IServiceProvider
*sp
)
112 static HRESULT
Number_hasOwnProperty(DispatchEx
*dispex
, LCID lcid
, WORD flags
, DISPPARAMS
*dp
,
113 VARIANT
*retv
, jsexcept_t
*ei
, IServiceProvider
*sp
)
119 static HRESULT
Number_propertyIsEnumerable(DispatchEx
*dispex
, LCID lcid
, WORD flags
, DISPPARAMS
*dp
,
120 VARIANT
*retv
, jsexcept_t
*ei
, IServiceProvider
*sp
)
126 static HRESULT
Number_isPrototypeOf(DispatchEx
*dispex
, LCID lcid
, WORD flags
, DISPPARAMS
*dp
,
127 VARIANT
*retv
, jsexcept_t
*ei
, IServiceProvider
*sp
)
133 static HRESULT
Number_value(DispatchEx
*dispex
, LCID lcid
, WORD flags
, DISPPARAMS
*dp
,
134 VARIANT
*retv
, jsexcept_t
*ei
, IServiceProvider
*sp
)
136 NumberInstance
*number
= (NumberInstance
*)dispex
;
139 case DISPATCH_PROPERTYGET
:
144 FIXME("flags %x\n", flags
);
151 static const builtin_prop_t Number_props
[] = {
152 {hasOwnPropertyW
, Number_hasOwnProperty
, PROPF_METHOD
},
153 {isPrototypeOfW
, Number_isPrototypeOf
, PROPF_METHOD
},
154 {propertyIsEnumerableW
, Number_propertyIsEnumerable
, PROPF_METHOD
},
155 {toExponentialW
, Number_toExponential
, PROPF_METHOD
},
156 {toFixedW
, Number_toFixed
, PROPF_METHOD
},
157 {toLocaleStringW
, Number_toLocaleString
, PROPF_METHOD
},
158 {toPrecisionW
, Number_toPrecision
, PROPF_METHOD
},
159 {toStringW
, Number_toString
, PROPF_METHOD
},
160 {valueOfW
, Number_valueOf
, PROPF_METHOD
}
163 static const builtin_info_t Number_info
= {
165 {NULL
, Number_value
, 0},
166 sizeof(Number_props
)/sizeof(*Number_props
),
172 static HRESULT
NumberConstr_value(DispatchEx
*dispex
, LCID lcid
, WORD flags
, DISPPARAMS
*dp
,
173 VARIANT
*retv
, jsexcept_t
*ei
, IServiceProvider
*sp
)
190 hres
= to_number(dispex
->ctx
, get_arg(dp
, 0), ei
, &num
);
198 case DISPATCH_CONSTRUCT
: {
201 switch(arg_cnt(dp
)) {
207 hres
= to_number(dispex
->ctx
, get_arg(dp
, 0), ei
, &num
);
212 FIXME("unimplemented args\n");
216 hres
= create_number(dispex
->ctx
, &num
, &obj
);
220 V_VT(retv
) = VT_DISPATCH
;
221 V_DISPATCH(retv
) = (IDispatch
*)_IDispatchEx_(obj
);
225 FIXME("unimplemented flags %x\n", flags
);
232 static HRESULT
alloc_number(script_ctx_t
*ctx
, BOOL use_constr
, NumberInstance
**ret
)
234 NumberInstance
*number
= heap_alloc_zero(sizeof(NumberInstance
));
238 hres
= init_dispex_from_constr(&number
->dispex
, ctx
, &Number_info
, ctx
->number_constr
);
240 hres
= init_dispex(&number
->dispex
, ctx
, &Number_info
, NULL
);
248 HRESULT
create_number_constr(script_ctx_t
*ctx
, DispatchEx
**ret
)
250 NumberInstance
*number
;
253 hres
= alloc_number(ctx
, FALSE
, &number
);
257 hres
= create_builtin_function(ctx
, NumberConstr_value
, PROPF_CONSTR
, &number
->dispex
, ret
);
259 jsdisp_release(&number
->dispex
);
263 HRESULT
create_number(script_ctx_t
*ctx
, VARIANT
*num
, DispatchEx
**ret
)
265 NumberInstance
*number
;
268 hres
= alloc_number(ctx
, TRUE
, &number
);
274 *ret
= &number
->dispex
;