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
)
110 if(!is_class(dispex
, JSCLASS_NUMBER
)) {
111 FIXME("throw TypeError\n");
116 NumberInstance
*number
= (NumberInstance
*)dispex
;
122 static HRESULT
Number_hasOwnProperty(DispatchEx
*dispex
, LCID lcid
, WORD flags
, DISPPARAMS
*dp
,
123 VARIANT
*retv
, jsexcept_t
*ei
, IServiceProvider
*sp
)
129 static HRESULT
Number_propertyIsEnumerable(DispatchEx
*dispex
, LCID lcid
, WORD flags
, DISPPARAMS
*dp
,
130 VARIANT
*retv
, jsexcept_t
*ei
, IServiceProvider
*sp
)
136 static HRESULT
Number_isPrototypeOf(DispatchEx
*dispex
, LCID lcid
, WORD flags
, DISPPARAMS
*dp
,
137 VARIANT
*retv
, jsexcept_t
*ei
, IServiceProvider
*sp
)
143 static HRESULT
Number_value(DispatchEx
*dispex
, LCID lcid
, WORD flags
, DISPPARAMS
*dp
,
144 VARIANT
*retv
, jsexcept_t
*ei
, IServiceProvider
*sp
)
146 NumberInstance
*number
= (NumberInstance
*)dispex
;
149 case DISPATCH_PROPERTYGET
:
154 FIXME("flags %x\n", flags
);
161 static const builtin_prop_t Number_props
[] = {
162 {hasOwnPropertyW
, Number_hasOwnProperty
, PROPF_METHOD
},
163 {isPrototypeOfW
, Number_isPrototypeOf
, PROPF_METHOD
},
164 {propertyIsEnumerableW
, Number_propertyIsEnumerable
, PROPF_METHOD
},
165 {toExponentialW
, Number_toExponential
, PROPF_METHOD
},
166 {toFixedW
, Number_toFixed
, PROPF_METHOD
},
167 {toLocaleStringW
, Number_toLocaleString
, PROPF_METHOD
},
168 {toPrecisionW
, Number_toPrecision
, PROPF_METHOD
},
169 {toStringW
, Number_toString
, PROPF_METHOD
},
170 {valueOfW
, Number_valueOf
, PROPF_METHOD
}
173 static const builtin_info_t Number_info
= {
175 {NULL
, Number_value
, 0},
176 sizeof(Number_props
)/sizeof(*Number_props
),
182 static HRESULT
NumberConstr_value(DispatchEx
*dispex
, LCID lcid
, WORD flags
, DISPPARAMS
*dp
,
183 VARIANT
*retv
, jsexcept_t
*ei
, IServiceProvider
*sp
)
200 hres
= to_number(dispex
->ctx
, get_arg(dp
, 0), ei
, &num
);
208 case DISPATCH_CONSTRUCT
: {
212 hres
= to_number(dispex
->ctx
, get_arg(dp
, 0), ei
, &num
);
220 hres
= create_number(dispex
->ctx
, &num
, &obj
);
224 V_VT(retv
) = VT_DISPATCH
;
225 V_DISPATCH(retv
) = (IDispatch
*)_IDispatchEx_(obj
);
229 FIXME("unimplemented flags %x\n", flags
);
236 static HRESULT
alloc_number(script_ctx_t
*ctx
, BOOL use_constr
, NumberInstance
**ret
)
238 NumberInstance
*number
;
241 number
= heap_alloc_zero(sizeof(NumberInstance
));
243 return E_OUTOFMEMORY
;
246 hres
= init_dispex_from_constr(&number
->dispex
, ctx
, &Number_info
, ctx
->number_constr
);
248 hres
= init_dispex(&number
->dispex
, ctx
, &Number_info
, NULL
);
256 HRESULT
create_number_constr(script_ctx_t
*ctx
, DispatchEx
**ret
)
258 NumberInstance
*number
;
261 hres
= alloc_number(ctx
, FALSE
, &number
);
265 V_VT(&number
->num
) = VT_I4
;
266 hres
= create_builtin_function(ctx
, NumberConstr_value
, PROPF_CONSTR
, &number
->dispex
, ret
);
268 jsdisp_release(&number
->dispex
);
272 HRESULT
create_number(script_ctx_t
*ctx
, VARIANT
*num
, DispatchEx
**ret
)
274 NumberInstance
*number
;
277 hres
= alloc_number(ctx
, TRUE
, &number
);
283 *ret
= &number
->dispex
;