push d1f5df181c120dbe494f7c89b454752c2e0dcc04
[wine/hacks.git] / dlls / jscript / jscript.c
blobd53ac2f6a379701ca5d115c9ebd0a496b5d30aaa
1 /*
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
19 #include "jscript.h"
20 #include "engine.h"
21 #include "objsafe.h"
23 #include "wine/debug.h"
25 WINE_DEFAULT_DEBUG_CHANNEL(jscript);
27 #ifdef _WIN64
29 #define CTXARG_T DWORDLONG
30 #define IActiveScriptParseVtbl IActiveScriptParse64Vtbl
32 #else
34 #define CTXARG_T DWORD
35 #define IActiveScriptParseVtbl IActiveScriptParse32Vtbl
37 #endif
39 typedef struct {
40 const IActiveScriptVtbl *lpIActiveScriptVtbl;
41 const IActiveScriptParseVtbl *lpIActiveScriptParseVtbl;
42 const IActiveScriptParseProcedure2Vtbl *lpIActiveScriptParseProcedure2Vtbl;
43 const IActiveScriptPropertyVtbl *lpIActiveScriptPropertyVtbl;
44 const IObjectSafetyVtbl *lpIObjectSafetyVtbl;
46 LONG ref;
48 DWORD safeopt;
49 script_ctx_t *ctx;
50 LONG thread_id;
51 LCID lcid;
53 IActiveScriptSite *site;
55 parser_ctx_t *queue_head;
56 parser_ctx_t *queue_tail;
57 } JScript;
59 #define ACTSCRIPT(x) ((IActiveScript*) &(x)->lpIActiveScriptVtbl)
60 #define ASPARSE(x) (&(x)->lpIActiveScriptParseVtbl)
61 #define ASPARSEPROC(x) (&(x)->lpIActiveScriptParseProcedure2Vtbl)
62 #define ACTSCPPROP(x) (&(x)->lpIActiveScriptPropertyVtbl)
63 #define OBJSAFETY(x) (&(x)->lpIObjectSafetyVtbl)
65 void script_release(script_ctx_t *ctx)
67 if(--ctx->ref)
68 return;
70 jsheap_free(&ctx->tmp_heap);
71 heap_free(ctx);
74 static void change_state(JScript *This, SCRIPTSTATE state)
76 if(This->ctx->state == state)
77 return;
79 This->ctx->state = state;
80 IActiveScriptSite_OnStateChange(This->site, state);
83 static inline BOOL is_started(script_ctx_t *ctx)
85 return ctx->state == SCRIPTSTATE_STARTED
86 || ctx->state == SCRIPTSTATE_CONNECTED
87 || ctx->state == SCRIPTSTATE_DISCONNECTED;
90 static HRESULT exec_global_code(JScript *This, parser_ctx_t *parser_ctx)
92 exec_ctx_t *exec_ctx;
93 jsexcept_t jsexcept;
94 VARIANT var;
95 HRESULT hres;
97 hres = create_exec_ctx((IDispatch*)_IDispatchEx_(This->ctx->script_disp), This->ctx->script_disp, NULL, &exec_ctx);
98 if(FAILED(hres))
99 return hres;
101 IActiveScriptSite_OnEnterScript(This->site);
103 memset(&jsexcept, 0, sizeof(jsexcept));
104 hres = exec_source(exec_ctx, parser_ctx, parser_ctx->source, &jsexcept, &var);
105 VariantClear(&jsexcept.var);
106 exec_release(exec_ctx);
107 if(SUCCEEDED(hres))
108 VariantClear(&var);
110 IActiveScriptSite_OnLeaveScript(This->site);
112 return hres;
115 static void clear_script_queue(JScript *This)
117 parser_ctx_t *iter, *iter2;
119 if(!This->queue_head)
120 return;
122 iter = This->queue_head;
123 while(iter) {
124 iter2 = iter->next;
125 iter->next = NULL;
126 parser_release(iter);
127 iter = iter2;
130 This->queue_head = This->queue_tail = NULL;
133 static void exec_queued_code(JScript *This)
135 parser_ctx_t *iter;
137 for(iter = This->queue_head; iter; iter = iter->next)
138 exec_global_code(This, iter);
140 clear_script_queue(This);
143 static HRESULT set_ctx_site(JScript *This)
145 HRESULT hres;
147 This->ctx->lcid = This->lcid;
149 if(!This->ctx->script_disp) {
150 hres = create_dispex(This->ctx, NULL, NULL, &This->ctx->script_disp);
151 if(FAILED(hres))
152 return hres;
155 hres = init_global(This->ctx);
156 if(FAILED(hres))
157 return hres;
159 IActiveScriptSite_AddRef(This->site);
160 This->ctx->site = This->site;
162 change_state(This, SCRIPTSTATE_INITIALIZED);
163 return S_OK;
166 #define ACTSCRIPT_THIS(iface) DEFINE_THIS(JScript, IActiveScript, iface)
168 static HRESULT WINAPI JScript_QueryInterface(IActiveScript *iface, REFIID riid, void **ppv)
170 JScript *This = ACTSCRIPT_THIS(iface);
172 *ppv = NULL;
174 if(IsEqualGUID(riid, &IID_IUnknown)) {
175 TRACE("(%p)->(IID_IUnknown %p)\n", This, ppv);
176 *ppv = ACTSCRIPT(This);
177 }else if(IsEqualGUID(riid, &IID_IActiveScript)) {
178 TRACE("(%p)->(IID_IActiveScript %p)\n", This, ppv);
179 *ppv = ACTSCRIPT(This);
180 }else if(IsEqualGUID(riid, &IID_IActiveScriptParse)) {
181 TRACE("(%p)->(IID_IActiveScriptParse %p)\n", This, ppv);
182 *ppv = ASPARSE(This);
183 }else if(IsEqualGUID(riid, &IID_IActiveScriptParseProcedure)) {
184 TRACE("(%p)->(IID_IActiveScriptParseProcedure %p)\n", This, ppv);
185 *ppv = ASPARSEPROC(This);
186 }else if(IsEqualGUID(riid, &IID_IActiveScriptParseProcedure2)) {
187 TRACE("(%p)->(IID_IActiveScriptParseProcedure2 %p)\n", This, ppv);
188 *ppv = ASPARSEPROC(This);
189 }else if(IsEqualGUID(riid, &IID_IActiveScriptProperty)) {
190 TRACE("(%p)->(IID_IActiveScriptProperty %p)\n", This, ppv);
191 *ppv = ACTSCPPROP(This);
192 }else if(IsEqualGUID(riid, &IID_IObjectSafety)) {
193 TRACE("(%p)->(IID_IObjectSafety %p)\n", This, ppv);
194 *ppv = OBJSAFETY(This);
197 if(*ppv) {
198 IUnknown_AddRef((IUnknown*)*ppv);
199 return S_OK;
202 FIXME("(%p)->(%s %p)\n", This, debugstr_guid(riid), ppv);
203 return E_NOINTERFACE;
206 static ULONG WINAPI JScript_AddRef(IActiveScript *iface)
208 JScript *This = ACTSCRIPT_THIS(iface);
209 LONG ref = InterlockedIncrement(&This->ref);
211 TRACE("(%p) ref=%d\n", This, ref);
213 return ref;
216 static ULONG WINAPI JScript_Release(IActiveScript *iface)
218 JScript *This = ACTSCRIPT_THIS(iface);
219 LONG ref = InterlockedDecrement(&This->ref);
221 TRACE("(%p) ref=%d\n", iface, ref);
223 if(!ref) {
224 if(This->ctx && This->ctx->state != SCRIPTSTATE_CLOSED)
225 IActiveScript_Close(ACTSCRIPT(This));
226 if(This->ctx)
227 script_release(This->ctx);
228 heap_free(This);
229 unlock_module();
232 return ref;
235 static HRESULT WINAPI JScript_SetScriptSite(IActiveScript *iface,
236 IActiveScriptSite *pass)
238 JScript *This = ACTSCRIPT_THIS(iface);
239 LCID lcid;
240 HRESULT hres;
242 TRACE("(%p)->(%p)\n", This, pass);
244 if(!pass)
245 return E_POINTER;
247 if(This->site)
248 return E_UNEXPECTED;
250 if(InterlockedCompareExchange(&This->thread_id, GetCurrentThreadId(), 0))
251 return E_UNEXPECTED;
253 This->site = pass;
254 IActiveScriptSite_AddRef(This->site);
256 hres = IActiveScriptSite_GetLCID(This->site, &lcid);
257 if(hres == S_OK)
258 This->lcid = lcid;
260 return This->ctx ? set_ctx_site(This) : S_OK;
263 static HRESULT WINAPI JScript_GetScriptSite(IActiveScript *iface, REFIID riid,
264 void **ppvObject)
266 JScript *This = ACTSCRIPT_THIS(iface);
267 FIXME("(%p)->()\n", This);
268 return E_NOTIMPL;
271 static HRESULT WINAPI JScript_SetScriptState(IActiveScript *iface, SCRIPTSTATE ss)
273 JScript *This = ACTSCRIPT_THIS(iface);
275 TRACE("(%p)->(%d)\n", This, ss);
277 if(!This->ctx || GetCurrentThreadId() != This->thread_id)
278 return E_UNEXPECTED;
280 switch(ss) {
281 case SCRIPTSTATE_STARTED:
282 case SCRIPTSTATE_CONNECTED: /* FIXME */
283 if(This->ctx->state == SCRIPTSTATE_CLOSED)
284 return E_UNEXPECTED;
286 exec_queued_code(This);
287 break;
288 default:
289 FIXME("unimplemented state %d\n", ss);
290 return E_NOTIMPL;
293 change_state(This, ss);
294 return S_OK;
297 static HRESULT WINAPI JScript_GetScriptState(IActiveScript *iface, SCRIPTSTATE *pssState)
299 JScript *This = ACTSCRIPT_THIS(iface);
301 TRACE("(%p)->(%p)\n", This, pssState);
303 if(!pssState)
304 return E_POINTER;
306 if(!This->thread_id) {
307 *pssState = SCRIPTSTATE_UNINITIALIZED;
308 return S_OK;
311 if(This->thread_id != GetCurrentThreadId())
312 return E_UNEXPECTED;
314 *pssState = This->ctx ? This->ctx->state : SCRIPTSTATE_UNINITIALIZED;
315 return S_OK;
318 static HRESULT WINAPI JScript_Close(IActiveScript *iface)
320 JScript *This = ACTSCRIPT_THIS(iface);
322 TRACE("(%p)->()\n", This);
324 if(This->thread_id != GetCurrentThreadId())
325 return E_UNEXPECTED;
327 if(This->ctx) {
328 if(This->ctx->state == SCRIPTSTATE_CONNECTED)
329 change_state(This, SCRIPTSTATE_DISCONNECTED);
331 clear_script_queue(This);
333 if(This->ctx->state == SCRIPTSTATE_DISCONNECTED)
334 change_state(This, SCRIPTSTATE_INITIALIZED);
336 if(This->ctx->named_items) {
337 named_item_t *iter, *iter2;
339 iter = This->ctx->named_items;
340 while(iter) {
341 iter2 = iter->next;
343 if(iter->disp)
344 IDispatch_Release(iter->disp);
345 heap_free(iter->name);
346 heap_free(iter);
347 iter = iter2;
350 This->ctx->named_items = NULL;
353 if(This->ctx->site) {
354 IActiveScriptSite_Release(This->ctx->site);
355 This->ctx->site = NULL;
358 if (This->site)
359 change_state(This, SCRIPTSTATE_CLOSED);
361 if(This->ctx->script_disp) {
362 IDispatchEx_Release(_IDispatchEx_(This->ctx->script_disp));
363 This->ctx->script_disp = NULL;
366 if(This->ctx->global) {
367 IDispatchEx_Release(_IDispatchEx_(This->ctx->global));
368 This->ctx->global = NULL;
372 if(This->site) {
373 IActiveScriptSite_Release(This->site);
374 This->site = NULL;
377 return S_OK;
380 static HRESULT WINAPI JScript_AddNamedItem(IActiveScript *iface,
381 LPCOLESTR pstrName, DWORD dwFlags)
383 JScript *This = ACTSCRIPT_THIS(iface);
384 named_item_t *item;
385 IDispatch *disp = NULL;
386 HRESULT hres;
388 TRACE("(%p)->(%s %x)\n", This, debugstr_w(pstrName), dwFlags);
390 if(This->thread_id != GetCurrentThreadId() || !This->ctx || This->ctx->state == SCRIPTSTATE_CLOSED)
391 return E_UNEXPECTED;
393 if(dwFlags & SCRIPTITEM_GLOBALMEMBERS) {
394 IUnknown *unk;
396 hres = IActiveScriptSite_GetItemInfo(This->site, pstrName, SCRIPTINFO_IUNKNOWN, &unk, NULL);
397 if(FAILED(hres)) {
398 WARN("GetItemInfo failed: %08x\n", hres);
399 return hres;
402 hres = IUnknown_QueryInterface(unk, &IID_IDispatch, (void**)&disp);
403 IUnknown_Release(unk);
404 if(FAILED(hres)) {
405 WARN("object does not implement IDispatch\n");
406 return hres;
410 item = heap_alloc(sizeof(*item));
411 if(!item) {
412 if(disp)
413 IDispatch_Release(disp);
414 return E_OUTOFMEMORY;
417 item->disp = disp;
418 item->flags = dwFlags;
419 item->name = heap_strdupW(pstrName);
420 if(!item->name) {
421 IDispatch_Release(disp);
422 heap_free(item);
423 return E_OUTOFMEMORY;
426 item->next = This->ctx->named_items;
427 This->ctx->named_items = item;
429 return S_OK;
432 static HRESULT WINAPI JScript_AddTypeLib(IActiveScript *iface, REFGUID rguidTypeLib,
433 DWORD dwMajor, DWORD dwMinor, DWORD dwFlags)
435 JScript *This = ACTSCRIPT_THIS(iface);
436 FIXME("(%p)->()\n", This);
437 return E_NOTIMPL;
440 static HRESULT WINAPI JScript_GetScriptDispatch(IActiveScript *iface, LPCOLESTR pstrItemName,
441 IDispatch **ppdisp)
443 JScript *This = ACTSCRIPT_THIS(iface);
445 TRACE("(%p)->(%p)\n", This, ppdisp);
447 if(!ppdisp)
448 return E_POINTER;
450 if(This->thread_id != GetCurrentThreadId() || !This->ctx->script_disp) {
451 *ppdisp = NULL;
452 return E_UNEXPECTED;
455 *ppdisp = (IDispatch*)_IDispatchEx_(This->ctx->script_disp);
456 IDispatch_AddRef(*ppdisp);
457 return S_OK;
460 static HRESULT WINAPI JScript_GetCurrentScriptThreadID(IActiveScript *iface,
461 SCRIPTTHREADID *pstridThread)
463 JScript *This = ACTSCRIPT_THIS(iface);
464 FIXME("(%p)->()\n", This);
465 return E_NOTIMPL;
468 static HRESULT WINAPI JScript_GetScriptThreadID(IActiveScript *iface,
469 DWORD dwWin32ThreadId, SCRIPTTHREADID *pstidThread)
471 JScript *This = ACTSCRIPT_THIS(iface);
472 FIXME("(%p)->()\n", This);
473 return E_NOTIMPL;
476 static HRESULT WINAPI JScript_GetScriptThreadState(IActiveScript *iface,
477 SCRIPTTHREADID stidThread, SCRIPTTHREADSTATE *pstsState)
479 JScript *This = ACTSCRIPT_THIS(iface);
480 FIXME("(%p)->()\n", This);
481 return E_NOTIMPL;
484 static HRESULT WINAPI JScript_InterruptScriptThread(IActiveScript *iface,
485 SCRIPTTHREADID stidThread, const EXCEPINFO *pexcepinfo, DWORD dwFlags)
487 JScript *This = ACTSCRIPT_THIS(iface);
488 FIXME("(%p)->()\n", This);
489 return E_NOTIMPL;
492 static HRESULT WINAPI JScript_Clone(IActiveScript *iface, IActiveScript **ppscript)
494 JScript *This = ACTSCRIPT_THIS(iface);
495 FIXME("(%p)->()\n", This);
496 return E_NOTIMPL;
499 #undef ACTSCRIPT_THIS
501 static const IActiveScriptVtbl JScriptVtbl = {
502 JScript_QueryInterface,
503 JScript_AddRef,
504 JScript_Release,
505 JScript_SetScriptSite,
506 JScript_GetScriptSite,
507 JScript_SetScriptState,
508 JScript_GetScriptState,
509 JScript_Close,
510 JScript_AddNamedItem,
511 JScript_AddTypeLib,
512 JScript_GetScriptDispatch,
513 JScript_GetCurrentScriptThreadID,
514 JScript_GetScriptThreadID,
515 JScript_GetScriptThreadState,
516 JScript_InterruptScriptThread,
517 JScript_Clone
520 #define ASPARSE_THIS(iface) DEFINE_THIS(JScript, IActiveScriptParse, iface)
522 static HRESULT WINAPI JScriptParse_QueryInterface(IActiveScriptParse *iface, REFIID riid, void **ppv)
524 JScript *This = ASPARSE_THIS(iface);
525 return IActiveScript_QueryInterface(ACTSCRIPT(This), riid, ppv);
528 static ULONG WINAPI JScriptParse_AddRef(IActiveScriptParse *iface)
530 JScript *This = ASPARSE_THIS(iface);
531 return IActiveScript_AddRef(ACTSCRIPT(This));
534 static ULONG WINAPI JScriptParse_Release(IActiveScriptParse *iface)
536 JScript *This = ASPARSE_THIS(iface);
537 return IActiveScript_Release(ACTSCRIPT(This));
540 static HRESULT WINAPI JScriptParse_InitNew(IActiveScriptParse *iface)
542 JScript *This = ASPARSE_THIS(iface);
543 script_ctx_t *ctx;
545 TRACE("(%p)\n", This);
547 if(This->ctx)
548 return E_UNEXPECTED;
550 ctx = heap_alloc_zero(sizeof(script_ctx_t));
551 if(!ctx)
552 return E_OUTOFMEMORY;
554 ctx->ref = 1;
555 ctx->state = SCRIPTSTATE_UNINITIALIZED;
556 jsheap_init(&ctx->tmp_heap);
558 ctx = InterlockedCompareExchangePointer((void**)&This->ctx, ctx, NULL);
559 if(ctx) {
560 script_release(ctx);
561 return E_UNEXPECTED;
564 return This->site ? set_ctx_site(This) : S_OK;
567 static HRESULT WINAPI JScriptParse_AddScriptlet(IActiveScriptParse *iface,
568 LPCOLESTR pstrDefaultName, LPCOLESTR pstrCode, LPCOLESTR pstrItemName,
569 LPCOLESTR pstrSubItemName, LPCOLESTR pstrEventName, LPCOLESTR pstrDelimiter,
570 CTXARG_T dwSourceContextCookie, ULONG ulStartingLineNumber, DWORD dwFlags,
571 BSTR *pbstrName, EXCEPINFO *pexcepinfo)
573 JScript *This = ASPARSE_THIS(iface);
574 FIXME("(%p)->(%s %s %s %s %s %s %s %u %x %p %p)\n", This, debugstr_w(pstrDefaultName),
575 debugstr_w(pstrCode), debugstr_w(pstrItemName), debugstr_w(pstrSubItemName),
576 debugstr_w(pstrEventName), debugstr_w(pstrDelimiter), wine_dbgstr_longlong(dwSourceContextCookie),
577 ulStartingLineNumber, dwFlags, pbstrName, pexcepinfo);
578 return E_NOTIMPL;
581 static HRESULT WINAPI JScriptParse_ParseScriptText(IActiveScriptParse *iface,
582 LPCOLESTR pstrCode, LPCOLESTR pstrItemName, IUnknown *punkContext,
583 LPCOLESTR pstrDelimiter, CTXARG_T dwSourceContextCookie, ULONG ulStartingLine,
584 DWORD dwFlags, VARIANT *pvarResult, EXCEPINFO *pexcepinfo)
586 JScript *This = ASPARSE_THIS(iface);
587 parser_ctx_t *parser_ctx;
588 HRESULT hres;
590 TRACE("(%p)->(%s %s %p %s %s %u %x %p %p)\n", This, debugstr_w(pstrCode),
591 debugstr_w(pstrItemName), punkContext, debugstr_w(pstrDelimiter),
592 wine_dbgstr_longlong(dwSourceContextCookie), ulStartingLine, dwFlags, pvarResult, pexcepinfo);
594 if(This->thread_id != GetCurrentThreadId() || This->ctx->state == SCRIPTSTATE_CLOSED)
595 return E_UNEXPECTED;
597 hres = script_parse(This->ctx, pstrCode, &parser_ctx);
598 if(FAILED(hres))
599 return hres;
601 if(!is_started(This->ctx)) {
602 if(This->queue_tail)
603 This->queue_tail = This->queue_tail->next = parser_ctx;
604 else
605 This->queue_head = This->queue_tail = parser_ctx;
606 return S_OK;
609 hres = exec_global_code(This, parser_ctx);
610 parser_release(parser_ctx);
612 return hres;
615 #undef ASPARSE_THIS
617 static const IActiveScriptParseVtbl JScriptParseVtbl = {
618 JScriptParse_QueryInterface,
619 JScriptParse_AddRef,
620 JScriptParse_Release,
621 JScriptParse_InitNew,
622 JScriptParse_AddScriptlet,
623 JScriptParse_ParseScriptText
626 #define ASPARSEPROC_THIS(iface) DEFINE_THIS(JScript, IActiveScriptParseProcedure2, iface)
628 static HRESULT WINAPI JScriptParseProcedure_QueryInterface(IActiveScriptParseProcedure2 *iface, REFIID riid, void **ppv)
630 JScript *This = ASPARSEPROC_THIS(iface);
631 return IActiveScript_QueryInterface(ACTSCRIPT(This), riid, ppv);
634 static ULONG WINAPI JScriptParseProcedure_AddRef(IActiveScriptParseProcedure2 *iface)
636 JScript *This = ASPARSEPROC_THIS(iface);
637 return IActiveScript_AddRef(ACTSCRIPT(This));
640 static ULONG WINAPI JScriptParseProcedure_Release(IActiveScriptParseProcedure2 *iface)
642 JScript *This = ASPARSEPROC_THIS(iface);
643 return IActiveScript_Release(ACTSCRIPT(This));
646 static HRESULT WINAPI JScriptParseProcedure_ParseProcedureText(IActiveScriptParseProcedure2 *iface,
647 LPCOLESTR pstrCode, LPCOLESTR pstrFormalParams, LPCOLESTR pstrProcedureName,
648 LPCOLESTR pstrItemName, IUnknown *punkContext, LPCOLESTR pstrDelimiter,
649 DWORD dwSourceContextCookie, ULONG ulStartingLineNumber, DWORD dwFlags, IDispatch **ppdisp)
651 JScript *This = ASPARSEPROC_THIS(iface);
652 parser_ctx_t *parser_ctx;
653 DispatchEx *dispex;
654 HRESULT hres;
656 TRACE("(%p)->(%s %s %s %s %p %s %x %u %x %p)\n", This, debugstr_w(pstrCode), debugstr_w(pstrFormalParams),
657 debugstr_w(pstrProcedureName), debugstr_w(pstrItemName), punkContext, debugstr_w(pstrDelimiter),
658 dwSourceContextCookie, ulStartingLineNumber, dwFlags, ppdisp);
660 if(This->thread_id != GetCurrentThreadId() || This->ctx->state == SCRIPTSTATE_CLOSED)
661 return E_UNEXPECTED;
663 hres = script_parse(This->ctx, pstrCode, &parser_ctx);
664 if(FAILED(hres)) {
665 WARN("Parse failed %08x\n", hres);
666 return hres;
669 hres = create_source_function(parser_ctx, NULL, parser_ctx->source, NULL, NULL, 0, &dispex);
670 parser_release(parser_ctx);
671 if(FAILED(hres))
672 return hres;
674 *ppdisp = (IDispatch*)_IDispatchEx_(dispex);
675 return S_OK;
678 #undef ASPARSEPROC_THIS
680 static const IActiveScriptParseProcedure2Vtbl JScriptParseProcedureVtbl = {
681 JScriptParseProcedure_QueryInterface,
682 JScriptParseProcedure_AddRef,
683 JScriptParseProcedure_Release,
684 JScriptParseProcedure_ParseProcedureText,
687 #define ACTSCPPROP_THIS(iface) DEFINE_THIS(JScript, IActiveScriptProperty, iface)
689 static HRESULT WINAPI JScriptProperty_QueryInterface(IActiveScriptProperty *iface, REFIID riid, void **ppv)
691 JScript *This = ACTSCPPROP_THIS(iface);
692 return IActiveScript_QueryInterface(ACTSCRIPT(This), riid, ppv);
695 static ULONG WINAPI JScriptProperty_AddRef(IActiveScriptProperty *iface)
697 JScript *This = ACTSCPPROP_THIS(iface);
698 return IActiveScript_AddRef(ACTSCRIPT(This));
701 static ULONG WINAPI JScriptProperty_Release(IActiveScriptProperty *iface)
703 JScript *This = ACTSCPPROP_THIS(iface);
704 return IActiveScript_Release(ACTSCRIPT(This));
707 static HRESULT WINAPI JScriptProperty_GetProperty(IActiveScriptProperty *iface, DWORD dwProperty,
708 VARIANT *pvarIndex, VARIANT *pvarValue)
710 JScript *This = ACTSCPPROP_THIS(iface);
711 FIXME("(%p)->(%x %p %p)\n", This, dwProperty, pvarIndex, pvarValue);
712 return E_NOTIMPL;
715 static HRESULT WINAPI JScriptProperty_SetProperty(IActiveScriptProperty *iface, DWORD dwProperty,
716 VARIANT *pvarIndex, VARIANT *pvarValue)
718 JScript *This = ACTSCPPROP_THIS(iface);
719 FIXME("(%p)->(%x %p %p)\n", This, dwProperty, pvarIndex, pvarValue);
720 return E_NOTIMPL;
723 #undef ACTSCPPROP_THIS
725 static const IActiveScriptPropertyVtbl JScriptPropertyVtbl = {
726 JScriptProperty_QueryInterface,
727 JScriptProperty_AddRef,
728 JScriptProperty_Release,
729 JScriptProperty_GetProperty,
730 JScriptProperty_SetProperty
733 #define OBJSAFETY_THIS(iface) DEFINE_THIS(JScript, IObjectSafety, iface)
735 static HRESULT WINAPI JScriptSafety_QueryInterface(IObjectSafety *iface, REFIID riid, void **ppv)
737 JScript *This = OBJSAFETY_THIS(iface);
738 return IActiveScript_QueryInterface(ACTSCRIPT(This), riid, ppv);
741 static ULONG WINAPI JScriptSafety_AddRef(IObjectSafety *iface)
743 JScript *This = OBJSAFETY_THIS(iface);
744 return IActiveScript_AddRef(ACTSCRIPT(This));
747 static ULONG WINAPI JScriptSafety_Release(IObjectSafety *iface)
749 JScript *This = OBJSAFETY_THIS(iface);
750 return IActiveScript_Release(ACTSCRIPT(This));
753 #define SUPPORTED_OPTIONS (INTERFACESAFE_FOR_UNTRUSTED_DATA|INTERFACE_USES_DISPEX|INTERFACE_USES_SECURITY_MANAGER)
755 static HRESULT WINAPI JScriptSafety_GetInterfaceSafetyOptions(IObjectSafety *iface, REFIID riid,
756 DWORD *pdwSupportedOptions, DWORD *pdwEnabledOptions)
758 JScript *This = OBJSAFETY_THIS(iface);
760 TRACE("(%p)->(%s %p %p)\n", This, debugstr_guid(riid), pdwSupportedOptions, pdwEnabledOptions);
762 if(!pdwSupportedOptions || !pdwEnabledOptions)
763 return E_POINTER;
765 *pdwSupportedOptions = SUPPORTED_OPTIONS;
766 *pdwEnabledOptions = This->safeopt;
768 return S_OK;
771 static HRESULT WINAPI JScriptSafety_SetInterfaceSafetyOptions(IObjectSafety *iface, REFIID riid,
772 DWORD dwOptionSetMask, DWORD dwEnabledOptions)
774 JScript *This = OBJSAFETY_THIS(iface);
776 TRACE("(%p)->(%s %x %x)\n", This, debugstr_guid(riid), dwOptionSetMask, dwEnabledOptions);
778 if(dwOptionSetMask & ~SUPPORTED_OPTIONS)
779 return E_FAIL;
781 This->safeopt = dwEnabledOptions & dwEnabledOptions;
782 return S_OK;
785 #undef OBJSAFETY_THIS
787 static const IObjectSafetyVtbl JScriptSafetyVtbl = {
788 JScriptSafety_QueryInterface,
789 JScriptSafety_AddRef,
790 JScriptSafety_Release,
791 JScriptSafety_GetInterfaceSafetyOptions,
792 JScriptSafety_SetInterfaceSafetyOptions
795 HRESULT WINAPI JScriptFactory_CreateInstance(IClassFactory *iface, IUnknown *pUnkOuter,
796 REFIID riid, void **ppv)
798 JScript *ret;
799 HRESULT hres;
801 TRACE("(%p %s %p)\n", pUnkOuter, debugstr_guid(riid), ppv);
803 lock_module();
805 ret = heap_alloc_zero(sizeof(*ret));
806 if(!ret)
807 return E_OUTOFMEMORY;
809 ret->lpIActiveScriptVtbl = &JScriptVtbl;
810 ret->lpIActiveScriptParseVtbl = &JScriptParseVtbl;
811 ret->lpIActiveScriptParseProcedure2Vtbl = &JScriptParseProcedureVtbl;
812 ret->lpIActiveScriptPropertyVtbl = &JScriptPropertyVtbl;
813 ret->lpIObjectSafetyVtbl = &JScriptSafetyVtbl;
814 ret->ref = 1;
815 ret->safeopt = INTERFACE_USES_DISPEX;
817 hres = IActiveScript_QueryInterface(ACTSCRIPT(ret), riid, ppv);
818 IActiveScript_Release(ACTSCRIPT(ret));
819 return hres;