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