d3d9: COM cleanup for the IDirect3DVertexDeclaration9 interface.
[wine] / dlls / mshtml / htmlwindow.c
1 /*
2  * Copyright 2006-2010 Jacek Caban for CodeWeavers
3  *
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.
8  *
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.
13  *
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
17  */
18
19 #include <stdarg.h>
20
21 #define COBJMACROS
22
23 #include "windef.h"
24 #include "winbase.h"
25 #include "winuser.h"
26 #include "ole2.h"
27 #include "mshtmdid.h"
28 #include "shlguid.h"
29 #include "shobjidl.h"
30
31 #define NO_SHLWAPI_REG
32 #include "shlwapi.h"
33
34 #include "wine/debug.h"
35
36 #include "mshtml_private.h"
37 #include "htmlevent.h"
38 #include "binding.h"
39 #include "resource.h"
40
41 WINE_DEFAULT_DEBUG_CHANNEL(mshtml);
42
43 static struct list window_list = LIST_INIT(window_list);
44
45 static void window_set_docnode(HTMLWindow *window, HTMLDocumentNode *doc_node)
46 {
47     if(window->doc) {
48         if(window->doc_obj && window == window->doc_obj->basedoc.window)
49             window->doc->basedoc.cp_container.forward_container = NULL;
50         detach_events(window->doc);
51         abort_document_bindings(window->doc);
52         window->doc->basedoc.window = NULL;
53         htmldoc_release(&window->doc->basedoc);
54     }
55     window->doc = doc_node;
56     if(doc_node)
57         htmldoc_addref(&doc_node->basedoc);
58
59     if(window->doc_obj && window->doc_obj->basedoc.window == window) {
60         if(window->doc_obj->basedoc.doc_node)
61             htmldoc_release(&window->doc_obj->basedoc.doc_node->basedoc);
62         window->doc_obj->basedoc.doc_node = doc_node;
63         if(doc_node)
64             htmldoc_addref(&doc_node->basedoc);
65     }
66
67     if(doc_node && window->doc_obj && window->doc_obj->usermode == EDITMODE) {
68         nsAString mode_str;
69         nsresult nsres;
70
71         static const PRUnichar onW[] = {'o','n',0};
72
73         nsAString_Init(&mode_str, onW);
74         nsres = nsIDOMHTMLDocument_SetDesignMode(doc_node->nsdoc, &mode_str);
75         nsAString_Finish(&mode_str);
76         if(NS_FAILED(nsres))
77             ERR("SetDesignMode failed: %08x\n", nsres);
78     }
79 }
80
81 static void release_children(HTMLWindow *This)
82 {
83     HTMLWindow *child;
84
85     while(!list_empty(&This->children)) {
86         child = LIST_ENTRY(list_tail(&This->children), HTMLWindow, sibling_entry);
87
88         list_remove(&child->sibling_entry);
89         child->parent = NULL;
90         IHTMLWindow2_Release(&child->IHTMLWindow2_iface);
91     }
92 }
93
94 static HRESULT get_location(HTMLWindow *This, HTMLLocation **ret)
95 {
96     if(This->location) {
97         IHTMLLocation_AddRef(&This->location->IHTMLLocation_iface);
98     }else {
99         HRESULT hres;
100
101         hres = HTMLLocation_Create(This, &This->location);
102         if(FAILED(hres))
103             return hres;
104     }
105
106     *ret = This->location;
107     return S_OK;
108 }
109
110 void get_top_window(HTMLWindow *window, HTMLWindow **ret)
111 {
112     HTMLWindow *iter;
113
114     for(iter = window; iter->parent; iter = iter->parent);
115     *ret = iter;
116 }
117
118 static inline HRESULT set_window_event(HTMLWindow *window, eventid_t eid, VARIANT *var)
119 {
120     if(!window->doc) {
121         FIXME("No document\n");
122         return E_FAIL;
123     }
124
125     return set_event_handler(&window->doc->body_event_target, NULL, window->doc, eid, var);
126 }
127
128 static inline HRESULT get_window_event(HTMLWindow *window, eventid_t eid, VARIANT *var)
129 {
130     if(!window->doc) {
131         FIXME("No document\n");
132         return E_FAIL;
133     }
134
135     return get_event_handler(&window->doc->body_event_target, eid, var);
136 }
137
138 static inline HTMLWindow *impl_from_IHTMLWindow2(IHTMLWindow2 *iface)
139 {
140     return CONTAINING_RECORD(iface, HTMLWindow, IHTMLWindow2_iface);
141 }
142
143 static HRESULT WINAPI HTMLWindow2_QueryInterface(IHTMLWindow2 *iface, REFIID riid, void **ppv)
144 {
145     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
146
147     *ppv = NULL;
148
149     if(IsEqualGUID(&IID_IUnknown, riid)) {
150         TRACE("(%p)->(IID_IUnknown %p)\n", This, ppv);
151         *ppv = &This->IHTMLWindow2_iface;
152     }else if(IsEqualGUID(&IID_IDispatch, riid)) {
153         TRACE("(%p)->(IID_IDispatch %p)\n", This, ppv);
154         *ppv = &This->IHTMLWindow2_iface;
155     }else if(IsEqualGUID(&IID_IDispatchEx, riid)) {
156         TRACE("(%p)->(IID_IDispatchEx %p)\n", This, ppv);
157         *ppv = &This->IDispatchEx_iface;
158     }else if(IsEqualGUID(&IID_IHTMLFramesCollection2, riid)) {
159         TRACE("(%p)->(IID_IHTMLFramesCollection2 %p)\n", This, ppv);
160         *ppv = &This->IHTMLWindow2_iface;
161     }else if(IsEqualGUID(&IID_IHTMLWindow2, riid)) {
162         TRACE("(%p)->(IID_IHTMLWindow2 %p)\n", This, ppv);
163         *ppv = &This->IHTMLWindow2_iface;
164     }else if(IsEqualGUID(&IID_IHTMLWindow3, riid)) {
165         TRACE("(%p)->(IID_IHTMLWindow3 %p)\n", This, ppv);
166         *ppv = &This->IHTMLWindow3_iface;
167     }else if(IsEqualGUID(&IID_IHTMLWindow4, riid)) {
168         TRACE("(%p)->(IID_IHTMLWindow4 %p)\n", This, ppv);
169         *ppv = &This->IHTMLWindow4_iface;
170     }else if(IsEqualGUID(&IID_IHTMLWindow5, riid)) {
171         TRACE("(%p)->(IID_IHTMLWindow5 %p)\n", This, ppv);
172         *ppv = &This->IHTMLWindow5_iface;
173     }else if(IsEqualGUID(&IID_IHTMLWindow6, riid)) {
174         TRACE("(%p)->(IID_IHTMLWindow6 %p)\n", This, ppv);
175         *ppv = &This->IHTMLWindow6_iface;
176     }else if(IsEqualGUID(&IID_IHTMLPrivateWindow, riid)) {
177         TRACE("(%p)->(IID_IHTMLPrivateWindow %p)\n", This, ppv);
178         *ppv = &This->IHTMLPrivateWindow_iface;
179     }else if(IsEqualGUID(&IID_IServiceProvider, riid)) {
180         TRACE("(%p)->(IID_IServiceProvider %p)\n", This, ppv);
181         *ppv = &This->IServiceProvider_iface;
182     }else if(IsEqualGUID(&IID_ITravelLogClient, riid)) {
183         TRACE("(%p)->(IID_ITravelLogClient %p)\n", This, ppv);
184         *ppv = &This->ITravelLogClient_iface;
185     }else if(dispex_query_interface(&This->dispex, riid, ppv)) {
186         return *ppv ? S_OK : E_NOINTERFACE;
187     }
188
189     if(*ppv) {
190         IUnknown_AddRef((IUnknown*)*ppv);
191         return S_OK;
192     }
193
194     WARN("(%p)->(%s %p)\n", This, debugstr_guid(riid), ppv);
195     return E_NOINTERFACE;
196 }
197
198 static ULONG WINAPI HTMLWindow2_AddRef(IHTMLWindow2 *iface)
199 {
200     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
201     LONG ref = InterlockedIncrement(&This->ref);
202
203     TRACE("(%p) ref=%d\n", This, ref);
204
205     return ref;
206 }
207
208 static ULONG WINAPI HTMLWindow2_Release(IHTMLWindow2 *iface)
209 {
210     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
211     LONG ref = InterlockedDecrement(&This->ref);
212
213     TRACE("(%p) ref=%d\n", This, ref);
214
215     if(!ref) {
216         DWORD i;
217
218         remove_target_tasks(This->task_magic);
219         set_window_bscallback(This, NULL);
220         set_current_mon(This, NULL);
221         window_set_docnode(This, NULL);
222         release_children(This);
223
224         if(This->secmgr)
225             IInternetSecurityManager_Release(This->secmgr);
226
227         if(This->frame_element)
228             This->frame_element->content_window = NULL;
229
230         if(This->option_factory) {
231             This->option_factory->window = NULL;
232             IHTMLOptionElementFactory_Release(&This->option_factory->IHTMLOptionElementFactory_iface);
233         }
234
235         if(This->image_factory) {
236             This->image_factory->window = NULL;
237             IHTMLImageElementFactory_Release(&This->image_factory->IHTMLImageElementFactory_iface);
238         }
239
240         if(This->location) {
241             This->location->window = NULL;
242             IHTMLLocation_Release(&This->location->IHTMLLocation_iface);
243         }
244
245         if(This->screen)
246             IHTMLScreen_Release(This->screen);
247
248         for(i=0; i < This->global_prop_cnt; i++)
249             heap_free(This->global_props[i].name);
250
251         This->window_ref->window = NULL;
252         windowref_release(This->window_ref);
253
254         heap_free(This->global_props);
255         release_script_hosts(This);
256
257         if(This->nswindow)
258             nsIDOMWindow_Release(This->nswindow);
259
260         list_remove(&This->entry);
261         release_dispex(&This->dispex);
262         heap_free(This);
263     }
264
265     return ref;
266 }
267
268 static HRESULT WINAPI HTMLWindow2_GetTypeInfoCount(IHTMLWindow2 *iface, UINT *pctinfo)
269 {
270     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
271
272     return IDispatchEx_GetTypeInfoCount(&This->IDispatchEx_iface, pctinfo);
273 }
274
275 static HRESULT WINAPI HTMLWindow2_GetTypeInfo(IHTMLWindow2 *iface, UINT iTInfo,
276                                               LCID lcid, ITypeInfo **ppTInfo)
277 {
278     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
279
280     return IDispatchEx_GetTypeInfo(&This->IDispatchEx_iface, iTInfo, lcid, ppTInfo);
281 }
282
283 static HRESULT WINAPI HTMLWindow2_GetIDsOfNames(IHTMLWindow2 *iface, REFIID riid,
284                                                 LPOLESTR *rgszNames, UINT cNames,
285                                                 LCID lcid, DISPID *rgDispId)
286 {
287     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
288
289     return IDispatchEx_GetIDsOfNames(&This->IDispatchEx_iface, riid, rgszNames, cNames, lcid,
290             rgDispId);
291 }
292
293 static HRESULT WINAPI HTMLWindow2_Invoke(IHTMLWindow2 *iface, DISPID dispIdMember,
294                             REFIID riid, LCID lcid, WORD wFlags, DISPPARAMS *pDispParams,
295                             VARIANT *pVarResult, EXCEPINFO *pExcepInfo, UINT *puArgErr)
296 {
297     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
298
299     return IDispatchEx_Invoke(&This->IDispatchEx_iface, dispIdMember, riid, lcid, wFlags,
300             pDispParams, pVarResult, pExcepInfo, puArgErr);
301 }
302
303 static HRESULT get_frame_by_index(nsIDOMWindowCollection *nsFrames, PRUint32 index, HTMLWindow **ret)
304 {
305     PRUint32 length;
306     nsIDOMWindow *nsWindow;
307     nsresult nsres;
308
309     nsres = nsIDOMWindowCollection_GetLength(nsFrames, &length);
310     if(NS_FAILED(nsres)) {
311         FIXME("nsIDOMWindowCollection_GetLength failed: 0x%08x\n", nsres);
312         return E_FAIL;
313     }
314
315     if(index >= length)
316         return DISP_E_MEMBERNOTFOUND;
317
318     nsres = nsIDOMWindowCollection_Item(nsFrames, index, &nsWindow);
319     if(NS_FAILED(nsres)) {
320         FIXME("nsIDOMWindowCollection_Item failed: 0x%08x\n", nsres);
321         return E_FAIL;
322     }
323
324     *ret = nswindow_to_window(nsWindow);
325
326     nsIDOMWindow_Release(nsWindow);
327
328     return S_OK;
329 }
330
331 static HRESULT WINAPI HTMLWindow2_item(IHTMLWindow2 *iface, VARIANT *pvarIndex, VARIANT *pvarResult)
332 {
333     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
334     nsIDOMWindowCollection *nsFrames;
335     HTMLWindow *window = NULL;
336     HRESULT hres = S_OK;
337     nsresult nsres;
338
339     TRACE("(%p)->(%p %p)\n", This, pvarIndex, pvarResult);
340
341     nsres = nsIDOMWindow_GetFrames(This->nswindow, &nsFrames);
342     if(NS_FAILED(nsres)) {
343         FIXME("nsIDOMWindow_GetFrames failed: 0x%08x\n", nsres);
344         return E_FAIL;
345     }
346
347     switch(V_VT(pvarIndex)) {
348     case VT_I4: {
349         int index = V_I4(pvarIndex);
350         TRACE("Getting index %d\n", index);
351         if(index < 0)
352             break;
353         hres = get_frame_by_index(nsFrames, index, &window);
354         break;
355     }
356     case VT_UINT: {
357         unsigned int index = V_UINT(pvarIndex);
358         TRACE("Getting index %u\n", index);
359         hres = get_frame_by_index(nsFrames, index, &window);
360         break;
361     }
362     case VT_BSTR: {
363         BSTR str = V_BSTR(pvarIndex);
364         PRUint32 length, i;
365
366         TRACE("Getting name %s\n", wine_dbgstr_w(str));
367
368         nsIDOMWindowCollection_GetLength(nsFrames, &length);
369
370         window = NULL;
371         for(i = 0; i < length && !window; ++i) {
372             HTMLWindow *cur_window;
373             nsIDOMWindow *nsWindow;
374             BSTR id;
375
376             nsres = nsIDOMWindowCollection_Item(nsFrames, i, &nsWindow);
377             if(NS_FAILED(nsres)) {
378                 FIXME("nsIDOMWindowCollection_Item failed: 0x%08x\n", nsres);
379                 hres = E_FAIL;
380                 break;
381             }
382
383             cur_window = nswindow_to_window(nsWindow);
384
385             nsIDOMWindow_Release(nsWindow);
386
387             hres = IHTMLElement_get_id(&cur_window->frame_element->element.IHTMLElement_iface, &id);
388             if(FAILED(hres)) {
389                 FIXME("IHTMLElement_get_id failed: 0x%08x\n", hres);
390                 break;
391             }
392
393             if(!strcmpW(id, str))
394                 window = cur_window;
395
396             SysFreeString(id);
397         }
398         break;
399     }
400     default:
401         hres = E_INVALIDARG;
402     }
403
404     nsIDOMWindowCollection_Release(nsFrames);
405     if(FAILED(hres))
406         return hres;
407     if(!window)
408         return DISP_E_MEMBERNOTFOUND;
409
410     IHTMLWindow2_AddRef(&window->IHTMLWindow2_iface);
411     V_VT(pvarResult) = VT_DISPATCH;
412     V_DISPATCH(pvarResult) = (IDispatch*)window;
413     return S_OK;
414 }
415
416 static HRESULT WINAPI HTMLWindow2_get_length(IHTMLWindow2 *iface, LONG *p)
417 {
418     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
419     nsIDOMWindowCollection *nscollection;
420     PRUint32 length;
421     nsresult nsres;
422
423     TRACE("(%p)->(%p)\n", This, p);
424
425     nsres = nsIDOMWindow_GetFrames(This->nswindow, &nscollection);
426     if(NS_FAILED(nsres)) {
427         ERR("GetFrames failed: %08x\n", nsres);
428         return E_FAIL;
429     }
430
431     nsres = nsIDOMWindowCollection_GetLength(nscollection, &length);
432     nsIDOMWindowCollection_Release(nscollection);
433     if(NS_FAILED(nsres)) {
434         ERR("GetLength failed: %08x\n", nsres);
435         return E_FAIL;
436     }
437
438     *p = length;
439     return S_OK;
440 }
441
442 static HRESULT WINAPI HTMLWindow2_get_frames(IHTMLWindow2 *iface, IHTMLFramesCollection2 **p)
443 {
444     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
445     FIXME("(%p)->(%p): semi-stub\n", This, p);
446
447     /* FIXME: Should return a separate Window object */
448     *p = (IHTMLFramesCollection2*)&This->IHTMLWindow2_iface;
449     HTMLWindow2_AddRef(iface);
450     return S_OK;
451 }
452
453 static HRESULT WINAPI HTMLWindow2_put_defaultStatus(IHTMLWindow2 *iface, BSTR v)
454 {
455     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
456     FIXME("(%p)->(%s)\n", This, debugstr_w(v));
457     return E_NOTIMPL;
458 }
459
460 static HRESULT WINAPI HTMLWindow2_get_defaultStatus(IHTMLWindow2 *iface, BSTR *p)
461 {
462     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
463     FIXME("(%p)->(%p)\n", This, p);
464     return E_NOTIMPL;
465 }
466
467 static HRESULT WINAPI HTMLWindow2_put_status(IHTMLWindow2 *iface, BSTR v)
468 {
469     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
470
471     WARN("(%p)->(%s)\n", This, debugstr_w(v));
472
473     /*
474      * FIXME: Since IE7, setting status is blocked, but still possible in certain circumstances.
475      * Ignoring the call should be enough for us.
476      */
477     return S_OK;
478 }
479
480 static HRESULT WINAPI HTMLWindow2_get_status(IHTMLWindow2 *iface, BSTR *p)
481 {
482     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
483
484     TRACE("(%p)->(%p)\n", This, p);
485
486     /* See put_status */
487     *p = NULL;
488     return S_OK;
489 }
490
491 static HRESULT WINAPI HTMLWindow2_setTimeout(IHTMLWindow2 *iface, BSTR expression,
492         LONG msec, VARIANT *language, LONG *timerID)
493 {
494     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
495     VARIANT expr_var;
496
497     TRACE("(%p)->(%s %d %p %p)\n", This, debugstr_w(expression), msec, language, timerID);
498
499     V_VT(&expr_var) = VT_BSTR;
500     V_BSTR(&expr_var) = expression;
501
502     return IHTMLWindow3_setTimeout(&This->IHTMLWindow3_iface, &expr_var, msec, language, timerID);
503 }
504
505 static HRESULT WINAPI HTMLWindow2_clearTimeout(IHTMLWindow2 *iface, LONG timerID)
506 {
507     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
508
509     TRACE("(%p)->(%d)\n", This, timerID);
510
511     return clear_task_timer(&This->doc->basedoc, FALSE, timerID);
512 }
513
514 #define MAX_MESSAGE_LEN 2000
515
516 static HRESULT WINAPI HTMLWindow2_alert(IHTMLWindow2 *iface, BSTR message)
517 {
518     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
519     WCHAR title[100], *msg = message;
520     DWORD len;
521
522     TRACE("(%p)->(%s)\n", This, debugstr_w(message));
523
524     if(!LoadStringW(get_shdoclc(), IDS_MESSAGE_BOX_TITLE, title,
525                     sizeof(title)/sizeof(WCHAR))) {
526         WARN("Could not load message box title: %d\n", GetLastError());
527         return S_OK;
528     }
529
530     len = SysStringLen(message);
531     if(len > MAX_MESSAGE_LEN) {
532         msg = heap_alloc((MAX_MESSAGE_LEN+1)*sizeof(WCHAR));
533         if(!msg)
534             return E_OUTOFMEMORY;
535         memcpy(msg, message, MAX_MESSAGE_LEN*sizeof(WCHAR));
536         msg[MAX_MESSAGE_LEN] = 0;
537     }
538
539     MessageBoxW(This->doc_obj->hwnd, msg, title, MB_ICONWARNING);
540     if(msg != message)
541         heap_free(msg);
542     return S_OK;
543 }
544
545 static HRESULT WINAPI HTMLWindow2_confirm(IHTMLWindow2 *iface, BSTR message,
546         VARIANT_BOOL *confirmed)
547 {
548     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
549     WCHAR wszTitle[100];
550
551     TRACE("(%p)->(%s %p)\n", This, debugstr_w(message), confirmed);
552
553     if(!confirmed) return E_INVALIDARG;
554
555     if(!LoadStringW(get_shdoclc(), IDS_MESSAGE_BOX_TITLE, wszTitle,
556                 sizeof(wszTitle)/sizeof(WCHAR))) {
557         WARN("Could not load message box title: %d\n", GetLastError());
558         *confirmed = VARIANT_TRUE;
559         return S_OK;
560     }
561
562     if(MessageBoxW(This->doc_obj->hwnd, message, wszTitle,
563                 MB_OKCANCEL|MB_ICONQUESTION)==IDOK)
564         *confirmed = VARIANT_TRUE;
565     else *confirmed = VARIANT_FALSE;
566
567     return S_OK;
568 }
569
570 typedef struct
571 {
572     BSTR message;
573     BSTR dststr;
574     VARIANT *textdata;
575 }prompt_arg;
576
577 static INT_PTR CALLBACK prompt_dlgproc(HWND hwnd, UINT msg,
578         WPARAM wparam, LPARAM lparam)
579 {
580     switch(msg)
581     {
582         case WM_INITDIALOG:
583         {
584             prompt_arg *arg = (prompt_arg*)lparam;
585             WCHAR wszTitle[100];
586
587             if(!LoadStringW(get_shdoclc(), IDS_MESSAGE_BOX_TITLE, wszTitle,
588                         sizeof(wszTitle)/sizeof(WCHAR))) {
589                 WARN("Could not load message box title: %d\n", GetLastError());
590                 EndDialog(hwnd, wparam);
591                 return FALSE;
592             }
593
594             SetWindowLongPtrW(hwnd, DWLP_USER, lparam);
595             SetWindowTextW(hwnd, wszTitle);
596             SetWindowTextW(GetDlgItem(hwnd, ID_PROMPT_PROMPT), arg->message);
597             SetWindowTextW(GetDlgItem(hwnd, ID_PROMPT_EDIT), arg->dststr);
598             return FALSE;
599         }
600         case WM_COMMAND:
601             switch(wparam)
602             {
603                 case MAKEWPARAM(IDCANCEL, BN_CLICKED):
604                     EndDialog(hwnd, wparam);
605                     return TRUE;
606                 case MAKEWPARAM(IDOK, BN_CLICKED):
607                 {
608                     prompt_arg *arg =
609                         (prompt_arg*)GetWindowLongPtrW(hwnd, DWLP_USER);
610                     HWND hwndPrompt = GetDlgItem(hwnd, ID_PROMPT_EDIT);
611                     INT len = GetWindowTextLengthW(hwndPrompt);
612
613                     if(!arg->textdata)
614                     {
615                         EndDialog(hwnd, wparam);
616                         return TRUE;
617                     }
618
619                     V_VT(arg->textdata) = VT_BSTR;
620                     if(!len && !arg->dststr)
621                         V_BSTR(arg->textdata) = NULL;
622                     else
623                     {
624                         V_BSTR(arg->textdata) = SysAllocStringLen(NULL, len);
625                         GetWindowTextW(hwndPrompt, V_BSTR(arg->textdata), len+1);
626                     }
627                     EndDialog(hwnd, wparam);
628                     return TRUE;
629                 }
630             }
631             return FALSE;
632         case WM_CLOSE:
633             EndDialog(hwnd, IDCANCEL);
634             return TRUE;
635         default:
636             return FALSE;
637     }
638 }
639
640 static HRESULT WINAPI HTMLWindow2_prompt(IHTMLWindow2 *iface, BSTR message,
641         BSTR dststr, VARIANT *textdata)
642 {
643     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
644     prompt_arg arg;
645
646     TRACE("(%p)->(%s %s %p)\n", This, debugstr_w(message), debugstr_w(dststr), textdata);
647
648     if(textdata) V_VT(textdata) = VT_NULL;
649
650     arg.message = message;
651     arg.dststr = dststr;
652     arg.textdata = textdata;
653
654     DialogBoxParamW(hInst, MAKEINTRESOURCEW(ID_PROMPT_DIALOG),
655             This->doc_obj->hwnd, prompt_dlgproc, (LPARAM)&arg);
656     return S_OK;
657 }
658
659 static HRESULT WINAPI HTMLWindow2_get_Image(IHTMLWindow2 *iface, IHTMLImageElementFactory **p)
660 {
661     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
662
663     TRACE("(%p)->(%p)\n", This, p);
664
665     if(!This->image_factory)
666         This->image_factory = HTMLImageElementFactory_Create(This);
667
668     *p = &This->image_factory->IHTMLImageElementFactory_iface;
669     IHTMLImageElementFactory_AddRef(*p);
670
671     return S_OK;
672 }
673
674 static HRESULT WINAPI HTMLWindow2_get_location(IHTMLWindow2 *iface, IHTMLLocation **p)
675 {
676     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
677     HTMLLocation *location;
678     HRESULT hres;
679
680     TRACE("(%p)->(%p)\n", This, p);
681
682     hres = get_location(This, &location);
683     if(FAILED(hres))
684         return hres;
685
686     *p = &location->IHTMLLocation_iface;
687     return S_OK;
688 }
689
690 static HRESULT WINAPI HTMLWindow2_get_history(IHTMLWindow2 *iface, IOmHistory **p)
691 {
692     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
693     FIXME("(%p)->(%p)\n", This, p);
694     return E_NOTIMPL;
695 }
696
697 static HRESULT WINAPI HTMLWindow2_close(IHTMLWindow2 *iface)
698 {
699     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
700     FIXME("(%p)->()\n", This);
701     return E_NOTIMPL;
702 }
703
704 static HRESULT WINAPI HTMLWindow2_put_opener(IHTMLWindow2 *iface, VARIANT v)
705 {
706     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
707     FIXME("(%p)->(%s)\n", This, debugstr_variant(&v));
708     return E_NOTIMPL;
709 }
710
711 static HRESULT WINAPI HTMLWindow2_get_opener(IHTMLWindow2 *iface, VARIANT *p)
712 {
713     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
714
715     FIXME("(%p)->(%p) returning empty\n", This, p);
716
717     V_VT(p) = VT_EMPTY;
718     return S_OK;
719 }
720
721 static HRESULT WINAPI HTMLWindow2_get_navigator(IHTMLWindow2 *iface, IOmNavigator **p)
722 {
723     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
724
725     TRACE("(%p)->(%p)\n", This, p);
726
727     *p = OmNavigator_Create();
728     return S_OK;
729 }
730
731 static HRESULT WINAPI HTMLWindow2_put_name(IHTMLWindow2 *iface, BSTR v)
732 {
733     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
734     nsAString name_str;
735     nsresult nsres;
736
737     TRACE("(%p)->(%s)\n", This, debugstr_w(v));
738
739     nsAString_InitDepend(&name_str, v);
740     nsres = nsIDOMWindow_SetName(This->nswindow, &name_str);
741     nsAString_Finish(&name_str);
742     if(NS_FAILED(nsres))
743         ERR("SetName failed: %08x\n", nsres);
744
745     return S_OK;
746 }
747
748 static HRESULT WINAPI HTMLWindow2_get_name(IHTMLWindow2 *iface, BSTR *p)
749 {
750     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
751     nsAString name_str;
752     nsresult nsres;
753     HRESULT hres;
754
755     TRACE("(%p)->(%p)\n", This, p);
756
757     nsAString_Init(&name_str, NULL);
758     nsres = nsIDOMWindow_GetName(This->nswindow, &name_str);
759     if(NS_SUCCEEDED(nsres)) {
760         const PRUnichar *name;
761
762         nsAString_GetData(&name_str, &name);
763         if(*name) {
764             *p = SysAllocString(name);
765             hres = *p ? S_OK : E_OUTOFMEMORY;
766         }else {
767             *p = NULL;
768             hres = S_OK;
769         }
770     }else {
771         ERR("GetName failed: %08x\n", nsres);
772         hres = E_FAIL;
773     }
774     nsAString_Finish(&name_str);
775
776     return hres;
777 }
778
779 static HRESULT WINAPI HTMLWindow2_get_parent(IHTMLWindow2 *iface, IHTMLWindow2 **p)
780 {
781     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
782
783     TRACE("(%p)->(%p)\n", This, p);
784
785     if(!This->parent)
786         return IHTMLWindow2_get_self(&This->IHTMLWindow2_iface, p);
787
788     *p = &This->parent->IHTMLWindow2_iface;
789     IHTMLWindow2_AddRef(*p);
790     return S_OK;
791 }
792
793 static HRESULT WINAPI HTMLWindow2_open(IHTMLWindow2 *iface, BSTR url, BSTR name,
794          BSTR features, VARIANT_BOOL replace, IHTMLWindow2 **pomWindowResult)
795 {
796     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
797     INewWindowManager *new_window_mgr;
798     IUri *uri;
799     HRESULT hres;
800
801     TRACE("(%p)->(%s %s %s %x %p)\n", This, debugstr_w(url), debugstr_w(name),
802           debugstr_w(features), replace, pomWindowResult);
803
804     if(!This->doc_obj)
805         return E_UNEXPECTED;
806
807     if(name && *name == '_') {
808         FIXME("Unsupported name %s\n", debugstr_w(name));
809         return E_NOTIMPL;
810     }
811
812     hres = do_query_service((IUnknown*)This->doc_obj->client, &SID_SNewWindowManager, &IID_INewWindowManager,
813             (void**)&new_window_mgr);
814     if(FAILED(hres)) {
815         FIXME("No INewWindowManager\n");
816         return E_NOTIMPL;
817     }
818
819     hres = INewWindowManager_EvaluateNewWindow(new_window_mgr, url, name, This->url,
820             features, !!replace, This->doc_obj->has_popup ? 0 : NWMF_FIRST, 0);
821     INewWindowManager_Release(new_window_mgr);
822     This->doc_obj->has_popup = TRUE;
823     if(FAILED(hres)) {
824         *pomWindowResult = NULL;
825         return S_OK;
826     }
827
828     hres = create_relative_uri(This, url, &uri);
829     if(FAILED(hres))
830         return hres;
831
832     hres = navigate_new_window(This, uri, name, pomWindowResult);
833     IUri_Release(uri);
834     return hres;
835 }
836
837 static HRESULT WINAPI HTMLWindow2_get_self(IHTMLWindow2 *iface, IHTMLWindow2 **p)
838 {
839     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
840
841     TRACE("(%p)->(%p)\n", This, p);
842
843     /* FIXME: We should return kind of proxy window here. */
844     IHTMLWindow2_AddRef(&This->IHTMLWindow2_iface);
845     *p = &This->IHTMLWindow2_iface;
846     return S_OK;
847 }
848
849 static HRESULT WINAPI HTMLWindow2_get_top(IHTMLWindow2 *iface, IHTMLWindow2 **p)
850 {
851     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
852     HTMLWindow *top;
853
854     TRACE("(%p)->(%p)\n", This, p);
855
856     get_top_window(This, &top);
857     *p = &top->IHTMLWindow2_iface;
858     IHTMLWindow2_AddRef(*p);
859
860     return S_OK;
861 }
862
863 static HRESULT WINAPI HTMLWindow2_get_window(IHTMLWindow2 *iface, IHTMLWindow2 **p)
864 {
865     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
866
867     TRACE("(%p)->(%p)\n", This, p);
868
869     /* FIXME: We should return kind of proxy window here. */
870     IHTMLWindow2_AddRef(&This->IHTMLWindow2_iface);
871     *p = &This->IHTMLWindow2_iface;
872     return S_OK;
873 }
874
875 static HRESULT WINAPI HTMLWindow2_navigate(IHTMLWindow2 *iface, BSTR url)
876 {
877     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
878     FIXME("(%p)->(%s)\n", This, debugstr_w(url));
879     return E_NOTIMPL;
880 }
881
882 static HRESULT WINAPI HTMLWindow2_put_onfocus(IHTMLWindow2 *iface, VARIANT v)
883 {
884     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
885     FIXME("(%p)->(%s)\n", This, debugstr_variant(&v));
886     return E_NOTIMPL;
887 }
888
889 static HRESULT WINAPI HTMLWindow2_get_onfocus(IHTMLWindow2 *iface, VARIANT *p)
890 {
891     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
892     FIXME("(%p)->(%p)\n", This, p);
893     return E_NOTIMPL;
894 }
895
896 static HRESULT WINAPI HTMLWindow2_put_onblur(IHTMLWindow2 *iface, VARIANT v)
897 {
898     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
899     FIXME("(%p)->(%s)\n", This, debugstr_variant(&v));
900     return E_NOTIMPL;
901 }
902
903 static HRESULT WINAPI HTMLWindow2_get_onblur(IHTMLWindow2 *iface, VARIANT *p)
904 {
905     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
906     FIXME("(%p)->(%p)\n", This, p);
907     return E_NOTIMPL;
908 }
909
910 static HRESULT WINAPI HTMLWindow2_put_onload(IHTMLWindow2 *iface, VARIANT v)
911 {
912     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
913
914     TRACE("(%p)->(%s)\n", This, debugstr_variant(&v));
915
916     return set_window_event(This, EVENTID_LOAD, &v);
917 }
918
919 static HRESULT WINAPI HTMLWindow2_get_onload(IHTMLWindow2 *iface, VARIANT *p)
920 {
921     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
922
923     TRACE("(%p)->(%p)\n", This, p);
924
925     return get_window_event(This, EVENTID_LOAD, p);
926 }
927
928 static HRESULT WINAPI HTMLWindow2_put_onbeforeunload(IHTMLWindow2 *iface, VARIANT v)
929 {
930     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
931
932     TRACE("(%p)->(%s)\n", This, debugstr_variant(&v));
933
934     return set_window_event(This, EVENTID_BEFOREUNLOAD, &v);
935 }
936
937 static HRESULT WINAPI HTMLWindow2_get_onbeforeunload(IHTMLWindow2 *iface, VARIANT *p)
938 {
939     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
940
941     TRACE("(%p)->(%p)\n", This, p);
942
943     return get_window_event(This, EVENTID_BEFOREUNLOAD, p);
944 }
945
946 static HRESULT WINAPI HTMLWindow2_put_onunload(IHTMLWindow2 *iface, VARIANT v)
947 {
948     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
949     FIXME("(%p)->(%s)\n", This, debugstr_variant(&v));
950     return E_NOTIMPL;
951 }
952
953 static HRESULT WINAPI HTMLWindow2_get_onunload(IHTMLWindow2 *iface, VARIANT *p)
954 {
955     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
956     FIXME("(%p)->(%p)\n", This, p);
957     return E_NOTIMPL;
958 }
959
960 static HRESULT WINAPI HTMLWindow2_put_onhelp(IHTMLWindow2 *iface, VARIANT v)
961 {
962     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
963     FIXME("(%p)->(%s)\n", This, debugstr_variant(&v));
964     return E_NOTIMPL;
965 }
966
967 static HRESULT WINAPI HTMLWindow2_get_onhelp(IHTMLWindow2 *iface, VARIANT *p)
968 {
969     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
970     FIXME("(%p)->(%p)\n", This, p);
971     return E_NOTIMPL;
972 }
973
974 static HRESULT WINAPI HTMLWindow2_put_onerror(IHTMLWindow2 *iface, VARIANT v)
975 {
976     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
977
978     FIXME("(%p)->(%s) semi-stub\n", This, debugstr_variant(&v));
979
980     return set_window_event(This, EVENTID_ERROR, &v);
981 }
982
983 static HRESULT WINAPI HTMLWindow2_get_onerror(IHTMLWindow2 *iface, VARIANT *p)
984 {
985     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
986
987     TRACE("(%p)->(%p)\n", This, p);
988
989     return get_window_event(This, EVENTID_ERROR, p);
990 }
991
992 static HRESULT WINAPI HTMLWindow2_put_onresize(IHTMLWindow2 *iface, VARIANT v)
993 {
994     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
995
996     TRACE("(%p)->(%s)\n", This, debugstr_variant(&v));
997
998     return set_window_event(This, EVENTID_RESIZE, &v);
999 }
1000
1001 static HRESULT WINAPI HTMLWindow2_get_onresize(IHTMLWindow2 *iface, VARIANT *p)
1002 {
1003     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
1004
1005     TRACE("(%p)->(%p)\n", This, p);
1006
1007     return get_window_event(This, EVENTID_RESIZE, p);
1008 }
1009
1010 static HRESULT WINAPI HTMLWindow2_put_onscroll(IHTMLWindow2 *iface, VARIANT v)
1011 {
1012     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
1013     FIXME("(%p)->(%s)\n", This, debugstr_variant(&v));
1014     return E_NOTIMPL;
1015 }
1016
1017 static HRESULT WINAPI HTMLWindow2_get_onscroll(IHTMLWindow2 *iface, VARIANT *p)
1018 {
1019     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
1020     FIXME("(%p)->(%p)\n", This, p);
1021     return E_NOTIMPL;
1022 }
1023
1024 static HRESULT WINAPI HTMLWindow2_get_document(IHTMLWindow2 *iface, IHTMLDocument2 **p)
1025 {
1026     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
1027
1028     TRACE("(%p)->(%p)\n", This, p);
1029
1030     if(This->doc) {
1031         /* FIXME: We should return a wrapper object here */
1032         *p = &This->doc->basedoc.IHTMLDocument2_iface;
1033         IHTMLDocument2_AddRef(*p);
1034     }else {
1035         *p = NULL;
1036     }
1037
1038     return S_OK;
1039 }
1040
1041 static HRESULT WINAPI HTMLWindow2_get_event(IHTMLWindow2 *iface, IHTMLEventObj **p)
1042 {
1043     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
1044
1045     TRACE("(%p)->(%p)\n", This, p);
1046
1047     if(This->event)
1048         IHTMLEventObj_AddRef(This->event);
1049     *p = This->event;
1050     return S_OK;
1051 }
1052
1053 static HRESULT WINAPI HTMLWindow2_get__newEnum(IHTMLWindow2 *iface, IUnknown **p)
1054 {
1055     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
1056     FIXME("(%p)->(%p)\n", This, p);
1057     return E_NOTIMPL;
1058 }
1059
1060 static HRESULT WINAPI HTMLWindow2_showModalDialog(IHTMLWindow2 *iface, BSTR dialog,
1061         VARIANT *varArgIn, VARIANT *varOptions, VARIANT *varArgOut)
1062 {
1063     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
1064     FIXME("(%p)->(%s %p %p %p)\n", This, debugstr_w(dialog), varArgIn, varOptions, varArgOut);
1065     return E_NOTIMPL;
1066 }
1067
1068 static HRESULT WINAPI HTMLWindow2_showHelp(IHTMLWindow2 *iface, BSTR helpURL, VARIANT helpArg,
1069         BSTR features)
1070 {
1071     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
1072     FIXME("(%p)->(%s %s %s)\n", This, debugstr_w(helpURL), debugstr_variant(&helpArg), debugstr_w(features));
1073     return E_NOTIMPL;
1074 }
1075
1076 static HRESULT WINAPI HTMLWindow2_get_screen(IHTMLWindow2 *iface, IHTMLScreen **p)
1077 {
1078     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
1079
1080     TRACE("(%p)->(%p)\n", This, p);
1081
1082     if(!This->screen) {
1083         HRESULT hres;
1084
1085         hres = HTMLScreen_Create(&This->screen);
1086         if(FAILED(hres))
1087             return hres;
1088     }
1089
1090     *p = This->screen;
1091     IHTMLScreen_AddRef(This->screen);
1092     return S_OK;
1093 }
1094
1095 static HRESULT WINAPI HTMLWindow2_get_Option(IHTMLWindow2 *iface, IHTMLOptionElementFactory **p)
1096 {
1097     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
1098
1099     TRACE("(%p)->(%p)\n", This, p);
1100
1101     if(!This->option_factory)
1102         This->option_factory = HTMLOptionElementFactory_Create(This);
1103
1104     *p = &This->option_factory->IHTMLOptionElementFactory_iface;
1105     IHTMLOptionElementFactory_AddRef(*p);
1106
1107     return S_OK;
1108 }
1109
1110 static HRESULT WINAPI HTMLWindow2_focus(IHTMLWindow2 *iface)
1111 {
1112     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
1113
1114     TRACE("(%p)->()\n", This);
1115
1116     if(This->doc_obj)
1117         SetFocus(This->doc_obj->hwnd);
1118     return S_OK;
1119 }
1120
1121 static HRESULT WINAPI HTMLWindow2_get_closed(IHTMLWindow2 *iface, VARIANT_BOOL *p)
1122 {
1123     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
1124     FIXME("(%p)->(%p)\n", This, p);
1125     return E_NOTIMPL;
1126 }
1127
1128 static HRESULT WINAPI HTMLWindow2_blur(IHTMLWindow2 *iface)
1129 {
1130     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
1131     FIXME("(%p)->()\n", This);
1132     return E_NOTIMPL;
1133 }
1134
1135 static HRESULT WINAPI HTMLWindow2_scroll(IHTMLWindow2 *iface, LONG x, LONG y)
1136 {
1137     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
1138     FIXME("(%p)->(%d %d)\n", This, x, y);
1139     return E_NOTIMPL;
1140 }
1141
1142 static HRESULT WINAPI HTMLWindow2_get_clientInformation(IHTMLWindow2 *iface, IOmNavigator **p)
1143 {
1144     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
1145     FIXME("(%p)->(%p)\n", This, p);
1146     return E_NOTIMPL;
1147 }
1148
1149 static HRESULT WINAPI HTMLWindow2_setInterval(IHTMLWindow2 *iface, BSTR expression,
1150         LONG msec, VARIANT *language, LONG *timerID)
1151 {
1152     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
1153     VARIANT expr;
1154
1155     TRACE("(%p)->(%s %d %p %p)\n", This, debugstr_w(expression), msec, language, timerID);
1156
1157     V_VT(&expr) = VT_BSTR;
1158     V_BSTR(&expr) = expression;
1159     return IHTMLWindow3_setInterval(&This->IHTMLWindow3_iface, &expr, msec, language, timerID);
1160 }
1161
1162 static HRESULT WINAPI HTMLWindow2_clearInterval(IHTMLWindow2 *iface, LONG timerID)
1163 {
1164     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
1165
1166     TRACE("(%p)->(%d)\n", This, timerID);
1167
1168     return clear_task_timer(&This->doc->basedoc, TRUE, timerID);
1169 }
1170
1171 static HRESULT WINAPI HTMLWindow2_put_offscreenBuffering(IHTMLWindow2 *iface, VARIANT v)
1172 {
1173     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
1174     FIXME("(%p)->(%s)\n", This, debugstr_variant(&v));
1175     return E_NOTIMPL;
1176 }
1177
1178 static HRESULT WINAPI HTMLWindow2_get_offscreenBuffering(IHTMLWindow2 *iface, VARIANT *p)
1179 {
1180     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
1181     FIXME("(%p)->(%p)\n", This, p);
1182     return E_NOTIMPL;
1183 }
1184
1185 static HRESULT WINAPI HTMLWindow2_execScript(IHTMLWindow2 *iface, BSTR scode, BSTR language,
1186         VARIANT *pvarRet)
1187 {
1188     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
1189
1190     TRACE("(%p)->(%s %s %p)\n", This, debugstr_w(scode), debugstr_w(language), pvarRet);
1191
1192     return exec_script(This, scode, language, pvarRet);
1193 }
1194
1195 static HRESULT WINAPI HTMLWindow2_toString(IHTMLWindow2 *iface, BSTR *String)
1196 {
1197     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
1198
1199     static const WCHAR objectW[] = {'[','o','b','j','e','c','t',']',0};
1200
1201     TRACE("(%p)->(%p)\n", This, String);
1202
1203     if(!String)
1204         return E_INVALIDARG;
1205
1206     *String = SysAllocString(objectW);
1207     return *String ? S_OK : E_OUTOFMEMORY;
1208 }
1209
1210 static HRESULT WINAPI HTMLWindow2_scrollBy(IHTMLWindow2 *iface, LONG x, LONG y)
1211 {
1212     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
1213     nsresult nsres;
1214
1215     TRACE("(%p)->(%d %d)\n", This, x, y);
1216
1217     nsres = nsIDOMWindow_ScrollBy(This->nswindow, x, y);
1218     if(NS_FAILED(nsres))
1219         ERR("ScrollBy failed: %08x\n", nsres);
1220
1221     return S_OK;
1222 }
1223
1224 static HRESULT WINAPI HTMLWindow2_scrollTo(IHTMLWindow2 *iface, LONG x, LONG y)
1225 {
1226     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
1227     nsresult nsres;
1228
1229     TRACE("(%p)->(%d %d)\n", This, x, y);
1230
1231     nsres = nsIDOMWindow_ScrollTo(This->nswindow, x, y);
1232     if(NS_FAILED(nsres))
1233         ERR("ScrollTo failed: %08x\n", nsres);
1234
1235     return S_OK;
1236 }
1237
1238 static HRESULT WINAPI HTMLWindow2_moveTo(IHTMLWindow2 *iface, LONG x, LONG y)
1239 {
1240     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
1241     FIXME("(%p)->(%d %d)\n", This, x, y);
1242     return E_NOTIMPL;
1243 }
1244
1245 static HRESULT WINAPI HTMLWindow2_moveBy(IHTMLWindow2 *iface, LONG x, LONG y)
1246 {
1247     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
1248     FIXME("(%p)->(%d %d)\n", This, x, y);
1249     return E_NOTIMPL;
1250 }
1251
1252 static HRESULT WINAPI HTMLWindow2_resizeTo(IHTMLWindow2 *iface, LONG x, LONG y)
1253 {
1254     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
1255     FIXME("(%p)->(%d %d)\n", This, x, y);
1256     return E_NOTIMPL;
1257 }
1258
1259 static HRESULT WINAPI HTMLWindow2_resizeBy(IHTMLWindow2 *iface, LONG x, LONG y)
1260 {
1261     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
1262     FIXME("(%p)->(%d %d)\n", This, x, y);
1263     return E_NOTIMPL;
1264 }
1265
1266 static HRESULT WINAPI HTMLWindow2_get_external(IHTMLWindow2 *iface, IDispatch **p)
1267 {
1268     HTMLWindow *This = impl_from_IHTMLWindow2(iface);
1269
1270     TRACE("(%p)->(%p)\n", This, p);
1271
1272     *p = NULL;
1273
1274     if(!This->doc_obj->hostui)
1275         return S_OK;
1276
1277     return IDocHostUIHandler_GetExternal(This->doc_obj->hostui, p);
1278 }
1279
1280 static const IHTMLWindow2Vtbl HTMLWindow2Vtbl = {
1281     HTMLWindow2_QueryInterface,
1282     HTMLWindow2_AddRef,
1283     HTMLWindow2_Release,
1284     HTMLWindow2_GetTypeInfoCount,
1285     HTMLWindow2_GetTypeInfo,
1286     HTMLWindow2_GetIDsOfNames,
1287     HTMLWindow2_Invoke,
1288     HTMLWindow2_item,
1289     HTMLWindow2_get_length,
1290     HTMLWindow2_get_frames,
1291     HTMLWindow2_put_defaultStatus,
1292     HTMLWindow2_get_defaultStatus,
1293     HTMLWindow2_put_status,
1294     HTMLWindow2_get_status,
1295     HTMLWindow2_setTimeout,
1296     HTMLWindow2_clearTimeout,
1297     HTMLWindow2_alert,
1298     HTMLWindow2_confirm,
1299     HTMLWindow2_prompt,
1300     HTMLWindow2_get_Image,
1301     HTMLWindow2_get_location,
1302     HTMLWindow2_get_history,
1303     HTMLWindow2_close,
1304     HTMLWindow2_put_opener,
1305     HTMLWindow2_get_opener,
1306     HTMLWindow2_get_navigator,
1307     HTMLWindow2_put_name,
1308     HTMLWindow2_get_name,
1309     HTMLWindow2_get_parent,
1310     HTMLWindow2_open,
1311     HTMLWindow2_get_self,
1312     HTMLWindow2_get_top,
1313     HTMLWindow2_get_window,
1314     HTMLWindow2_navigate,
1315     HTMLWindow2_put_onfocus,
1316     HTMLWindow2_get_onfocus,
1317     HTMLWindow2_put_onblur,
1318     HTMLWindow2_get_onblur,
1319     HTMLWindow2_put_onload,
1320     HTMLWindow2_get_onload,
1321     HTMLWindow2_put_onbeforeunload,
1322     HTMLWindow2_get_onbeforeunload,
1323     HTMLWindow2_put_onunload,
1324     HTMLWindow2_get_onunload,
1325     HTMLWindow2_put_onhelp,
1326     HTMLWindow2_get_onhelp,
1327     HTMLWindow2_put_onerror,
1328     HTMLWindow2_get_onerror,
1329     HTMLWindow2_put_onresize,
1330     HTMLWindow2_get_onresize,
1331     HTMLWindow2_put_onscroll,
1332     HTMLWindow2_get_onscroll,
1333     HTMLWindow2_get_document,
1334     HTMLWindow2_get_event,
1335     HTMLWindow2_get__newEnum,
1336     HTMLWindow2_showModalDialog,
1337     HTMLWindow2_showHelp,
1338     HTMLWindow2_get_screen,
1339     HTMLWindow2_get_Option,
1340     HTMLWindow2_focus,
1341     HTMLWindow2_get_closed,
1342     HTMLWindow2_blur,
1343     HTMLWindow2_scroll,
1344     HTMLWindow2_get_clientInformation,
1345     HTMLWindow2_setInterval,
1346     HTMLWindow2_clearInterval,
1347     HTMLWindow2_put_offscreenBuffering,
1348     HTMLWindow2_get_offscreenBuffering,
1349     HTMLWindow2_execScript,
1350     HTMLWindow2_toString,
1351     HTMLWindow2_scrollBy,
1352     HTMLWindow2_scrollTo,
1353     HTMLWindow2_moveTo,
1354     HTMLWindow2_moveBy,
1355     HTMLWindow2_resizeTo,
1356     HTMLWindow2_resizeBy,
1357     HTMLWindow2_get_external
1358 };
1359
1360 static inline HTMLWindow *impl_from_IHTMLWindow3(IHTMLWindow3 *iface)
1361 {
1362     return CONTAINING_RECORD(iface, HTMLWindow, IHTMLWindow3_iface);
1363 }
1364
1365 static HRESULT WINAPI HTMLWindow3_QueryInterface(IHTMLWindow3 *iface, REFIID riid, void **ppv)
1366 {
1367     HTMLWindow *This = impl_from_IHTMLWindow3(iface);
1368
1369     return IHTMLWindow2_QueryInterface(&This->IHTMLWindow2_iface, riid, ppv);
1370 }
1371
1372 static ULONG WINAPI HTMLWindow3_AddRef(IHTMLWindow3 *iface)
1373 {
1374     HTMLWindow *This = impl_from_IHTMLWindow3(iface);
1375
1376     return IHTMLWindow2_AddRef(&This->IHTMLWindow2_iface);
1377 }
1378
1379 static ULONG WINAPI HTMLWindow3_Release(IHTMLWindow3 *iface)
1380 {
1381     HTMLWindow *This = impl_from_IHTMLWindow3(iface);
1382
1383     return IHTMLWindow2_Release(&This->IHTMLWindow2_iface);
1384 }
1385
1386 static HRESULT WINAPI HTMLWindow3_GetTypeInfoCount(IHTMLWindow3 *iface, UINT *pctinfo)
1387 {
1388     HTMLWindow *This = impl_from_IHTMLWindow3(iface);
1389
1390     return IDispatchEx_GetTypeInfoCount(&This->IDispatchEx_iface, pctinfo);
1391 }
1392
1393 static HRESULT WINAPI HTMLWindow3_GetTypeInfo(IHTMLWindow3 *iface, UINT iTInfo,
1394                                               LCID lcid, ITypeInfo **ppTInfo)
1395 {
1396     HTMLWindow *This = impl_from_IHTMLWindow3(iface);
1397
1398     return IDispatchEx_GetTypeInfo(&This->IDispatchEx_iface, iTInfo, lcid, ppTInfo);
1399 }
1400
1401 static HRESULT WINAPI HTMLWindow3_GetIDsOfNames(IHTMLWindow3 *iface, REFIID riid,
1402                                                 LPOLESTR *rgszNames, UINT cNames,
1403                                                 LCID lcid, DISPID *rgDispId)
1404 {
1405     HTMLWindow *This = impl_from_IHTMLWindow3(iface);
1406
1407     return IDispatchEx_GetIDsOfNames(&This->IDispatchEx_iface, riid, rgszNames, cNames, lcid,
1408             rgDispId);
1409 }
1410
1411 static HRESULT WINAPI HTMLWindow3_Invoke(IHTMLWindow3 *iface, DISPID dispIdMember,
1412                             REFIID riid, LCID lcid, WORD wFlags, DISPPARAMS *pDispParams,
1413                             VARIANT *pVarResult, EXCEPINFO *pExcepInfo, UINT *puArgErr)
1414 {
1415     HTMLWindow *This = impl_from_IHTMLWindow3(iface);
1416
1417     return IDispatchEx_Invoke(&This->IDispatchEx_iface, dispIdMember, riid, lcid, wFlags,
1418             pDispParams, pVarResult, pExcepInfo, puArgErr);
1419 }
1420
1421 static HRESULT WINAPI HTMLWindow3_get_screenLeft(IHTMLWindow3 *iface, LONG *p)
1422 {
1423     HTMLWindow *This = impl_from_IHTMLWindow3(iface);
1424     FIXME("(%p)->(%p)\n", This, p);
1425     return E_NOTIMPL;
1426 }
1427
1428 static HRESULT WINAPI HTMLWindow3_get_screenTop(IHTMLWindow3 *iface, LONG *p)
1429 {
1430     HTMLWindow *This = impl_from_IHTMLWindow3(iface);
1431     FIXME("(%p)->(%p)\n", This, p);
1432     return E_NOTIMPL;
1433 }
1434
1435 static HRESULT WINAPI HTMLWindow3_attachEvent(IHTMLWindow3 *iface, BSTR event, IDispatch *pDisp, VARIANT_BOOL *pfResult)
1436 {
1437     HTMLWindow *This = impl_from_IHTMLWindow3(iface);
1438
1439     TRACE("(%p)->(%s %p %p)\n", This, debugstr_w(event), pDisp, pfResult);
1440
1441     if(!This->doc) {
1442         FIXME("No document\n");
1443         return E_FAIL;
1444     }
1445
1446     return attach_event(&This->doc->body_event_target, NULL, &This->doc->basedoc, event, pDisp, pfResult);
1447 }
1448
1449 static HRESULT WINAPI HTMLWindow3_detachEvent(IHTMLWindow3 *iface, BSTR event, IDispatch *pDisp)
1450 {
1451     HTMLWindow *This = impl_from_IHTMLWindow3(iface);
1452     FIXME("(%p)->()\n", This);
1453     return E_NOTIMPL;
1454 }
1455
1456 static HRESULT window_set_timer(HTMLWindow *This, VARIANT *expr, LONG msec, VARIANT *language,
1457         BOOL interval, LONG *timer_id)
1458 {
1459     IDispatch *disp = NULL;
1460
1461     switch(V_VT(expr)) {
1462     case VT_DISPATCH:
1463         disp = V_DISPATCH(expr);
1464         IDispatch_AddRef(disp);
1465         break;
1466
1467     case VT_BSTR:
1468         disp = script_parse_event(This, V_BSTR(expr));
1469         break;
1470
1471     default:
1472         FIXME("unimplemented expr %s\n", debugstr_variant(expr));
1473         return E_NOTIMPL;
1474     }
1475
1476     if(!disp)
1477         return E_FAIL;
1478
1479     *timer_id = set_task_timer(&This->doc->basedoc, msec, interval, disp);
1480     IDispatch_Release(disp);
1481
1482     return S_OK;
1483 }
1484
1485 static HRESULT WINAPI HTMLWindow3_setTimeout(IHTMLWindow3 *iface, VARIANT *expression, LONG msec,
1486         VARIANT *language, LONG *timerID)
1487 {
1488     HTMLWindow *This = impl_from_IHTMLWindow3(iface);
1489
1490     TRACE("(%p)->(%s %d %s %p)\n", This, debugstr_variant(expression), msec, debugstr_variant(language), timerID);
1491
1492     return window_set_timer(This, expression, msec, language, FALSE, timerID);
1493 }
1494
1495 static HRESULT WINAPI HTMLWindow3_setInterval(IHTMLWindow3 *iface, VARIANT *expression, LONG msec,
1496         VARIANT *language, LONG *timerID)
1497 {
1498     HTMLWindow *This = impl_from_IHTMLWindow3(iface);
1499
1500     TRACE("(%p)->(%p %d %p %p)\n", This, expression, msec, language, timerID);
1501
1502     return window_set_timer(This, expression, msec, language, TRUE, timerID);
1503 }
1504
1505 static HRESULT WINAPI HTMLWindow3_print(IHTMLWindow3 *iface)
1506 {
1507     HTMLWindow *This = impl_from_IHTMLWindow3(iface);
1508     FIXME("(%p)\n", This);
1509     return E_NOTIMPL;
1510 }
1511
1512 static HRESULT WINAPI HTMLWindow3_put_onbeforeprint(IHTMLWindow3 *iface, VARIANT v)
1513 {
1514     HTMLWindow *This = impl_from_IHTMLWindow3(iface);
1515     FIXME("(%p)->(%s)\n", This, debugstr_variant(&v));
1516     return E_NOTIMPL;
1517 }
1518
1519 static HRESULT WINAPI HTMLWindow3_get_onbeforeprint(IHTMLWindow3 *iface, VARIANT *p)
1520 {
1521     HTMLWindow *This = impl_from_IHTMLWindow3(iface);
1522     FIXME("(%p)->(%p)\n", This, p);
1523     return E_NOTIMPL;
1524 }
1525
1526 static HRESULT WINAPI HTMLWindow3_put_onafterprint(IHTMLWindow3 *iface, VARIANT v)
1527 {
1528     HTMLWindow *This = impl_from_IHTMLWindow3(iface);
1529     FIXME("(%p)->(%s)\n", This, debugstr_variant(&v));
1530     return E_NOTIMPL;
1531 }
1532
1533 static HRESULT WINAPI HTMLWindow3_get_onafterprint(IHTMLWindow3 *iface, VARIANT *p)
1534 {
1535     HTMLWindow *This = impl_from_IHTMLWindow3(iface);
1536     FIXME("(%p)->(%p)\n", This, p);
1537     return E_NOTIMPL;
1538 }
1539
1540 static HRESULT WINAPI HTMLWindow3_get_clipboardData(IHTMLWindow3 *iface, IHTMLDataTransfer **p)
1541 {
1542     HTMLWindow *This = impl_from_IHTMLWindow3(iface);
1543     FIXME("(%p)->(%p)\n", This, p);
1544     return E_NOTIMPL;
1545 }
1546
1547 static HRESULT WINAPI HTMLWindow3_showModelessDialog(IHTMLWindow3 *iface, BSTR url,
1548         VARIANT *varArgIn, VARIANT *options, IHTMLWindow2 **pDialog)
1549 {
1550     HTMLWindow *This = impl_from_IHTMLWindow3(iface);
1551     FIXME("(%p)->(%s %p %p %p)\n", This, debugstr_w(url), varArgIn, options, pDialog);
1552     return E_NOTIMPL;
1553 }
1554
1555 static const IHTMLWindow3Vtbl HTMLWindow3Vtbl = {
1556     HTMLWindow3_QueryInterface,
1557     HTMLWindow3_AddRef,
1558     HTMLWindow3_Release,
1559     HTMLWindow3_GetTypeInfoCount,
1560     HTMLWindow3_GetTypeInfo,
1561     HTMLWindow3_GetIDsOfNames,
1562     HTMLWindow3_Invoke,
1563     HTMLWindow3_get_screenLeft,
1564     HTMLWindow3_get_screenTop,
1565     HTMLWindow3_attachEvent,
1566     HTMLWindow3_detachEvent,
1567     HTMLWindow3_setTimeout,
1568     HTMLWindow3_setInterval,
1569     HTMLWindow3_print,
1570     HTMLWindow3_put_onbeforeprint,
1571     HTMLWindow3_get_onbeforeprint,
1572     HTMLWindow3_put_onafterprint,
1573     HTMLWindow3_get_onafterprint,
1574     HTMLWindow3_get_clipboardData,
1575     HTMLWindow3_showModelessDialog
1576 };
1577
1578 static inline HTMLWindow *impl_from_IHTMLWindow4(IHTMLWindow4 *iface)
1579 {
1580     return CONTAINING_RECORD(iface, HTMLWindow, IHTMLWindow4_iface);
1581 }
1582
1583 static HRESULT WINAPI HTMLWindow4_QueryInterface(IHTMLWindow4 *iface, REFIID riid, void **ppv)
1584 {
1585     HTMLWindow *This = impl_from_IHTMLWindow4(iface);
1586
1587     return IHTMLWindow2_QueryInterface(&This->IHTMLWindow2_iface, riid, ppv);
1588 }
1589
1590 static ULONG WINAPI HTMLWindow4_AddRef(IHTMLWindow4 *iface)
1591 {
1592     HTMLWindow *This = impl_from_IHTMLWindow4(iface);
1593
1594     return IHTMLWindow2_AddRef(&This->IHTMLWindow2_iface);
1595 }
1596
1597 static ULONG WINAPI HTMLWindow4_Release(IHTMLWindow4 *iface)
1598 {
1599     HTMLWindow *This = impl_from_IHTMLWindow4(iface);
1600
1601     return IHTMLWindow2_Release(&This->IHTMLWindow2_iface);
1602 }
1603
1604 static HRESULT WINAPI HTMLWindow4_GetTypeInfoCount(IHTMLWindow4 *iface, UINT *pctinfo)
1605 {
1606     HTMLWindow *This = impl_from_IHTMLWindow4(iface);
1607
1608     return IDispatchEx_GetTypeInfoCount(&This->IDispatchEx_iface, pctinfo);
1609 }
1610
1611 static HRESULT WINAPI HTMLWindow4_GetTypeInfo(IHTMLWindow4 *iface, UINT iTInfo,
1612                                               LCID lcid, ITypeInfo **ppTInfo)
1613 {
1614     HTMLWindow *This = impl_from_IHTMLWindow4(iface);
1615
1616     return IDispatchEx_GetTypeInfo(&This->IDispatchEx_iface, iTInfo, lcid, ppTInfo);
1617 }
1618
1619 static HRESULT WINAPI HTMLWindow4_GetIDsOfNames(IHTMLWindow4 *iface, REFIID riid,
1620                                                 LPOLESTR *rgszNames, UINT cNames,
1621                                                 LCID lcid, DISPID *rgDispId)
1622 {
1623     HTMLWindow *This = impl_from_IHTMLWindow4(iface);
1624
1625     return IDispatchEx_GetIDsOfNames(&This->IDispatchEx_iface, riid, rgszNames, cNames, lcid,
1626             rgDispId);
1627 }
1628
1629 static HRESULT WINAPI HTMLWindow4_Invoke(IHTMLWindow4 *iface, DISPID dispIdMember,
1630                             REFIID riid, LCID lcid, WORD wFlags, DISPPARAMS *pDispParams,
1631                             VARIANT *pVarResult, EXCEPINFO *pExcepInfo, UINT *puArgErr)
1632 {
1633     HTMLWindow *This = impl_from_IHTMLWindow4(iface);
1634
1635     return IDispatchEx_Invoke(&This->IDispatchEx_iface, dispIdMember, riid, lcid, wFlags,
1636             pDispParams, pVarResult, pExcepInfo, puArgErr);
1637 }
1638
1639 static HRESULT WINAPI HTMLWindow4_createPopup(IHTMLWindow4 *iface, VARIANT *varArgIn,
1640                             IDispatch **ppPopup)
1641 {
1642     HTMLWindow *This = impl_from_IHTMLWindow4(iface);
1643     FIXME("(%p)->(%p %p)\n", This, varArgIn, ppPopup);
1644     return E_NOTIMPL;
1645 }
1646
1647 static HRESULT WINAPI HTMLWindow4_get_frameElement(IHTMLWindow4 *iface, IHTMLFrameBase **p)
1648 {
1649     HTMLWindow *This = impl_from_IHTMLWindow4(iface);
1650     TRACE("(%p)->(%p)\n", This, p);
1651
1652     if(This->frame_element) {
1653         *p = &This->frame_element->IHTMLFrameBase_iface;
1654         IHTMLFrameBase_AddRef(*p);
1655     }else
1656         *p = NULL;
1657
1658     return S_OK;
1659 }
1660
1661 static const IHTMLWindow4Vtbl HTMLWindow4Vtbl = {
1662     HTMLWindow4_QueryInterface,
1663     HTMLWindow4_AddRef,
1664     HTMLWindow4_Release,
1665     HTMLWindow4_GetTypeInfoCount,
1666     HTMLWindow4_GetTypeInfo,
1667     HTMLWindow4_GetIDsOfNames,
1668     HTMLWindow4_Invoke,
1669     HTMLWindow4_createPopup,
1670     HTMLWindow4_get_frameElement
1671 };
1672
1673 static inline HTMLWindow *impl_from_IHTMLWindow5(IHTMLWindow5 *iface)
1674 {
1675     return CONTAINING_RECORD(iface, HTMLWindow, IHTMLWindow5_iface);
1676 }
1677
1678 static HRESULT WINAPI HTMLWindow5_QueryInterface(IHTMLWindow5 *iface, REFIID riid, void **ppv)
1679 {
1680     HTMLWindow *This = impl_from_IHTMLWindow5(iface);
1681
1682     return IHTMLWindow2_QueryInterface(&This->IHTMLWindow2_iface, riid, ppv);
1683 }
1684
1685 static ULONG WINAPI HTMLWindow5_AddRef(IHTMLWindow5 *iface)
1686 {
1687     HTMLWindow *This = impl_from_IHTMLWindow5(iface);
1688
1689     return IHTMLWindow2_AddRef(&This->IHTMLWindow2_iface);
1690 }
1691
1692 static ULONG WINAPI HTMLWindow5_Release(IHTMLWindow5 *iface)
1693 {
1694     HTMLWindow *This = impl_from_IHTMLWindow5(iface);
1695
1696     return IHTMLWindow2_Release(&This->IHTMLWindow2_iface);
1697 }
1698
1699 static HRESULT WINAPI HTMLWindow5_GetTypeInfoCount(IHTMLWindow5 *iface, UINT *pctinfo)
1700 {
1701     HTMLWindow *This = impl_from_IHTMLWindow5(iface);
1702
1703     return IDispatchEx_GetTypeInfoCount(&This->IDispatchEx_iface, pctinfo);
1704 }
1705
1706 static HRESULT WINAPI HTMLWindow5_GetTypeInfo(IHTMLWindow5 *iface, UINT iTInfo,
1707         LCID lcid, ITypeInfo **ppTInfo)
1708 {
1709     HTMLWindow *This = impl_from_IHTMLWindow5(iface);
1710
1711     return IDispatchEx_GetTypeInfo(&This->IDispatchEx_iface, iTInfo, lcid, ppTInfo);
1712 }
1713
1714 static HRESULT WINAPI HTMLWindow5_GetIDsOfNames(IHTMLWindow5 *iface, REFIID riid,
1715         LPOLESTR *rgszNames, UINT cNames, LCID lcid, DISPID *rgDispId)
1716 {
1717     HTMLWindow *This = impl_from_IHTMLWindow5(iface);
1718
1719     return IDispatchEx_GetIDsOfNames(&This->IDispatchEx_iface, riid, rgszNames, cNames, lcid,
1720             rgDispId);
1721 }
1722
1723 static HRESULT WINAPI HTMLWindow5_Invoke(IHTMLWindow5 *iface, DISPID dispIdMember,
1724         REFIID riid, LCID lcid, WORD wFlags, DISPPARAMS *pDispParams,
1725         VARIANT *pVarResult, EXCEPINFO *pExcepInfo, UINT *puArgErr)
1726 {
1727     HTMLWindow *This = impl_from_IHTMLWindow5(iface);
1728
1729     return IDispatchEx_Invoke(&This->IDispatchEx_iface, dispIdMember, riid, lcid, wFlags,
1730             pDispParams, pVarResult, pExcepInfo, puArgErr);
1731 }
1732
1733 static HRESULT WINAPI HTMLWindow5_put_XMLHttpRequest(IHTMLWindow5 *iface, VARIANT v)
1734 {
1735     HTMLWindow *This = impl_from_IHTMLWindow5(iface);
1736     FIXME("(%p)->(%s)\n", This, debugstr_variant(&v));
1737     return E_NOTIMPL;
1738 }
1739
1740 static HRESULT WINAPI HTMLWindow5_get_XMLHttpRequest(IHTMLWindow5 *iface, VARIANT *p)
1741 {
1742     HTMLWindow *This = impl_from_IHTMLWindow5(iface);
1743     FIXME("(%p)->(%p)\n", This, p);
1744     return E_NOTIMPL;
1745 }
1746
1747 static const IHTMLWindow5Vtbl HTMLWindow5Vtbl = {
1748     HTMLWindow5_QueryInterface,
1749     HTMLWindow5_AddRef,
1750     HTMLWindow5_Release,
1751     HTMLWindow5_GetTypeInfoCount,
1752     HTMLWindow5_GetTypeInfo,
1753     HTMLWindow5_GetIDsOfNames,
1754     HTMLWindow5_Invoke,
1755     HTMLWindow5_put_XMLHttpRequest,
1756     HTMLWindow5_get_XMLHttpRequest
1757 };
1758
1759 static inline HTMLWindow *impl_from_IHTMLWindow6(IHTMLWindow6 *iface)
1760 {
1761     return CONTAINING_RECORD(iface, HTMLWindow, IHTMLWindow6_iface);
1762 }
1763
1764 static HRESULT WINAPI HTMLWindow6_QueryInterface(IHTMLWindow6 *iface, REFIID riid, void **ppv)
1765 {
1766     HTMLWindow *This = impl_from_IHTMLWindow6(iface);
1767
1768     return IHTMLWindow2_QueryInterface(&This->IHTMLWindow2_iface, riid, ppv);
1769 }
1770
1771 static ULONG WINAPI HTMLWindow6_AddRef(IHTMLWindow6 *iface)
1772 {
1773     HTMLWindow *This = impl_from_IHTMLWindow6(iface);
1774
1775     return IHTMLWindow2_AddRef(&This->IHTMLWindow2_iface);
1776 }
1777
1778 static ULONG WINAPI HTMLWindow6_Release(IHTMLWindow6 *iface)
1779 {
1780     HTMLWindow *This = impl_from_IHTMLWindow6(iface);
1781
1782     return IHTMLWindow2_Release(&This->IHTMLWindow2_iface);
1783 }
1784
1785 static HRESULT WINAPI HTMLWindow6_GetTypeInfoCount(IHTMLWindow6 *iface, UINT *pctinfo)
1786 {
1787     HTMLWindow *This = impl_from_IHTMLWindow6(iface);
1788
1789     return IDispatchEx_GetTypeInfoCount(&This->IDispatchEx_iface, pctinfo);
1790 }
1791
1792 static HRESULT WINAPI HTMLWindow6_GetTypeInfo(IHTMLWindow6 *iface, UINT iTInfo,
1793                                               LCID lcid, ITypeInfo **ppTInfo)
1794 {
1795     HTMLWindow *This = impl_from_IHTMLWindow6(iface);
1796
1797     return IDispatchEx_GetTypeInfo(&This->IDispatchEx_iface, iTInfo, lcid, ppTInfo);
1798 }
1799
1800 static HRESULT WINAPI HTMLWindow6_GetIDsOfNames(IHTMLWindow6 *iface, REFIID riid,
1801                                                 LPOLESTR *rgszNames, UINT cNames,
1802                                                 LCID lcid, DISPID *rgDispId)
1803 {
1804     HTMLWindow *This = impl_from_IHTMLWindow6(iface);
1805
1806     return IDispatchEx_GetIDsOfNames(&This->IDispatchEx_iface, riid, rgszNames, cNames, lcid,
1807             rgDispId);
1808 }
1809
1810 static HRESULT WINAPI HTMLWindow6_Invoke(IHTMLWindow6 *iface, DISPID dispIdMember,
1811                             REFIID riid, LCID lcid, WORD wFlags, DISPPARAMS *pDispParams,
1812                             VARIANT *pVarResult, EXCEPINFO *pExcepInfo, UINT *puArgErr)
1813 {
1814     HTMLWindow *This = impl_from_IHTMLWindow6(iface);
1815
1816     return IDispatchEx_Invoke(&This->IDispatchEx_iface, dispIdMember, riid, lcid, wFlags,
1817             pDispParams, pVarResult, pExcepInfo, puArgErr);
1818 }
1819
1820 static HRESULT WINAPI HTMLWindow6_put_XDomainRequest(IHTMLWindow6 *iface, VARIANT v)
1821 {
1822     HTMLWindow *This = impl_from_IHTMLWindow6(iface);
1823     FIXME("(%p)->(%s)\n", This, debugstr_variant(&v));
1824     return E_NOTIMPL;
1825 }
1826
1827 static HRESULT WINAPI HTMLWindow6_get_XDomainRequest(IHTMLWindow6 *iface, VARIANT *p)
1828 {
1829     HTMLWindow *This = impl_from_IHTMLWindow6(iface);
1830     FIXME("(%p)->(%p)\n", This, p);
1831     return E_NOTIMPL;
1832 }
1833
1834 static HRESULT WINAPI HTMLWindow6_get_sessionStorage(IHTMLWindow6 *iface, IHTMLStorage **p)
1835 {
1836     HTMLWindow *This = impl_from_IHTMLWindow6(iface);
1837     FIXME("(%p)->(%p)\n", This, p);
1838     return E_NOTIMPL;
1839 }
1840
1841 static HRESULT WINAPI HTMLWindow6_get_localStorage(IHTMLWindow6 *iface, IHTMLStorage **p)
1842 {
1843     HTMLWindow *This = impl_from_IHTMLWindow6(iface);
1844     FIXME("(%p)->(%p)\n", This, p);
1845     return E_NOTIMPL;
1846 }
1847
1848 static HRESULT WINAPI HTMLWindow6_put_onhashchange(IHTMLWindow6 *iface, VARIANT v)
1849 {
1850     HTMLWindow *This = impl_from_IHTMLWindow6(iface);
1851     FIXME("(%p)->(%s)\n", This, debugstr_variant(&v));
1852     return E_NOTIMPL;
1853 }
1854
1855 static HRESULT WINAPI HTMLWindow6_get_onhashchange(IHTMLWindow6 *iface, VARIANT *p)
1856 {
1857     HTMLWindow *This = impl_from_IHTMLWindow6(iface);
1858     FIXME("(%p)->(%p)\n", This, p);
1859     return E_NOTIMPL;
1860 }
1861
1862 static HRESULT WINAPI HTMLWindow6_get_maxConnectionsPerServer(IHTMLWindow6 *iface, LONG *p)
1863 {
1864     HTMLWindow *This = impl_from_IHTMLWindow6(iface);
1865     FIXME("(%p)->(%p)\n", This, p);
1866     return E_NOTIMPL;
1867 }
1868
1869 static HRESULT WINAPI HTMLWindow6_postMessage(IHTMLWindow6 *iface, BSTR msg, VARIANT targetOrigin)
1870 {
1871     HTMLWindow *This = impl_from_IHTMLWindow6(iface);
1872     FIXME("(%p)->(%s %s)\n", This, debugstr_w(msg), debugstr_variant(&targetOrigin));
1873     return E_NOTIMPL;
1874 }
1875
1876 static HRESULT WINAPI HTMLWindow6_toStaticHTML(IHTMLWindow6 *iface, BSTR bstrHTML, BSTR *pbstrStaticHTML)
1877 {
1878     HTMLWindow *This = impl_from_IHTMLWindow6(iface);
1879     FIXME("(%p)->(%s %p)\n", This, debugstr_w(bstrHTML), pbstrStaticHTML);
1880     return E_NOTIMPL;
1881 }
1882
1883 static HRESULT WINAPI HTMLWindow6_put_onmessage(IHTMLWindow6 *iface, VARIANT v)
1884 {
1885     HTMLWindow *This = impl_from_IHTMLWindow6(iface);
1886     FIXME("(%p)->(%s)\n", This, debugstr_variant(&v));
1887     return E_NOTIMPL;
1888 }
1889
1890 static HRESULT WINAPI HTMLWindow6_get_onmessage(IHTMLWindow6 *iface, VARIANT *p)
1891 {
1892     HTMLWindow *This = impl_from_IHTMLWindow6(iface);
1893     FIXME("(%p)->(%p)\n", This, p);
1894     return E_NOTIMPL;
1895 }
1896
1897 static HRESULT WINAPI HTMLWindow6_msWriteProfilerMark(IHTMLWindow6 *iface, BSTR bstrProfilerMark)
1898 {
1899     HTMLWindow *This = impl_from_IHTMLWindow6(iface);
1900     FIXME("(%p)->(%s)\n", This, debugstr_w(bstrProfilerMark));
1901     return E_NOTIMPL;
1902 }
1903
1904 static const IHTMLWindow6Vtbl HTMLWindow6Vtbl = {
1905     HTMLWindow6_QueryInterface,
1906     HTMLWindow6_AddRef,
1907     HTMLWindow6_Release,
1908     HTMLWindow6_GetTypeInfoCount,
1909     HTMLWindow6_GetTypeInfo,
1910     HTMLWindow6_GetIDsOfNames,
1911     HTMLWindow6_Invoke,
1912     HTMLWindow6_put_XDomainRequest,
1913     HTMLWindow6_get_XDomainRequest,
1914     HTMLWindow6_get_sessionStorage,
1915     HTMLWindow6_get_localStorage,
1916     HTMLWindow6_put_onhashchange,
1917     HTMLWindow6_get_onhashchange,
1918     HTMLWindow6_get_maxConnectionsPerServer,
1919     HTMLWindow6_postMessage,
1920     HTMLWindow6_toStaticHTML,
1921     HTMLWindow6_put_onmessage,
1922     HTMLWindow6_get_onmessage,
1923     HTMLWindow6_msWriteProfilerMark
1924 };
1925
1926 static inline HTMLWindow *impl_from_IHTMLPrivateWindow(IHTMLPrivateWindow *iface)
1927 {
1928     return CONTAINING_RECORD(iface, HTMLWindow, IHTMLPrivateWindow_iface);
1929 }
1930
1931 static HRESULT WINAPI HTMLPrivateWindow_QueryInterface(IHTMLPrivateWindow *iface, REFIID riid, void **ppv)
1932 {
1933     HTMLWindow *This = impl_from_IHTMLPrivateWindow(iface);
1934
1935     return IHTMLWindow2_QueryInterface(&This->IHTMLWindow2_iface, riid, ppv);
1936 }
1937
1938 static ULONG WINAPI HTMLPrivateWindow_AddRef(IHTMLPrivateWindow *iface)
1939 {
1940     HTMLWindow *This = impl_from_IHTMLPrivateWindow(iface);
1941
1942     return IHTMLWindow2_AddRef(&This->IHTMLWindow2_iface);
1943 }
1944
1945 static ULONG WINAPI HTMLPrivateWindow_Release(IHTMLPrivateWindow *iface)
1946 {
1947     HTMLWindow *This = impl_from_IHTMLPrivateWindow(iface);
1948
1949     return IHTMLWindow2_Release(&This->IHTMLWindow2_iface);
1950 }
1951
1952 static HRESULT WINAPI HTMLPrivateWindow_SuperNavigate(IHTMLPrivateWindow *iface, BSTR url, BSTR arg2, BSTR arg3,
1953         BSTR arg4, VARIANT *post_data_var, VARIANT *headers_var, ULONG flags)
1954 {
1955     HTMLWindow *This = impl_from_IHTMLPrivateWindow(iface);
1956     OLECHAR *translated_url = NULL;
1957     DWORD post_data_size = 0;
1958     BYTE *post_data = NULL;
1959     WCHAR *headers = NULL;
1960     IUri *uri;
1961     HRESULT hres;
1962
1963     TRACE("(%p)->(%s %s %s %s %s %s %x)\n", This, debugstr_w(url), debugstr_w(arg2), debugstr_w(arg3), debugstr_w(arg4),
1964           debugstr_variant(post_data_var), debugstr_variant(headers_var), flags);
1965
1966     if(This->doc_obj->hostui) {
1967         hres = IDocHostUIHandler_TranslateUrl(This->doc_obj->hostui, 0, url, &translated_url);
1968         if(hres != S_OK)
1969             translated_url = NULL;
1970     }
1971
1972     hres = CreateUri(translated_url ? translated_url : url, 0, 0, &uri);
1973     CoTaskMemFree(translated_url);
1974     if(FAILED(hres))
1975         return hres;
1976
1977     if(post_data_var) {
1978         if(V_VT(post_data_var) == (VT_ARRAY|VT_UI1)) {
1979             SafeArrayAccessData(V_ARRAY(post_data_var), (void**)&post_data);
1980             post_data_size = V_ARRAY(post_data_var)->rgsabound[0].cElements;
1981         }
1982     }
1983
1984     if(headers_var && V_VT(headers_var) != VT_EMPTY && V_VT(headers_var) != VT_ERROR) {
1985         if(V_VT(headers_var) != VT_BSTR)
1986             return E_INVALIDARG;
1987
1988         headers = V_BSTR(headers_var);
1989     }
1990
1991     hres = super_navigate(This, uri, headers, post_data, post_data_size);
1992     IUri_Release(uri);
1993     if(post_data)
1994         SafeArrayUnaccessData(V_ARRAY(post_data_var));
1995
1996     return hres;
1997 }
1998
1999 static HRESULT WINAPI HTMLPrivateWindow_GetPendingUrl(IHTMLPrivateWindow *iface, BSTR *url)
2000 {
2001     HTMLWindow *This = impl_from_IHTMLPrivateWindow(iface);
2002     FIXME("(%p)->(%p)\n", This, url);
2003     return E_NOTIMPL;
2004 }
2005
2006 static HRESULT WINAPI HTMLPrivateWindow_SetPICSTarget(IHTMLPrivateWindow *iface, IOleCommandTarget *cmdtrg)
2007 {
2008     HTMLWindow *This = impl_from_IHTMLPrivateWindow(iface);
2009     FIXME("(%p)->(%p)\n", This, cmdtrg);
2010     return E_NOTIMPL;
2011 }
2012
2013 static HRESULT WINAPI HTMLPrivateWindow_PICSComplete(IHTMLPrivateWindow *iface, int arg)
2014 {
2015     HTMLWindow *This = impl_from_IHTMLPrivateWindow(iface);
2016     FIXME("(%p)->(%x)\n", This, arg);
2017     return E_NOTIMPL;
2018 }
2019
2020 static HRESULT WINAPI HTMLPrivateWindow_FindWindowByName(IHTMLPrivateWindow *iface, LPCWSTR name, IHTMLWindow2 **ret)
2021 {
2022     HTMLWindow *This = impl_from_IHTMLPrivateWindow(iface);
2023     FIXME("(%p)->(%s %p)\n", This, debugstr_w(name), ret);
2024     return E_NOTIMPL;
2025 }
2026
2027 static HRESULT WINAPI HTMLPrivateWindow_GetAddressBarUrl(IHTMLPrivateWindow *iface, BSTR *url)
2028 {
2029     HTMLWindow *This = impl_from_IHTMLPrivateWindow(iface);
2030     TRACE("(%p)->(%p)\n", This, url);
2031
2032     if(!url)
2033         return E_INVALIDARG;
2034
2035     *url = SysAllocString(This->url);
2036     return S_OK;
2037 }
2038
2039 static const IHTMLPrivateWindowVtbl HTMLPrivateWindowVtbl = {
2040     HTMLPrivateWindow_QueryInterface,
2041     HTMLPrivateWindow_AddRef,
2042     HTMLPrivateWindow_Release,
2043     HTMLPrivateWindow_SuperNavigate,
2044     HTMLPrivateWindow_GetPendingUrl,
2045     HTMLPrivateWindow_SetPICSTarget,
2046     HTMLPrivateWindow_PICSComplete,
2047     HTMLPrivateWindow_FindWindowByName,
2048     HTMLPrivateWindow_GetAddressBarUrl
2049 };
2050
2051 static inline HTMLWindow *impl_from_ITravelLogClient(ITravelLogClient *iface)
2052 {
2053     return CONTAINING_RECORD(iface, HTMLWindow, ITravelLogClient_iface);
2054 }
2055
2056 static HRESULT WINAPI TravelLogClient_QueryInterface(ITravelLogClient *iface, REFIID riid, void **ppv)
2057 {
2058     HTMLWindow *This = impl_from_ITravelLogClient(iface);
2059
2060     return IHTMLWindow2_QueryInterface(&This->IHTMLWindow2_iface, riid, ppv);
2061 }
2062
2063 static ULONG WINAPI TravelLogClient_AddRef(ITravelLogClient *iface)
2064 {
2065     HTMLWindow *This = impl_from_ITravelLogClient(iface);
2066
2067     return IHTMLWindow2_AddRef(&This->IHTMLWindow2_iface);
2068 }
2069
2070 static ULONG WINAPI TravelLogClient_Release(ITravelLogClient *iface)
2071 {
2072     HTMLWindow *This = impl_from_ITravelLogClient(iface);
2073
2074     return IHTMLWindow2_Release(&This->IHTMLWindow2_iface);
2075 }
2076
2077 static HRESULT WINAPI TravelLogClient_FindWindowByIndex(ITravelLogClient *iface, DWORD dwID, IUnknown **ppunk)
2078 {
2079     HTMLWindow *This = impl_from_ITravelLogClient(iface);
2080
2081     FIXME("(%p)->(%d %p) semi-stub\n", This, dwID, ppunk);
2082
2083     *ppunk = NULL;
2084     return E_FAIL;
2085 }
2086
2087 static HRESULT WINAPI TravelLogClient_GetWindowData(ITravelLogClient *iface, IStream *pStream, LPWINDOWDATA pWinData)
2088 {
2089     HTMLWindow *This = impl_from_ITravelLogClient(iface);
2090     FIXME("(%p)->(%p %p)\n", This, pStream, pWinData);
2091     return E_NOTIMPL;
2092 }
2093
2094 static HRESULT WINAPI TravelLogClient_LoadHistoryPosition(ITravelLogClient *iface, LPWSTR pszUrlLocation, DWORD dwPosition)
2095 {
2096     HTMLWindow *This = impl_from_ITravelLogClient(iface);
2097     FIXME("(%p)->(%s %d)\n", This, debugstr_w(pszUrlLocation), dwPosition);
2098     return E_NOTIMPL;
2099 }
2100
2101 static const ITravelLogClientVtbl TravelLogClientVtbl = {
2102     TravelLogClient_QueryInterface,
2103     TravelLogClient_AddRef,
2104     TravelLogClient_Release,
2105     TravelLogClient_FindWindowByIndex,
2106     TravelLogClient_GetWindowData,
2107     TravelLogClient_LoadHistoryPosition
2108 };
2109
2110 static inline HTMLWindow *impl_from_IDispatchEx(IDispatchEx *iface)
2111 {
2112     return CONTAINING_RECORD(iface, HTMLWindow, IDispatchEx_iface);
2113 }
2114
2115 static HRESULT WINAPI WindowDispEx_QueryInterface(IDispatchEx *iface, REFIID riid, void **ppv)
2116 {
2117     HTMLWindow *This = impl_from_IDispatchEx(iface);
2118
2119     return IHTMLWindow2_QueryInterface(&This->IHTMLWindow2_iface, riid, ppv);
2120 }
2121
2122 static ULONG WINAPI WindowDispEx_AddRef(IDispatchEx *iface)
2123 {
2124     HTMLWindow *This = impl_from_IDispatchEx(iface);
2125
2126     return IHTMLWindow2_AddRef(&This->IHTMLWindow2_iface);
2127 }
2128
2129 static ULONG WINAPI WindowDispEx_Release(IDispatchEx *iface)
2130 {
2131     HTMLWindow *This = impl_from_IDispatchEx(iface);
2132
2133     return IHTMLWindow2_Release(&This->IHTMLWindow2_iface);
2134 }
2135
2136 static HRESULT WINAPI WindowDispEx_GetTypeInfoCount(IDispatchEx *iface, UINT *pctinfo)
2137 {
2138     HTMLWindow *This = impl_from_IDispatchEx(iface);
2139
2140     TRACE("(%p)->(%p)\n", This, pctinfo);
2141
2142     return IDispatchEx_GetTypeInfoCount(&This->dispex.IDispatchEx_iface, pctinfo);
2143 }
2144
2145 static HRESULT WINAPI WindowDispEx_GetTypeInfo(IDispatchEx *iface, UINT iTInfo,
2146                                                LCID lcid, ITypeInfo **ppTInfo)
2147 {
2148     HTMLWindow *This = impl_from_IDispatchEx(iface);
2149
2150     TRACE("(%p)->(%u %u %p)\n", This, iTInfo, lcid, ppTInfo);
2151
2152     return IDispatchEx_GetTypeInfo(&This->dispex.IDispatchEx_iface, iTInfo, lcid, ppTInfo);
2153 }
2154
2155 static HRESULT WINAPI WindowDispEx_GetIDsOfNames(IDispatchEx *iface, REFIID riid,
2156                                                  LPOLESTR *rgszNames, UINT cNames,
2157                                                  LCID lcid, DISPID *rgDispId)
2158 {
2159     HTMLWindow *This = impl_from_IDispatchEx(iface);
2160     UINT i;
2161     HRESULT hres;
2162
2163     WARN("(%p)->(%s %p %u %u %p)\n", This, debugstr_guid(riid), rgszNames, cNames,
2164           lcid, rgDispId);
2165
2166     for(i=0; i < cNames; i++) {
2167         /* We shouldn't use script's IDispatchEx here, so we shouldn't use GetDispID */
2168         hres = IDispatchEx_GetDispID(&This->IDispatchEx_iface, rgszNames[i], 0, rgDispId+i);
2169         if(FAILED(hres))
2170             return hres;
2171     }
2172
2173     return S_OK;
2174 }
2175
2176 static HRESULT WINAPI WindowDispEx_Invoke(IDispatchEx *iface, DISPID dispIdMember,
2177                             REFIID riid, LCID lcid, WORD wFlags, DISPPARAMS *pDispParams,
2178                             VARIANT *pVarResult, EXCEPINFO *pExcepInfo, UINT *puArgErr)
2179 {
2180     HTMLWindow *This = impl_from_IDispatchEx(iface);
2181
2182     TRACE("(%p)->(%d %s %d %d %p %p %p %p)\n", This, dispIdMember, debugstr_guid(riid),
2183           lcid, wFlags, pDispParams, pVarResult, pExcepInfo, puArgErr);
2184
2185     /* FIXME: Use script dispatch */
2186
2187     return IDispatchEx_Invoke(&This->dispex.IDispatchEx_iface, dispIdMember, riid, lcid, wFlags,
2188             pDispParams, pVarResult, pExcepInfo, puArgErr);
2189 }
2190
2191 static global_prop_t *alloc_global_prop(HTMLWindow *This, global_prop_type_t type, BSTR name)
2192 {
2193     if(This->global_prop_cnt == This->global_prop_size) {
2194         global_prop_t *new_props;
2195         DWORD new_size;
2196
2197         if(This->global_props) {
2198             new_size = This->global_prop_size*2;
2199             new_props = heap_realloc(This->global_props, new_size*sizeof(global_prop_t));
2200         }else {
2201             new_size = 16;
2202             new_props = heap_alloc(new_size*sizeof(global_prop_t));
2203         }
2204         if(!new_props)
2205             return NULL;
2206         This->global_props = new_props;
2207         This->global_prop_size = new_size;
2208     }
2209
2210     This->global_props[This->global_prop_cnt].name = heap_strdupW(name);
2211     if(!This->global_props[This->global_prop_cnt].name)
2212         return NULL;
2213
2214     This->global_props[This->global_prop_cnt].type = type;
2215     return This->global_props + This->global_prop_cnt++;
2216 }
2217
2218 static inline DWORD prop_to_dispid(HTMLWindow *This, global_prop_t *prop)
2219 {
2220     return MSHTML_DISPID_CUSTOM_MIN + (prop-This->global_props);
2221 }
2222
2223 HRESULT search_window_props(HTMLWindow *This, BSTR bstrName, DWORD grfdex, DISPID *pid)
2224 {
2225     DWORD i;
2226     ScriptHost *script_host;
2227     DISPID id;
2228
2229     for(i=0; i < This->global_prop_cnt; i++) {
2230         /* FIXME: case sensitivity */
2231         if(!strcmpW(This->global_props[i].name, bstrName)) {
2232             *pid = MSHTML_DISPID_CUSTOM_MIN+i;
2233             return S_OK;
2234         }
2235     }
2236
2237     if(find_global_prop(This, bstrName, grfdex, &script_host, &id)) {
2238         global_prop_t *prop;
2239
2240         prop = alloc_global_prop(This, GLOBAL_SCRIPTVAR, bstrName);
2241         if(!prop)
2242             return E_OUTOFMEMORY;
2243
2244         prop->script_host = script_host;
2245         prop->id = id;
2246
2247         *pid = prop_to_dispid(This, prop);
2248         return S_OK;
2249     }
2250
2251     return DISP_E_UNKNOWNNAME;
2252 }
2253
2254 static HRESULT WINAPI WindowDispEx_GetDispID(IDispatchEx *iface, BSTR bstrName, DWORD grfdex, DISPID *pid)
2255 {
2256     HTMLWindow *This = impl_from_IDispatchEx(iface);
2257     HRESULT hres;
2258
2259     TRACE("(%p)->(%s %x %p)\n", This, debugstr_w(bstrName), grfdex, pid);
2260
2261     hres = search_window_props(This, bstrName, grfdex, pid);
2262     if(hres != DISP_E_UNKNOWNNAME)
2263         return hres;
2264
2265     hres = IDispatchEx_GetDispID(&This->dispex.IDispatchEx_iface, bstrName, grfdex, pid);
2266     if(hres != DISP_E_UNKNOWNNAME)
2267         return hres;
2268
2269     if(This->doc) {
2270         global_prop_t *prop;
2271         IHTMLElement *elem;
2272
2273         hres = IHTMLDocument3_getElementById(&This->doc->basedoc.IHTMLDocument3_iface,
2274                                              bstrName, &elem);
2275         if(SUCCEEDED(hres) && elem) {
2276             IHTMLElement_Release(elem);
2277
2278             prop = alloc_global_prop(This, GLOBAL_ELEMENTVAR, bstrName);
2279             if(!prop)
2280                 return E_OUTOFMEMORY;
2281
2282             *pid = prop_to_dispid(This, prop);
2283             return S_OK;
2284         }
2285     }
2286
2287     return DISP_E_UNKNOWNNAME;
2288 }
2289
2290 static HRESULT WINAPI WindowDispEx_InvokeEx(IDispatchEx *iface, DISPID id, LCID lcid, WORD wFlags, DISPPARAMS *pdp,
2291         VARIANT *pvarRes, EXCEPINFO *pei, IServiceProvider *pspCaller)
2292 {
2293     HTMLWindow *This = impl_from_IDispatchEx(iface);
2294
2295     TRACE("(%p)->(%x %x %x %p %p %p %p)\n", This, id, lcid, wFlags, pdp, pvarRes, pei, pspCaller);
2296
2297     if(id == DISPID_IHTMLWINDOW2_LOCATION && (wFlags & DISPATCH_PROPERTYPUT)) {
2298         HTMLLocation *location;
2299         HRESULT hres;
2300
2301         TRACE("forwarding to location.href\n");
2302
2303         hres = get_location(This, &location);
2304         if(FAILED(hres))
2305             return hres;
2306
2307         hres = IDispatchEx_InvokeEx(&location->dispex.IDispatchEx_iface, DISPID_VALUE, lcid,
2308                 wFlags, pdp, pvarRes, pei, pspCaller);
2309         IHTMLLocation_Release(&location->IHTMLLocation_iface);
2310         return hres;
2311     }
2312
2313     return IDispatchEx_InvokeEx(&This->dispex.IDispatchEx_iface, id, lcid, wFlags, pdp, pvarRes,
2314             pei, pspCaller);
2315 }
2316
2317 static HRESULT WINAPI WindowDispEx_DeleteMemberByName(IDispatchEx *iface, BSTR bstrName, DWORD grfdex)
2318 {
2319     HTMLWindow *This = impl_from_IDispatchEx(iface);
2320
2321     TRACE("(%p)->(%s %x)\n", This, debugstr_w(bstrName), grfdex);
2322
2323     return IDispatchEx_DeleteMemberByName(&This->dispex.IDispatchEx_iface, bstrName, grfdex);
2324 }
2325
2326 static HRESULT WINAPI WindowDispEx_DeleteMemberByDispID(IDispatchEx *iface, DISPID id)
2327 {
2328     HTMLWindow *This = impl_from_IDispatchEx(iface);
2329
2330     TRACE("(%p)->(%x)\n", This, id);
2331
2332     return IDispatchEx_DeleteMemberByDispID(&This->dispex.IDispatchEx_iface, id);
2333 }
2334
2335 static HRESULT WINAPI WindowDispEx_GetMemberProperties(IDispatchEx *iface, DISPID id, DWORD grfdexFetch, DWORD *pgrfdex)
2336 {
2337     HTMLWindow *This = impl_from_IDispatchEx(iface);
2338
2339     TRACE("(%p)->(%x %x %p)\n", This, id, grfdexFetch, pgrfdex);
2340
2341     return IDispatchEx_GetMemberProperties(&This->dispex.IDispatchEx_iface, id, grfdexFetch,
2342             pgrfdex);
2343 }
2344
2345 static HRESULT WINAPI WindowDispEx_GetMemberName(IDispatchEx *iface, DISPID id, BSTR *pbstrName)
2346 {
2347     HTMLWindow *This = impl_from_IDispatchEx(iface);
2348
2349     TRACE("(%p)->(%x %p)\n", This, id, pbstrName);
2350
2351     return IDispatchEx_GetMemberName(&This->dispex.IDispatchEx_iface, id, pbstrName);
2352 }
2353
2354 static HRESULT WINAPI WindowDispEx_GetNextDispID(IDispatchEx *iface, DWORD grfdex, DISPID id, DISPID *pid)
2355 {
2356     HTMLWindow *This = impl_from_IDispatchEx(iface);
2357
2358     TRACE("(%p)->(%x %x %p)\n", This, grfdex, id, pid);
2359
2360     return IDispatchEx_GetNextDispID(&This->dispex.IDispatchEx_iface, grfdex, id, pid);
2361 }
2362
2363 static HRESULT WINAPI WindowDispEx_GetNameSpaceParent(IDispatchEx *iface, IUnknown **ppunk)
2364 {
2365     HTMLWindow *This = impl_from_IDispatchEx(iface);
2366
2367     TRACE("(%p)->(%p)\n", This, ppunk);
2368
2369     *ppunk = NULL;
2370     return S_OK;
2371 }
2372
2373 static const IDispatchExVtbl WindowDispExVtbl = {
2374     WindowDispEx_QueryInterface,
2375     WindowDispEx_AddRef,
2376     WindowDispEx_Release,
2377     WindowDispEx_GetTypeInfoCount,
2378     WindowDispEx_GetTypeInfo,
2379     WindowDispEx_GetIDsOfNames,
2380     WindowDispEx_Invoke,
2381     WindowDispEx_GetDispID,
2382     WindowDispEx_InvokeEx,
2383     WindowDispEx_DeleteMemberByName,
2384     WindowDispEx_DeleteMemberByDispID,
2385     WindowDispEx_GetMemberProperties,
2386     WindowDispEx_GetMemberName,
2387     WindowDispEx_GetNextDispID,
2388     WindowDispEx_GetNameSpaceParent
2389 };
2390
2391 static inline HTMLWindow *impl_from_IServiceProvider(IServiceProvider *iface)
2392 {
2393     return CONTAINING_RECORD(iface, HTMLWindow, IServiceProvider_iface);
2394 }
2395
2396 static HRESULT WINAPI HTMLWindowSP_QueryInterface(IServiceProvider *iface, REFIID riid, void **ppv)
2397 {
2398     HTMLWindow *This = impl_from_IServiceProvider(iface);
2399     return IHTMLWindow2_QueryInterface(&This->IHTMLWindow2_iface, riid, ppv);
2400 }
2401
2402 static ULONG WINAPI HTMLWindowSP_AddRef(IServiceProvider *iface)
2403 {
2404     HTMLWindow *This = impl_from_IServiceProvider(iface);
2405     return IHTMLWindow2_AddRef(&This->IHTMLWindow2_iface);
2406 }
2407
2408 static ULONG WINAPI HTMLWindowSP_Release(IServiceProvider *iface)
2409 {
2410     HTMLWindow *This = impl_from_IServiceProvider(iface);
2411     return IHTMLWindow2_Release(&This->IHTMLWindow2_iface);
2412 }
2413
2414 static HRESULT WINAPI HTMLWindowSP_QueryService(IServiceProvider *iface, REFGUID guidService, REFIID riid, void **ppv)
2415 {
2416     HTMLWindow *This = impl_from_IServiceProvider(iface);
2417
2418     if(IsEqualGUID(guidService, &IID_IHTMLWindow2)) {
2419         TRACE("IID_IHTMLWindow2\n");
2420         return IHTMLWindow2_QueryInterface(&This->IHTMLWindow2_iface, riid, ppv);
2421     }
2422
2423     TRACE("(%p)->(%s %s %p)\n", This, debugstr_guid(guidService), debugstr_guid(riid), ppv);
2424
2425     if(!This->doc_obj)
2426         return E_NOINTERFACE;
2427
2428     return IServiceProvider_QueryService(&This->doc_obj->basedoc.IServiceProvider_iface,
2429             guidService, riid, ppv);
2430 }
2431
2432 static const IServiceProviderVtbl ServiceProviderVtbl = {
2433     HTMLWindowSP_QueryInterface,
2434     HTMLWindowSP_AddRef,
2435     HTMLWindowSP_Release,
2436     HTMLWindowSP_QueryService
2437 };
2438
2439 static inline HTMLWindow *impl_from_DispatchEx(DispatchEx *iface)
2440 {
2441     return CONTAINING_RECORD(iface, HTMLWindow, dispex);
2442 }
2443
2444 static HRESULT HTMLWindow_invoke(DispatchEx *dispex, DISPID id, LCID lcid, WORD flags, DISPPARAMS *params,
2445         VARIANT *res, EXCEPINFO *ei, IServiceProvider *caller)
2446 {
2447     HTMLWindow *This = impl_from_DispatchEx(dispex);
2448     global_prop_t *prop;
2449     DWORD idx;
2450     HRESULT hres;
2451
2452     idx = id - MSHTML_DISPID_CUSTOM_MIN;
2453     if(idx >= This->global_prop_cnt)
2454         return DISP_E_MEMBERNOTFOUND;
2455
2456     prop = This->global_props+idx;
2457
2458     switch(prop->type) {
2459     case GLOBAL_SCRIPTVAR: {
2460         IDispatchEx *iface;
2461         IDispatch *disp;
2462
2463         disp = get_script_disp(prop->script_host);
2464         if(!disp)
2465             return E_UNEXPECTED;
2466
2467         hres = IDispatch_QueryInterface(disp, &IID_IDispatchEx, (void**)&iface);
2468         if(SUCCEEDED(hres)) {
2469             TRACE("%s >>>\n", debugstr_w(prop->name));
2470             hres = IDispatchEx_InvokeEx(iface, prop->id, lcid, flags, params, res, ei, caller);
2471             if(hres == S_OK)
2472                 TRACE("%s <<<\n", debugstr_w(prop->name));
2473             else
2474                 WARN("%s <<< %08x\n", debugstr_w(prop->name), hres);
2475             IDispatchEx_Release(iface);
2476         }else {
2477             FIXME("No IDispatchEx\n");
2478         }
2479         IDispatch_Release(disp);
2480         break;
2481     }
2482     case GLOBAL_ELEMENTVAR: {
2483         IHTMLElement *elem;
2484
2485         hres = IHTMLDocument3_getElementById(&This->doc->basedoc.IHTMLDocument3_iface,
2486                                              prop->name, &elem);
2487         if(FAILED(hres))
2488             return hres;
2489
2490         if(!elem)
2491             return DISP_E_MEMBERNOTFOUND;
2492
2493         V_VT(res) = VT_DISPATCH;
2494         V_DISPATCH(res) = (IDispatch*)elem;
2495         break;
2496     }
2497     default:
2498         ERR("invalid type %d\n", prop->type);
2499         hres = DISP_E_MEMBERNOTFOUND;
2500     }
2501
2502     return hres;
2503 }
2504
2505
2506 static const dispex_static_data_vtbl_t HTMLWindow_dispex_vtbl = {
2507     NULL,
2508     NULL,
2509     HTMLWindow_invoke,
2510     NULL
2511 };
2512
2513 static const tid_t HTMLWindow_iface_tids[] = {
2514     IHTMLWindow2_tid,
2515     IHTMLWindow3_tid,
2516     IHTMLWindow4_tid,
2517     IHTMLWindow6_tid,
2518     0
2519 };
2520
2521 static dispex_static_data_t HTMLWindow_dispex = {
2522     &HTMLWindow_dispex_vtbl,
2523     DispHTMLWindow2_tid,
2524     NULL,
2525     HTMLWindow_iface_tids
2526 };
2527
2528 HRESULT HTMLWindow_Create(HTMLDocumentObj *doc_obj, nsIDOMWindow *nswindow, HTMLWindow *parent, HTMLWindow **ret)
2529 {
2530     HTMLWindow *window;
2531     HRESULT hres;
2532
2533     window = heap_alloc_zero(sizeof(HTMLWindow));
2534     if(!window)
2535         return E_OUTOFMEMORY;
2536
2537     window->window_ref = heap_alloc(sizeof(windowref_t));
2538     if(!window->window_ref) {
2539         heap_free(window);
2540         return E_OUTOFMEMORY;
2541     }
2542
2543     window->IHTMLWindow2_iface.lpVtbl = &HTMLWindow2Vtbl;
2544     window->IHTMLWindow3_iface.lpVtbl = &HTMLWindow3Vtbl;
2545     window->IHTMLWindow4_iface.lpVtbl = &HTMLWindow4Vtbl;
2546     window->IHTMLWindow5_iface.lpVtbl = &HTMLWindow5Vtbl;
2547     window->IHTMLWindow6_iface.lpVtbl = &HTMLWindow6Vtbl;
2548     window->IHTMLPrivateWindow_iface.lpVtbl = &HTMLPrivateWindowVtbl;
2549     window->IDispatchEx_iface.lpVtbl = &WindowDispExVtbl;
2550     window->IServiceProvider_iface.lpVtbl = &ServiceProviderVtbl;
2551     window->ITravelLogClient_iface.lpVtbl = &TravelLogClientVtbl;
2552     window->ref = 1;
2553     window->doc_obj = doc_obj;
2554
2555     window->window_ref->window = window;
2556     window->window_ref->ref = 1;
2557
2558     init_dispex(&window->dispex, (IUnknown*)&window->IHTMLWindow2_iface, &HTMLWindow_dispex);
2559
2560     if(nswindow) {
2561         nsIDOMWindow_AddRef(nswindow);
2562         window->nswindow = nswindow;
2563     }
2564
2565     window->scriptmode = parent ? parent->scriptmode : SCRIPTMODE_GECKO;
2566     window->readystate = READYSTATE_UNINITIALIZED;
2567     list_init(&window->script_hosts);
2568
2569     hres = CoInternetCreateSecurityManager(NULL, &window->secmgr, 0);
2570     if(FAILED(hres)) {
2571         IHTMLWindow2_Release(&window->IHTMLWindow2_iface);
2572         return hres;
2573     }
2574
2575     window->task_magic = get_task_target_magic();
2576     update_window_doc(window);
2577
2578     list_init(&window->children);
2579     list_add_head(&window_list, &window->entry);
2580
2581     if(parent) {
2582         IHTMLWindow2_AddRef(&window->IHTMLWindow2_iface);
2583
2584         window->parent = parent;
2585         list_add_tail(&parent->children, &window->sibling_entry);
2586     }
2587
2588     *ret = window;
2589     return S_OK;
2590 }
2591
2592 void update_window_doc(HTMLWindow *window)
2593 {
2594     nsIDOMHTMLDocument *nshtmldoc;
2595     nsIDOMDocument *nsdoc;
2596     nsresult nsres;
2597
2598     nsres = nsIDOMWindow_GetDocument(window->nswindow, &nsdoc);
2599     if(NS_FAILED(nsres) || !nsdoc) {
2600         ERR("GetDocument failed: %08x\n", nsres);
2601         return;
2602     }
2603
2604     nsres = nsIDOMDocument_QueryInterface(nsdoc, &IID_nsIDOMHTMLDocument, (void**)&nshtmldoc);
2605     nsIDOMDocument_Release(nsdoc);
2606     if(NS_FAILED(nsres)) {
2607         ERR("Could not get nsIDOMHTMLDocument iface: %08x\n", nsres);
2608         return;
2609     }
2610
2611     if(!window->doc || window->doc->nsdoc != nshtmldoc) {
2612         HTMLDocumentNode *doc;
2613         HRESULT hres;
2614
2615         hres = create_doc_from_nsdoc(nshtmldoc, window->doc_obj, window, &doc);
2616         if(SUCCEEDED(hres)) {
2617             window_set_docnode(window, doc);
2618             htmldoc_release(&doc->basedoc);
2619         }else {
2620             ERR("create_doc_from_nsdoc failed: %08x\n", hres);
2621         }
2622     }
2623
2624     nsIDOMHTMLDocument_Release(nshtmldoc);
2625 }
2626
2627 HTMLWindow *nswindow_to_window(const nsIDOMWindow *nswindow)
2628 {
2629     HTMLWindow *iter;
2630
2631     LIST_FOR_EACH_ENTRY(iter, &window_list, HTMLWindow, entry) {
2632         if(iter->nswindow == nswindow)
2633             return iter;
2634     }
2635
2636     return NULL;
2637 }