Commit 5d412056 authored by Piotr Caban's avatar Piotr Caban Committed by Alexandre Julliard

jscript: Inherit some RegExp functions from Object.

parent 79f45c53
...@@ -774,7 +774,7 @@ static HRESULT init_constructors(script_ctx_t *ctx, DispatchEx *object_prototype ...@@ -774,7 +774,7 @@ static HRESULT init_constructors(script_ctx_t *ctx, DispatchEx *object_prototype
if(FAILED(hres)) if(FAILED(hres))
return hres; return hres;
hres = create_regexp_constr(ctx, &ctx->regexp_constr); hres = create_regexp_constr(ctx, object_prototype, &ctx->regexp_constr);
if(FAILED(hres)) if(FAILED(hres))
return hres; return hres;
......
...@@ -231,7 +231,7 @@ HRESULT create_date_constr(script_ctx_t*,DispatchEx**); ...@@ -231,7 +231,7 @@ HRESULT create_date_constr(script_ctx_t*,DispatchEx**);
HRESULT init_error_constr(script_ctx_t*); HRESULT init_error_constr(script_ctx_t*);
HRESULT create_number_constr(script_ctx_t*,DispatchEx**); HRESULT create_number_constr(script_ctx_t*,DispatchEx**);
HRESULT create_object_constr(script_ctx_t*,DispatchEx*,DispatchEx**); HRESULT create_object_constr(script_ctx_t*,DispatchEx*,DispatchEx**);
HRESULT create_regexp_constr(script_ctx_t*,DispatchEx**); HRESULT create_regexp_constr(script_ctx_t*,DispatchEx*,DispatchEx**);
HRESULT create_string_constr(script_ctx_t*,DispatchEx*,DispatchEx**); HRESULT create_string_constr(script_ctx_t*,DispatchEx*,DispatchEx**);
typedef struct { typedef struct {
......
...@@ -90,11 +90,6 @@ static const WCHAR ignoreCaseW[] = {'i','g','n','o','r','e','C','a','s','e',0}; ...@@ -90,11 +90,6 @@ static const WCHAR ignoreCaseW[] = {'i','g','n','o','r','e','C','a','s','e',0};
static const WCHAR multilineW[] = {'m','u','l','t','i','l','i','n','e',0}; static const WCHAR multilineW[] = {'m','u','l','t','i','l','i','n','e',0};
static const WCHAR lastIndexW[] = {'l','a','s','t','I','n','d','e','x',0}; static const WCHAR lastIndexW[] = {'l','a','s','t','I','n','d','e','x',0};
static const WCHAR toStringW[] = {'t','o','S','t','r','i','n','g',0}; static const WCHAR toStringW[] = {'t','o','S','t','r','i','n','g',0};
static const WCHAR toLocaleStringW[] = {'t','o','L','o','c','a','l','e','S','t','r','i','n','g',0};
static const WCHAR hasOwnPropertyW[] = {'h','a','s','O','w','n','P','r','o','p','e','r','t','y',0};
static const WCHAR propertyIsEnumerableW[] =
{'p','r','o','p','e','r','t','y','I','s','E','n','u','m','e','r','a','b','l','e',0};
static const WCHAR isPrototypeOfW[] = {'i','s','P','r','o','t','o','t','y','p','e','O','f',0};
static const WCHAR execW[] = {'e','x','e','c',0}; static const WCHAR execW[] = {'e','x','e','c',0};
static const WCHAR testW[] = {'t','e','s','t',0}; static const WCHAR testW[] = {'t','e','s','t',0};
...@@ -3471,34 +3466,6 @@ static HRESULT RegExp_toString(DispatchEx *dispex, LCID lcid, WORD flags, DISPPA ...@@ -3471,34 +3466,6 @@ static HRESULT RegExp_toString(DispatchEx *dispex, LCID lcid, WORD flags, DISPPA
return E_NOTIMPL; return E_NOTIMPL;
} }
static HRESULT RegExp_toLocaleString(DispatchEx *dispex, LCID lcid, WORD flags, DISPPARAMS *dp,
VARIANT *retv, jsexcept_t *ei, IServiceProvider *sp)
{
FIXME("\n");
return E_NOTIMPL;
}
static HRESULT RegExp_hasOwnProperty(DispatchEx *dispex, LCID lcid, WORD flags, DISPPARAMS *dp,
VARIANT *retv, jsexcept_t *ei, IServiceProvider *sp)
{
FIXME("\n");
return E_NOTIMPL;
}
static HRESULT RegExp_propertyIsEnumerable(DispatchEx *dispex, LCID lcid, WORD flags, DISPPARAMS *dp,
VARIANT *retv, jsexcept_t *ei, IServiceProvider *sp)
{
FIXME("\n");
return E_NOTIMPL;
}
static HRESULT RegExp_isPrototypeOf(DispatchEx *dispex, LCID lcid, WORD flags, DISPPARAMS *dp,
VARIANT *retv, jsexcept_t *ei, IServiceProvider *sp)
{
FIXME("\n");
return E_NOTIMPL;
}
static HRESULT RegExp_exec(DispatchEx *dispex, LCID lcid, WORD flags, DISPPARAMS *dp, static HRESULT RegExp_exec(DispatchEx *dispex, LCID lcid, WORD flags, DISPPARAMS *dp,
VARIANT *retv, jsexcept_t *ei, IServiceProvider *sp) VARIANT *retv, jsexcept_t *ei, IServiceProvider *sp)
{ {
...@@ -3542,15 +3509,11 @@ static void RegExp_destructor(DispatchEx *dispex) ...@@ -3542,15 +3509,11 @@ static void RegExp_destructor(DispatchEx *dispex)
static const builtin_prop_t RegExp_props[] = { static const builtin_prop_t RegExp_props[] = {
{execW, RegExp_exec, PROPF_METHOD}, {execW, RegExp_exec, PROPF_METHOD},
{globalW, RegExp_global, 0}, {globalW, RegExp_global, 0},
{hasOwnPropertyW, RegExp_hasOwnProperty, PROPF_METHOD},
{ignoreCaseW, RegExp_ignoreCase, 0}, {ignoreCaseW, RegExp_ignoreCase, 0},
{isPrototypeOfW, RegExp_isPrototypeOf, PROPF_METHOD},
{lastIndexW, RegExp_lastIndex, 0}, {lastIndexW, RegExp_lastIndex, 0},
{multilineW, RegExp_multiline, 0}, {multilineW, RegExp_multiline, 0},
{propertyIsEnumerableW, RegExp_propertyIsEnumerable, PROPF_METHOD},
{sourceW, RegExp_source, 0}, {sourceW, RegExp_source, 0},
{testW, RegExp_test, PROPF_METHOD}, {testW, RegExp_test, PROPF_METHOD},
{toLocaleStringW, RegExp_toLocaleString, PROPF_METHOD},
{toStringW, RegExp_toString, PROPF_METHOD} {toStringW, RegExp_toString, PROPF_METHOD}
}; };
...@@ -3563,7 +3526,7 @@ static const builtin_info_t RegExp_info = { ...@@ -3563,7 +3526,7 @@ static const builtin_info_t RegExp_info = {
NULL NULL
}; };
static HRESULT alloc_regexp(script_ctx_t *ctx, BOOL use_constr, RegExpInstance **ret) static HRESULT alloc_regexp(script_ctx_t *ctx, DispatchEx *object_prototype, RegExpInstance **ret)
{ {
RegExpInstance *regexp; RegExpInstance *regexp;
HRESULT hres; HRESULT hres;
...@@ -3572,10 +3535,10 @@ static HRESULT alloc_regexp(script_ctx_t *ctx, BOOL use_constr, RegExpInstance * ...@@ -3572,10 +3535,10 @@ static HRESULT alloc_regexp(script_ctx_t *ctx, BOOL use_constr, RegExpInstance *
if(!regexp) if(!regexp)
return E_OUTOFMEMORY; return E_OUTOFMEMORY;
if(use_constr) if(object_prototype)
hres = init_dispex_from_constr(&regexp->dispex, ctx, &RegExp_info, ctx->regexp_constr); hres = init_dispex(&regexp->dispex, ctx, &RegExp_info, object_prototype);
else else
hres = init_dispex(&regexp->dispex, ctx, &RegExp_info, NULL); hres = init_dispex_from_constr(&regexp->dispex, ctx, &RegExp_info, ctx->regexp_constr);
if(FAILED(hres)) { if(FAILED(hres)) {
heap_free(regexp); heap_free(regexp);
...@@ -3593,7 +3556,7 @@ static HRESULT create_regexp(script_ctx_t *ctx, const WCHAR *exp, int len, DWORD ...@@ -3593,7 +3556,7 @@ static HRESULT create_regexp(script_ctx_t *ctx, const WCHAR *exp, int len, DWORD
TRACE("%s %x\n", debugstr_w(exp), flags); TRACE("%s %x\n", debugstr_w(exp), flags);
hres = alloc_regexp(ctx, TRUE, &regexp); hres = alloc_regexp(ctx, NULL, &regexp);
if(FAILED(hres)) if(FAILED(hres))
return hres; return hres;
...@@ -3694,12 +3657,12 @@ static HRESULT RegExpConstr_value(DispatchEx *dispex, LCID lcid, WORD flags, DIS ...@@ -3694,12 +3657,12 @@ static HRESULT RegExpConstr_value(DispatchEx *dispex, LCID lcid, WORD flags, DIS
return S_OK; return S_OK;
} }
HRESULT create_regexp_constr(script_ctx_t *ctx, DispatchEx **ret) HRESULT create_regexp_constr(script_ctx_t *ctx, DispatchEx *object_prototype, DispatchEx **ret)
{ {
RegExpInstance *regexp; RegExpInstance *regexp;
HRESULT hres; HRESULT hres;
hres = alloc_regexp(ctx, FALSE, &regexp); hres = alloc_regexp(ctx, object_prototype, &regexp);
if(FAILED(hres)) if(FAILED(hres))
return hres; return hres;
......
...@@ -1374,10 +1374,11 @@ function testObjectInherit(obj, ts, tls, vo) { ...@@ -1374,10 +1374,11 @@ function testObjectInherit(obj, ts, tls, vo) {
ok(obj.valueOf != Object.prototype.valueOf, ok(obj.valueOf != Object.prototype.valueOf,
"obj.valueOf == Object.prototype.valueOf"); "obj.valueOf == Object.prototype.valueOf");
ok(obj.test === "test", "obj.test = " + obj.test); ok(obj._test === "test", "obj.test = " + obj._test);
} }
Object.prototype.test = "test"; Object.prototype._test = "test";
testObjectInherit(new String("test"), false, true, false); testObjectInherit(new String("test"), false, true, false);
testObjectInherit(/test/g, false, true, true);
reportSuccess(); reportSuccess();
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment