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);
25 #define JSREG_FOLD 0x01 /* fold uppercase to lowercase */
26 #define JSREG_GLOB 0x02 /* global exec, creates array of matches */
27 #define JSREG_MULTILINE 0x04 /* treat ^ and $ as begin and end of line */
28 #define JSREG_STICKY 0x08 /* only match starting at lastIndex */
34 static const WCHAR sourceW[] = {'s','o','u','r','c','e',0};
35 static const WCHAR globalW[] = {'g','l','o','b','a','l',0};
36 static const WCHAR ignoreCaseW[] = {'i','g','n','o','r','e','C','a','s','e',0};
37 static const WCHAR multilineW[] = {'m','u','l','t','i','l','i','n','e',0};
38 static const WCHAR lastIndexW[] = {'l','a','s','t','I','n','d','e','x',0};
39 static const WCHAR toStringW[] = {'t','o','S','t','r','i','n','g',0};
40 static const WCHAR toLocaleStringW[] = {'t','o','L','o','c','a','l','e','S','t','r','i','n','g',0};
41 static const WCHAR hasOwnPropertyW[] = {'h','a','s','O','w','n','P','r','o','p','e','r','t','y',0};
42 static const WCHAR propertyIsEnumerableW[] =
43 {'p','r','o','p','e','r','t','y','I','s','E','n','u','m','e','r','a','b','l','e',0};
44 static const WCHAR isPrototypeOfW[] = {'i','s','P','r','o','t','o','t','y','p','e','O','f',0};
45 static const WCHAR execW[] = {'e','x','e','c',0};
47 static HRESULT RegExp_source(DispatchEx *dispex, LCID lcid, WORD flags, DISPPARAMS *dp,
48 VARIANT *retv, jsexcept_t *ei, IServiceProvider *sp)
54 static HRESULT RegExp_global(DispatchEx *dispex, LCID lcid, WORD flags, DISPPARAMS *dp,
55 VARIANT *retv, jsexcept_t *ei, IServiceProvider *sp)
61 static HRESULT RegExp_ignoreCase(DispatchEx *dispex, LCID lcid, WORD flags, DISPPARAMS *dp,
62 VARIANT *retv, jsexcept_t *ei, IServiceProvider *sp)
68 static HRESULT RegExp_multiline(DispatchEx *dispex, LCID lcid, WORD flags, DISPPARAMS *dp,
69 VARIANT *retv, jsexcept_t *ei, IServiceProvider *sp)
75 static HRESULT RegExp_lastIndex(DispatchEx *dispex, LCID lcid, WORD flags, DISPPARAMS *dp,
76 VARIANT *retv, jsexcept_t *ei, IServiceProvider *sp)
82 static HRESULT RegExp_toString(DispatchEx *dispex, LCID lcid, WORD flags, DISPPARAMS *dp,
83 VARIANT *retv, jsexcept_t *ei, IServiceProvider *sp)
89 static HRESULT RegExp_toLocaleString(DispatchEx *dispex, LCID lcid, WORD flags, DISPPARAMS *dp,
90 VARIANT *retv, jsexcept_t *ei, IServiceProvider *sp)
96 static HRESULT RegExp_hasOwnProperty(DispatchEx *dispex, LCID lcid, WORD flags, DISPPARAMS *dp,
97 VARIANT *retv, jsexcept_t *ei, IServiceProvider *sp)
103 static HRESULT RegExp_propertyIsEnumerable(DispatchEx *dispex, LCID lcid, WORD flags, DISPPARAMS *dp,
104 VARIANT *retv, jsexcept_t *ei, IServiceProvider *sp)
110 static HRESULT RegExp_isPrototypeOf(DispatchEx *dispex, LCID lcid, WORD flags, DISPPARAMS *dp,
111 VARIANT *retv, jsexcept_t *ei, IServiceProvider *sp)
117 static HRESULT RegExp_exec(DispatchEx *dispex, LCID lcid, WORD flags, DISPPARAMS *dp,
118 VARIANT *retv, jsexcept_t *ei, IServiceProvider *sp)
124 static HRESULT RegExp_value(DispatchEx *dispex, LCID lcid, WORD flags, DISPPARAMS *dp,
125 VARIANT *retv, jsexcept_t *ei, IServiceProvider *sp)
131 static void RegExp_destructor(DispatchEx *dispex)
136 static const builtin_prop_t RegExp_props[] = {
137 {execW, RegExp_exec, PROPF_METHOD},
138 {globalW, RegExp_global, 0},
139 {hasOwnPropertyW, RegExp_hasOwnProperty, PROPF_METHOD},
140 {ignoreCaseW, RegExp_ignoreCase, 0},
141 {isPrototypeOfW, RegExp_isPrototypeOf, PROPF_METHOD},
142 {lastIndexW, RegExp_lastIndex, 0},
143 {multilineW, RegExp_multiline, 0},
144 {propertyIsEnumerableW, RegExp_propertyIsEnumerable, PROPF_METHOD},
145 {sourceW, RegExp_source, 0},
146 {toLocaleStringW, RegExp_toLocaleString, PROPF_METHOD},
147 {toStringW, RegExp_toString, PROPF_METHOD}
150 static const builtin_info_t RegExp_info = {
152 {NULL, RegExp_value, 0},
153 sizeof(RegExp_props)/sizeof(*RegExp_props),
159 static HRESULT alloc_regexp(script_ctx_t *ctx, BOOL use_constr, RegExpInstance **ret)
161 RegExpInstance *regexp;
164 regexp = heap_alloc_zero(sizeof(RegExpInstance));
166 return E_OUTOFMEMORY;
169 hres = init_dispex_from_constr(®exp->dispex, ctx, &RegExp_info, ctx->regexp_constr);
171 hres = init_dispex(®exp->dispex, ctx, &RegExp_info, NULL);
182 static HRESULT create_regexp(script_ctx_t *ctx, const WCHAR *exp, int len, DWORD flags, DispatchEx **ret)
188 static HRESULT RegExpConstr_value(DispatchEx *dispex, LCID lcid, WORD flags, DISPPARAMS *dp,
189 VARIANT *retv, jsexcept_t *ei, IServiceProvider *sp)
195 HRESULT create_regexp_constr(script_ctx_t *ctx, DispatchEx **ret)
197 RegExpInstance *regexp;
200 hres = alloc_regexp(ctx, FALSE, ®exp);
204 hres = create_builtin_function(ctx, RegExpConstr_value, PROPF_CONSTR, ®exp->dispex, ret);
206 jsdisp_release(®exp->dispex);
210 HRESULT create_regexp_str(script_ctx_t *ctx, const WCHAR *exp, DWORD exp_len, const WCHAR *opt,
211 DWORD opt_len, DispatchEx **ret)
217 for (p = opt; p < opt+opt_len; p++) {
226 flags |= JSREG_MULTILINE;
229 flags |= JSREG_STICKY;
232 WARN("wrong flag %c\n", *p);
238 return create_regexp(ctx, exp, exp_len, flags, ret);