mshtml: Store HTMLDocument reference in HTMLSelectionObject.
[wine] / dlls / mshtml / htmldoc.c
1 /*
2  * Copyright 2005 Jacek Caban
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 "config.h"
20
21 #include <stdarg.h>
22 #include <stdio.h>
23
24 #define COBJMACROS
25
26 #include "windef.h"
27 #include "winbase.h"
28 #include "winuser.h"
29 #include "ole2.h"
30
31 #include "wine/debug.h"
32
33 #include "mshtml_private.h"
34
35 WINE_DEFAULT_DEBUG_CHANNEL(mshtml);
36
37 #define HTMLDOC_THIS(iface) DEFINE_THIS(HTMLDocument, HTMLDocument2, iface)
38
39 static HRESULT WINAPI HTMLDocument_QueryInterface(IHTMLDocument2 *iface, REFIID riid, void **ppvObject)
40 {
41     HTMLDocument *This = HTMLDOC_THIS(iface);
42
43     *ppvObject = NULL;
44     if(IsEqualGUID(&IID_IUnknown, riid)) {
45         TRACE("(%p)->(IID_IUnknown, %p)\n", This, ppvObject);
46         *ppvObject = HTMLDOC(This);
47     }else if(IsEqualGUID(&IID_IDispatch, riid)) {
48         TRACE("(%p)->(IID_IDispatch, %p)\n", This, ppvObject);
49         *ppvObject = HTMLDOC(This);
50     }else if(IsEqualGUID(&IID_IHTMLDocument, riid)) {
51         TRACE("(%p)->(IID_IHTMLDocument, %p)\n", This, ppvObject);
52         *ppvObject = HTMLDOC(This);
53     }else if(IsEqualGUID(&IID_IHTMLDocument2, riid)) {
54         TRACE("(%p)->(IID_IHTMLDocument2, %p)\n", This, ppvObject);
55         *ppvObject = HTMLDOC(This);
56     }else if(IsEqualGUID(&IID_IHTMLDocument3, riid)) {
57         TRACE("(%p)->(IID_IHTMLDocument3, %p)\n", This, ppvObject);
58         *ppvObject = HTMLDOC3(This);
59     }else if(IsEqualGUID(&IID_IPersist, riid)) {
60         TRACE("(%p)->(IID_IPersist, %p)\n", This, ppvObject);
61         *ppvObject = PERSIST(This);
62     }else if(IsEqualGUID(&IID_IPersistMoniker, riid)) {
63         TRACE("(%p)->(IID_IPersistMoniker, %p)\n", This, ppvObject);
64         *ppvObject = PERSISTMON(This);
65     }else if(IsEqualGUID(&IID_IPersistFile, riid)) {
66         TRACE("(%p)->(IID_IPersistFile, %p)\n", This, ppvObject);
67         *ppvObject = PERSISTFILE(This);
68     }else if(IsEqualGUID(&IID_IMonikerProp, riid)) {
69         TRACE("(%p)->(IID_IMonikerProp, %p)\n", This, ppvObject);
70         *ppvObject = MONPROP(This);
71     }else if(IsEqualGUID(&IID_IOleObject, riid)) {
72         TRACE("(%p)->(IID_IOleObject, %p)\n", This, ppvObject);
73         *ppvObject = OLEOBJ(This);
74     }else if(IsEqualGUID(&IID_IOleDocument, riid)) {
75         TRACE("(%p)->(IID_IOleDocument, %p)\n", This, ppvObject);
76         *ppvObject = OLEDOC(This);
77     }else if(IsEqualGUID(&IID_IOleDocumentView, riid)) {
78         TRACE("(%p)->(IID_IOleDocumentView, %p)\n", This, ppvObject);
79         *ppvObject = DOCVIEW(This);
80     }else if(IsEqualGUID(&IID_IOleInPlaceActiveObject, riid)) {
81         TRACE("(%p)->(IID_IOleInPlaceActiveObject, %p)\n", This, ppvObject);
82         *ppvObject = ACTOBJ(This);
83     }else if(IsEqualGUID(&IID_IViewObject, riid)) {
84         TRACE("(%p)->(IID_IViewObject, %p)\n", This, ppvObject);
85         *ppvObject = VIEWOBJ(This);
86     }else if(IsEqualGUID(&IID_IViewObject2, riid)) {
87         TRACE("(%p)->(IID_IViewObject2, %p)\n", This, ppvObject);
88         *ppvObject = VIEWOBJ2(This);
89     }else if(IsEqualGUID(&IID_IOleWindow, riid)) {
90         TRACE("(%p)->(IID_IOleWindow, %p)\n", This, ppvObject);
91         *ppvObject = OLEWIN(This);
92     }else if(IsEqualGUID(&IID_IOleInPlaceObject, riid)) {
93         TRACE("(%p)->(IID_IOleInPlaceObject, %p)\n", This, ppvObject);
94         *ppvObject = INPLACEOBJ(This);
95     }else if(IsEqualGUID(&IID_IOleInPlaceObjectWindowless, riid)) {
96         TRACE("(%p)->(IID_IOleInPlaceObjectWindowless, %p)\n", This, ppvObject);
97         *ppvObject = INPLACEWIN(This);
98     }else if(IsEqualGUID(&IID_IServiceProvider, riid)) {
99         TRACE("(%p)->(IID_IServiceProvider, %p)\n", This, ppvObject);
100         *ppvObject = SERVPROV(This);
101     }else if(IsEqualGUID(&IID_IOleCommandTarget, riid)) {
102         TRACE("(%p)->(IID_IOleCommandTarget, %p)\n", This, ppvObject);
103         *ppvObject = CMDTARGET(This);
104     }else if(IsEqualGUID(&IID_IOleControl, riid)) {
105         TRACE("(%p)->(IID_IOleControl, %p)\n", This, ppvObject);
106         *ppvObject = CONTROL(This);
107     }else if(IsEqualGUID(&IID_IHlinkTarget, riid)) {
108         TRACE("(%p)->(IID_IHlinkTarget, %p)\n", This, ppvObject);
109         *ppvObject = HLNKTARGET(This);
110     }else if(IsEqualGUID(&IID_IConnectionPointContainer, riid)) {
111         TRACE("(%p)->(IID_IConnectionPointContainer %p)\n", This, ppvObject);
112         *ppvObject = CONPTCONT(&This->cp_container);
113     }else if(IsEqualGUID(&IID_IPersistStreamInit, riid)) {
114         TRACE("(%p)->(IID_IPersistStreamInit %p)\n", This, ppvObject);
115         *ppvObject = PERSTRINIT(This);
116     }else if(IsEqualGUID(&IID_ICustomDoc, riid)) {
117         TRACE("(%p)->(IID_ICustomDoc %p)\n", This, ppvObject);
118         *ppvObject = CUSTOMDOC(This);
119     }else if(IsEqualGUID(&DIID_DispHTMLDocument, riid)) {
120         TRACE("(%p)->(DIID_DispHTMLDocument %p)\n", This, ppvObject);
121         *ppvObject = HTMLDOC(This);
122     }else if(IsEqualGUID(&CLSID_CMarkup, riid)) {
123         FIXME("(%p)->(CLSID_CMarkup %p)\n", This, ppvObject);
124         return E_NOINTERFACE;
125     }else if(IsEqualGUID(&IID_IRunnableObject, riid)) {
126         TRACE("(%p)->(IID_IRunnableObject %p) returning NULL\n", This, ppvObject);
127         return E_NOINTERFACE;
128     }
129
130     if(*ppvObject) {
131         IHTMLDocument2_AddRef(iface);
132         return S_OK;
133     }
134
135     FIXME("(%p)->(%s %p) interface not supported\n", This, debugstr_guid(riid), ppvObject);
136     return E_NOINTERFACE;
137 }
138
139 static ULONG WINAPI HTMLDocument_AddRef(IHTMLDocument2 *iface)
140 {
141     HTMLDocument *This = HTMLDOC_THIS(iface);
142     ULONG ref = InterlockedIncrement(&This->ref);
143     TRACE("(%p) ref = %u\n", This, ref);
144     return ref;
145 }
146
147 static ULONG WINAPI HTMLDocument_Release(IHTMLDocument2 *iface)
148 {
149     HTMLDocument *This = HTMLDOC_THIS(iface);
150     ULONG ref = InterlockedDecrement(&This->ref);
151
152     TRACE("(%p) ref = %u\n", This, ref);
153
154     if(!ref) {
155         remove_doc_tasks(This);
156
157         if(This->client)
158             IOleObject_SetClientSite(OLEOBJ(This), NULL);
159         if(This->in_place_active)
160             IOleInPlaceObjectWindowless_InPlaceDeactivate(INPLACEWIN(This));
161         if(This->ipsite)
162             IOleDocumentView_SetInPlaceSite(DOCVIEW(This), NULL);
163
164         set_document_bscallback(This, NULL);
165         set_current_mon(This, NULL);
166
167         if(This->tooltips_hwnd)
168             DestroyWindow(This->tooltips_hwnd);
169         if(This->hwnd)
170             DestroyWindow(This->hwnd);
171
172         if(This->window)
173             IHTMLWindow2_Release(HTMLWINDOW2(This->window));
174
175         detach_selection(This);
176         release_nodes(This);
177
178         ConnectionPointContainer_Destroy(&This->cp_container);
179
180         if(This->nscontainer)
181             NSContainer_Release(This->nscontainer);
182
183         mshtml_free(This);
184
185         UNLOCK_MODULE();
186     }
187
188     return ref;
189 }
190
191 static HRESULT WINAPI HTMLDocument_GetTypeInfoCount(IHTMLDocument2 *iface, UINT *pctinfo)
192 {
193     FIXME("(%p)->(%p)\n", iface, pctinfo);
194     return E_NOTIMPL;
195 }
196
197 static HRESULT WINAPI HTMLDocument_GetTypeInfo(IHTMLDocument2 *iface, UINT iTInfo,
198                                                 LCID lcid, ITypeInfo **ppTInfo)
199 {
200     FIXME("(%p)->(%u %u %p)\n", iface, iTInfo, lcid, ppTInfo);
201     return E_NOTIMPL;
202 }
203
204 static HRESULT WINAPI HTMLDocument_GetIDsOfNames(IHTMLDocument2 *iface, REFIID riid,
205                                                 LPOLESTR *rgszNames, UINT cNames,
206                                                 LCID lcid, DISPID *rgDispId)
207 {
208     FIXME("(%p)->(%s %p %u %u %p)\n", iface, debugstr_guid(riid), rgszNames, cNames,
209                                         lcid, rgDispId);
210     return E_NOTIMPL;
211 }
212
213 static HRESULT WINAPI HTMLDocument_Invoke(IHTMLDocument2 *iface, DISPID dispIdMember,
214                             REFIID riid, LCID lcid, WORD wFlags, DISPPARAMS *pDispParams,
215                             VARIANT *pVarResult, EXCEPINFO *pExcepInfo, UINT *puArgErr)
216 {
217     FIXME("(%p)->(%d %s %d %d %p %p %p %p)\n", iface, dispIdMember, debugstr_guid(riid),
218             lcid, wFlags, pDispParams, pVarResult, pExcepInfo, puArgErr);
219     return E_NOTIMPL;
220 }
221
222 static HRESULT WINAPI HTMLDocument_get_Script(IHTMLDocument2 *iface, IDispatch **p)
223 {
224     FIXME("(%p)->(%p)\n", iface, p);
225     return E_NOTIMPL;
226 }
227
228 static HRESULT WINAPI HTMLDocument_get_all(IHTMLDocument2 *iface, IHTMLElementCollection **p)
229 {
230     HTMLDocument *This = HTMLDOC_THIS(iface);
231     IHTMLElement *doc;
232     IDispatch *disp;
233     HRESULT hres;
234
235     TRACE("(%p)->(%p)\n", This, p);
236
237     hres = IHTMLDocument3_get_documentElement(HTMLDOC3(This), &doc);
238     if(FAILED(hres))
239         return hres;
240
241     hres = IHTMLElement_get_all(doc, &disp);
242     IHTMLElement_Release(doc);
243     if(FAILED(hres))
244         return hres;
245
246     hres = IDispatch_QueryInterface(disp, &IID_IHTMLElementCollection, (void**)p);
247     IDispatch_Release(disp);
248
249     return hres;
250 }
251
252 static HRESULT WINAPI HTMLDocument_get_body(IHTMLDocument2 *iface, IHTMLElement **p)
253 {
254     HTMLDocument *This = HTMLDOC_THIS(iface);
255     nsIDOMDocument *nsdoc;
256     nsIDOMHTMLDocument *nshtmldoc;
257     nsIDOMHTMLElement *nsbody = NULL;
258     HTMLDOMNode *node;
259     nsresult nsres;
260
261     TRACE("(%p)->(%p)\n", This, p);
262
263     *p = NULL;
264
265     if(!This->nscontainer)
266         return S_OK;
267
268     nsres = nsIWebNavigation_GetDocument(This->nscontainer->navigation, &nsdoc);
269     if(NS_FAILED(nsres)) {
270         ERR("GetDocument failed: %08x\n", nsres);
271         return S_OK;
272     }
273
274     if(NS_FAILED(nsres) || !nsdoc) 
275         return S_OK;
276
277     nsIDOMDocument_QueryInterface(nsdoc, &IID_nsIDOMHTMLDocument, (void**)&nshtmldoc);
278     nsIDOMDocument_Release(nsdoc);
279
280     nsres = nsIDOMHTMLDocument_GetBody(nshtmldoc, &nsbody);
281     nsIDOMHTMLDocument_Release(nshtmldoc);
282
283     if(NS_FAILED(nsres) || !nsbody) {
284         TRACE("Could not get body: %08x\n", nsres);
285         return S_OK;
286     }
287
288     node = get_node(This, (nsIDOMNode*)nsbody);
289     nsIDOMHTMLElement_Release(nsbody);
290
291     IHTMLDOMNode_QueryInterface(HTMLDOMNODE(node), &IID_IHTMLElement, (void**)p);
292
293     TRACE("*p = %p\n", *p);
294     return S_OK;
295 }
296
297 static HRESULT WINAPI HTMLDocument_get_activeElement(IHTMLDocument2 *iface, IHTMLElement **p)
298 {
299     FIXME("(%p)->(%p)\n", iface, p);
300     return E_NOTIMPL;
301 }
302
303 static HRESULT WINAPI HTMLDocument_get_images(IHTMLDocument2 *iface, IHTMLElementCollection **p)
304 {
305     FIXME("(%p)->(%p)\n", iface, p);
306     return E_NOTIMPL;
307 }
308
309 static HRESULT WINAPI HTMLDocument_get_applets(IHTMLDocument2 *iface, IHTMLElementCollection **p)
310 {
311     FIXME("(%p)->(%p)\n", iface, p);
312     return E_NOTIMPL;
313 }
314
315 static HRESULT WINAPI HTMLDocument_get_links(IHTMLDocument2 *iface, IHTMLElementCollection **p)
316 {
317     FIXME("(%p)->(%p)\n", iface, p);
318     return E_NOTIMPL;
319 }
320
321 static HRESULT WINAPI HTMLDocument_get_forms(IHTMLDocument2 *iface, IHTMLElementCollection **p)
322 {
323     FIXME("(%p)->(%p)\n", iface, p);
324     return E_NOTIMPL;
325 }
326
327 static HRESULT WINAPI HTMLDocument_get_anchors(IHTMLDocument2 *iface, IHTMLElementCollection **p)
328 {
329     FIXME("(%p)->(%p)\n", iface, p);
330     return E_NOTIMPL;
331 }
332
333 static HRESULT WINAPI HTMLDocument_put_title(IHTMLDocument2 *iface, BSTR v)
334 {
335     FIXME("(%p)->(%s)\n", iface, debugstr_w(v));
336     return E_NOTIMPL;
337 }
338
339 static HRESULT WINAPI HTMLDocument_get_title(IHTMLDocument2 *iface, BSTR *p)
340 {
341     FIXME("(%p)->(%p)\n", iface, p);
342     return E_NOTIMPL;
343 }
344
345 static HRESULT WINAPI HTMLDocument_get_scripts(IHTMLDocument2 *iface, IHTMLElementCollection **p)
346 {
347     FIXME("(%p)->(%p)\n", iface, p);
348     return E_NOTIMPL;
349 }
350
351 static HRESULT WINAPI HTMLDocument_put_designMode(IHTMLDocument2 *iface, BSTR v)
352 {
353     FIXME("(%p)->(%s)\n", iface, debugstr_w(v));
354     return E_NOTIMPL;
355 }
356
357 static HRESULT WINAPI HTMLDocument_get_designMode(IHTMLDocument2 *iface, BSTR *p)
358 {
359     FIXME("(%p)->(%p)\n", iface, p);
360     return E_NOTIMPL;
361 }
362
363 static HRESULT WINAPI HTMLDocument_get_selection(IHTMLDocument2 *iface, IHTMLSelectionObject **p)
364 {
365     HTMLDocument *This = HTMLDOC_THIS(iface);
366     nsISelection *nsselection = NULL;
367
368     TRACE("(%p)->(%p)\n", This, p);
369
370     if(This->nscontainer) {
371         nsIDOMWindow *dom_window = NULL;
372
373         nsIWebBrowser_GetContentDOMWindow(This->nscontainer->webbrowser, &dom_window);
374         if(dom_window) {
375             nsIDOMWindow_GetSelection(dom_window, &nsselection);
376             nsIDOMWindow_Release(dom_window);
377         }
378     }
379
380     *p = HTMLSelectionObject_Create(This, nsselection);
381     return S_OK;
382 }
383
384 static HRESULT WINAPI HTMLDocument_get_readyState(IHTMLDocument2 *iface, BSTR *p)
385 {
386     HTMLDocument *This = HTMLDOC_THIS(iface);
387
388     static const WCHAR wszUninitialized[] = {'u','n','i','n','i','t','i','a','l','i','z','e','d',0};
389     static const WCHAR wszLoading[] = {'l','o','a','d','i','n','g',0};
390     static const WCHAR wszLoaded[] = {'l','o','a','d','e','d',0};
391     static const WCHAR wszInteractive[] = {'i','n','t','e','r','a','c','t','i','v','e',0};
392     static const WCHAR wszComplete[] = {'c','o','m','p','l','e','t','e',0};
393
394     static const LPCWSTR readystate_str[] = {
395         wszUninitialized,
396         wszLoading,
397         wszLoaded,
398         wszInteractive,
399         wszComplete
400     };
401
402     TRACE("(%p)->(%p)\n", iface, p);
403
404     if(!p)
405         return E_POINTER;
406
407     *p = SysAllocString(readystate_str[This->readystate]);
408     return S_OK;
409 }
410
411 static HRESULT WINAPI HTMLDocument_get_frames(IHTMLDocument2 *iface, IHTMLFramesCollection2 **p)
412 {
413     FIXME("(%p)->(%p)\n", iface, p);
414     return E_NOTIMPL;
415 }
416
417 static HRESULT WINAPI HTMLDocument_get_embeds(IHTMLDocument2 *iface, IHTMLElementCollection **p)
418 {
419     FIXME("(%p)->(%p)\n", iface, p);
420     return E_NOTIMPL;
421 }
422
423 static HRESULT WINAPI HTMLDocument_get_plugins(IHTMLDocument2 *iface, IHTMLElementCollection **p)
424 {
425     FIXME("(%p)->(%p)\n", iface, p);
426     return E_NOTIMPL;
427 }
428
429 static HRESULT WINAPI HTMLDocument_put_alinkColor(IHTMLDocument2 *iface, VARIANT v)
430 {
431     FIXME("(%p)\n", iface);
432     return E_NOTIMPL;
433 }
434
435 static HRESULT WINAPI HTMLDocument_get_alinkColor(IHTMLDocument2 *iface, VARIANT *p)
436 {
437     FIXME("(%p)->(%p)\n", iface, p);
438     return E_NOTIMPL;
439 }
440
441 static HRESULT WINAPI HTMLDocument_put_bgColor(IHTMLDocument2 *iface, VARIANT v)
442 {
443     FIXME("(%p)\n", iface);
444     return E_NOTIMPL;
445 }
446
447 static HRESULT WINAPI HTMLDocument_get_bgColor(IHTMLDocument2 *iface, VARIANT *p)
448 {
449     FIXME("(%p)->(%p)\n", iface, p);
450     return E_NOTIMPL;
451 }
452
453 static HRESULT WINAPI HTMLDocument_put_fgColor(IHTMLDocument2 *iface, VARIANT v)
454 {
455     FIXME("(%p)\n", iface);
456     return E_NOTIMPL;
457 }
458
459 static HRESULT WINAPI HTMLDocument_get_fgColor(IHTMLDocument2 *iface, VARIANT *p)
460 {
461     FIXME("(%p)->(%p)\n", iface, p);
462     return E_NOTIMPL;
463 }
464
465 static HRESULT WINAPI HTMLDocument_put_linkColor(IHTMLDocument2 *iface, VARIANT v)
466 {
467     FIXME("(%p)->()\n", iface);
468     return E_NOTIMPL;
469 }
470
471 static HRESULT WINAPI HTMLDocument_get_linkColor(IHTMLDocument2 *iface, VARIANT *p)
472 {
473     FIXME("(%p)->(%p)\n", iface, p);
474     return E_NOTIMPL;
475 }
476
477 static HRESULT WINAPI HTMLDocument_put_vlinkColor(IHTMLDocument2 *iface, VARIANT v)
478 {
479     FIXME("(%p)\n", iface);
480     return E_NOTIMPL;
481 }
482
483 static HRESULT WINAPI HTMLDocument_get_vlinkColor(IHTMLDocument2 *iface, VARIANT *p)
484 {
485     FIXME("(%p)->(%p)\n", iface, p);
486     return E_NOTIMPL;
487 }
488
489 static HRESULT WINAPI HTMLDocument_get_referrer(IHTMLDocument2 *iface, BSTR *p)
490 {
491     FIXME("(%p)->(%p)\n", iface, p);
492     return E_NOTIMPL;
493 }
494
495 static HRESULT WINAPI HTMLDocument_get_location(IHTMLDocument2 *iface, IHTMLLocation **p)
496 {
497     FIXME("(%p)->(%p)\n", iface, p);
498     return E_NOTIMPL;
499 }
500
501 static HRESULT WINAPI HTMLDocument_get_lastModified(IHTMLDocument2 *iface, BSTR *p)
502 {
503     FIXME("(%p)->(%p)\n", iface, p);
504     return E_NOTIMPL;
505 }
506
507 static HRESULT WINAPI HTMLDocument_put_URL(IHTMLDocument2 *iface, BSTR v)
508 {
509     FIXME("(%p)->(%s)\n", iface, debugstr_w(v));
510     return E_NOTIMPL;
511 }
512
513 static HRESULT WINAPI HTMLDocument_get_URL(IHTMLDocument2 *iface, BSTR *p)
514 {
515     HTMLDocument *This = HTMLDOC_THIS(iface);
516
517     static const WCHAR about_blank_url[] =
518         {'a','b','o','u','t',':','b','l','a','n','k',0};
519
520     TRACE("(%p)->(%p)\n", iface, p);
521
522     *p = SysAllocString(This->url ? This->url : about_blank_url);
523     return S_OK;
524 }
525
526 static HRESULT WINAPI HTMLDocument_put_domain(IHTMLDocument2 *iface, BSTR v)
527 {
528     FIXME("(%p)->(%s)\n", iface, debugstr_w(v));
529     return E_NOTIMPL;
530 }
531
532 static HRESULT WINAPI HTMLDocument_get_domain(IHTMLDocument2 *iface, BSTR *p)
533 {
534     FIXME("(%p)->(%p)\n", iface, p);
535     return E_NOTIMPL;
536 }
537
538 static HRESULT WINAPI HTMLDocument_put_cookie(IHTMLDocument2 *iface, BSTR v)
539 {
540     FIXME("(%p)->(%s)\n", iface, debugstr_w(v));
541     return E_NOTIMPL;
542 }
543
544 static HRESULT WINAPI HTMLDocument_get_cookie(IHTMLDocument2 *iface, BSTR *p)
545 {
546     FIXME("(%p)->(%p)\n", iface, p);
547     return E_NOTIMPL;
548 }
549
550 static HRESULT WINAPI HTMLDocument_put_expando(IHTMLDocument2 *iface, VARIANT_BOOL v)
551 {
552     FIXME("(%p)->(%x)\n", iface, v);
553     return E_NOTIMPL;
554 }
555
556 static HRESULT WINAPI HTMLDocument_get_expando(IHTMLDocument2 *iface, VARIANT_BOOL *p)
557 {
558     FIXME("(%p)->(%p)\n", iface, p);
559     return E_NOTIMPL;
560 }
561
562 static HRESULT WINAPI HTMLDocument_put_charset(IHTMLDocument2 *iface, BSTR v)
563 {
564     FIXME("(%p)->(%s)\n", iface, debugstr_w(v));
565     return E_NOTIMPL;
566 }
567
568 static HRESULT WINAPI HTMLDocument_get_charset(IHTMLDocument2 *iface, BSTR *p)
569 {
570     FIXME("(%p)->(%p)\n", iface, p);
571     return E_NOTIMPL;
572 }
573
574 static HRESULT WINAPI HTMLDocument_put_defaultCharset(IHTMLDocument2 *iface, BSTR v)
575 {
576     FIXME("(%p)->(%s)\n", iface, debugstr_w(v));
577     return E_NOTIMPL;
578 }
579
580 static HRESULT WINAPI HTMLDocument_get_defaultCharset(IHTMLDocument2 *iface, BSTR *p)
581 {
582     FIXME("(%p)->(%p)\n", iface, p);
583     return E_NOTIMPL;
584 }
585
586 static HRESULT WINAPI HTMLDocument_get_mimeType(IHTMLDocument2 *iface, BSTR *p)
587 {
588     FIXME("(%p)->(%p)\n", iface, p);
589     return E_NOTIMPL;
590 }
591
592 static HRESULT WINAPI HTMLDocument_get_fileSize(IHTMLDocument2 *iface, BSTR *p)
593 {
594     FIXME("(%p)->(%p)\n", iface, p);
595     return E_NOTIMPL;
596 }
597
598 static HRESULT WINAPI HTMLDocument_get_fileCreatedDate(IHTMLDocument2 *iface, BSTR *p)
599 {
600     FIXME("(%p)->(%p)\n", iface, p);
601     return E_NOTIMPL;
602 }
603
604 static HRESULT WINAPI HTMLDocument_get_fileModifiedDate(IHTMLDocument2 *iface, BSTR *p)
605 {
606     FIXME("(%p)->(%p)\n", iface, p);
607     return E_NOTIMPL;
608 }
609
610 static HRESULT WINAPI HTMLDocument_get_fileUpdatedDate(IHTMLDocument2 *iface, BSTR *p)
611 {
612     FIXME("(%p)->(%p)\n", iface, p);
613     return E_NOTIMPL;
614 }
615
616 static HRESULT WINAPI HTMLDocument_get_security(IHTMLDocument2 *iface, BSTR *p)
617 {
618     FIXME("(%p)->(%p)\n", iface, p);
619     return E_NOTIMPL;
620 }
621
622 static HRESULT WINAPI HTMLDocument_get_protocol(IHTMLDocument2 *iface, BSTR *p)
623 {
624     FIXME("(%p)->(%p)\n", iface, p);
625     return E_NOTIMPL;
626 }
627
628 static HRESULT WINAPI HTMLDocument_get_nameProp(IHTMLDocument2 *iface, BSTR *p)
629 {
630     FIXME("(%p)->(%p)\n", iface, p);
631     return E_NOTIMPL;
632 }
633
634 static HRESULT WINAPI HTMLDocument_write(IHTMLDocument2 *iface, SAFEARRAY *psarray)
635 {
636     FIXME("(%p)->(%p)\n", iface, psarray);
637     return E_NOTIMPL;
638 }
639
640 static HRESULT WINAPI HTMLDocument_writeln(IHTMLDocument2 *iface, SAFEARRAY *psarray)
641 {
642     FIXME("(%p)->(%p)\n", iface, psarray);
643     return E_NOTIMPL;
644 }
645
646 static HRESULT WINAPI HTMLDocument_open(IHTMLDocument2 *iface, BSTR url, VARIANT name,
647                         VARIANT features, VARIANT replace, IDispatch **pomWindowResult)
648 {
649     FIXME("(%p)->(%s %p)\n", iface, debugstr_w(url), pomWindowResult);
650     return E_NOTIMPL;
651 }
652
653 static HRESULT WINAPI HTMLDocument_close(IHTMLDocument2 *iface)
654 {
655     FIXME("(%p)\n", iface);
656     return E_NOTIMPL;
657 }
658
659 static HRESULT WINAPI HTMLDocument_clear(IHTMLDocument2 *iface)
660 {
661     FIXME("(%p)\n", iface);
662     return E_NOTIMPL;
663 }
664
665 static HRESULT WINAPI HTMLDocument_queryCommandSupported(IHTMLDocument2 *iface, BSTR cmdID,
666                                                         VARIANT_BOOL *pfRet)
667 {
668     FIXME("(%p)->(%s %p)\n", iface, debugstr_w(cmdID), pfRet);
669     return E_NOTIMPL;
670 }
671
672 static HRESULT WINAPI HTMLDocument_queryCommandEnabled(IHTMLDocument2 *iface, BSTR cmdID,
673                                                         VARIANT_BOOL *pfRet)
674 {
675     FIXME("(%p)->(%s %p)\n", iface, debugstr_w(cmdID), pfRet);
676     return E_NOTIMPL;
677 }
678
679 static HRESULT WINAPI HTMLDocument_queryCommandState(IHTMLDocument2 *iface, BSTR cmdID,
680                                                         VARIANT_BOOL *pfRet)
681 {
682     FIXME("(%p)->(%s %p)\n", iface, debugstr_w(cmdID), pfRet);
683     return E_NOTIMPL;
684 }
685
686 static HRESULT WINAPI HTMLDocument_queryCommandIndeterm(IHTMLDocument2 *iface, BSTR cmdID,
687                                                         VARIANT_BOOL *pfRet)
688 {
689     FIXME("(%p)->(%s %p)\n", iface, debugstr_w(cmdID), pfRet);
690     return E_NOTIMPL;
691 }
692
693 static HRESULT WINAPI HTMLDocument_queryCommandText(IHTMLDocument2 *iface, BSTR cmdID,
694                                                         BSTR *pfRet)
695 {
696     FIXME("(%p)->(%s %p)\n", iface, debugstr_w(cmdID), pfRet);
697     return E_NOTIMPL;
698 }
699
700 static HRESULT WINAPI HTMLDocument_queryCommandValue(IHTMLDocument2 *iface, BSTR cmdID,
701                                                         VARIANT *pfRet)
702 {
703     FIXME("(%p)->(%s %p)\n", iface, debugstr_w(cmdID), pfRet);
704     return E_NOTIMPL;
705 }
706
707 static HRESULT WINAPI HTMLDocument_execCommand(IHTMLDocument2 *iface, BSTR cmdID,
708                                 VARIANT_BOOL showUI, VARIANT value, VARIANT_BOOL *pfRet)
709 {
710     FIXME("(%p)->(%s %x %p)\n", iface, debugstr_w(cmdID), showUI, pfRet);
711     return E_NOTIMPL;
712 }
713
714 static HRESULT WINAPI HTMLDocument_execCommandShowHelp(IHTMLDocument2 *iface, BSTR cmdID,
715                                                         VARIANT_BOOL *pfRet)
716 {
717     FIXME("(%p)->(%s %p)\n", iface, debugstr_w(cmdID), pfRet);
718     return E_NOTIMPL;
719 }
720
721 static HRESULT WINAPI HTMLDocument_createElement(IHTMLDocument2 *iface, BSTR eTag,
722                                                     IHTMLElement **newElem)
723 {
724     FIXME("(%p)->(%s %p)\n", iface, debugstr_w(eTag), newElem);
725     return E_NOTIMPL;
726 }
727
728 static HRESULT WINAPI HTMLDocument_put_onhelp(IHTMLDocument2 *iface, VARIANT v)
729 {
730     FIXME("(%p)\n", iface);
731     return E_NOTIMPL;
732 }
733
734 static HRESULT WINAPI HTMLDocument_get_onhelp(IHTMLDocument2 *iface, VARIANT *p)
735 {
736     FIXME("(%p)->(%p)\n", iface, p);
737     return E_NOTIMPL;
738 }
739
740 static HRESULT WINAPI HTMLDocument_put_onclick(IHTMLDocument2 *iface, VARIANT v)
741 {
742     FIXME("(%p)\n", iface);
743     return E_NOTIMPL;
744 }
745
746 static HRESULT WINAPI HTMLDocument_get_onclick(IHTMLDocument2 *iface, VARIANT *p)
747 {
748     FIXME("(%p)->(%p)\n", iface, p);
749     return E_NOTIMPL;
750 }
751
752 static HRESULT WINAPI HTMLDocument_put_ondblclick(IHTMLDocument2 *iface, VARIANT v)
753 {
754     FIXME("(%p)\n", iface);
755     return E_NOTIMPL;
756 }
757
758 static HRESULT WINAPI HTMLDocument_get_ondblclick(IHTMLDocument2 *iface, VARIANT *p)
759 {
760     FIXME("(%p)->(%p)\n", iface, p);
761     return E_NOTIMPL;
762 }
763
764 static HRESULT WINAPI HTMLDocument_put_onkeyup(IHTMLDocument2 *iface, VARIANT v)
765 {
766     FIXME("(%p)\n", iface);
767     return E_NOTIMPL;
768 }
769
770 static HRESULT WINAPI HTMLDocument_get_onkeyup(IHTMLDocument2 *iface, VARIANT *p)
771 {
772     FIXME("(%p)->(%p)\n", iface, p);
773     return E_NOTIMPL;
774 }
775
776 static HRESULT WINAPI HTMLDocument_put_onkeydown(IHTMLDocument2 *iface, VARIANT v)
777 {
778     FIXME("(%p)\n", iface);
779     return E_NOTIMPL;
780 }
781
782 static HRESULT WINAPI HTMLDocument_get_onkeydown(IHTMLDocument2 *iface, VARIANT *p)
783 {
784     FIXME("(%p)->(%p)\n", iface, p);
785     return E_NOTIMPL;
786 }
787
788 static HRESULT WINAPI HTMLDocument_put_onkeypress(IHTMLDocument2 *iface, VARIANT v)
789 {
790     FIXME("(%p)\n", iface);
791     return E_NOTIMPL;
792 }
793
794 static HRESULT WINAPI HTMLDocument_get_onkeypress(IHTMLDocument2 *iface, VARIANT *p)
795 {
796     FIXME("(%p)->(%p)\n", iface, p);
797     return E_NOTIMPL;
798 }
799
800 static HRESULT WINAPI HTMLDocument_put_onmouseup(IHTMLDocument2 *iface, VARIANT v)
801 {
802     FIXME("(%p)\n", iface);
803     return E_NOTIMPL;
804 }
805
806 static HRESULT WINAPI HTMLDocument_get_onmouseup(IHTMLDocument2 *iface, VARIANT *p)
807 {
808     FIXME("(%p)->(%p)\n", iface, p);
809     return E_NOTIMPL;
810 }
811
812 static HRESULT WINAPI HTMLDocument_put_onmousedown(IHTMLDocument2 *iface, VARIANT v)
813 {
814     FIXME("(%p)\n", iface);
815     return E_NOTIMPL;
816 }
817
818 static HRESULT WINAPI HTMLDocument_get_onmousedown(IHTMLDocument2 *iface, VARIANT *p)
819 {
820     FIXME("(%p)->(%p)\n", iface, p);
821     return E_NOTIMPL;
822 }
823
824 static HRESULT WINAPI HTMLDocument_put_onmousemove(IHTMLDocument2 *iface, VARIANT v)
825 {
826     FIXME("(%p)\n", iface);
827     return E_NOTIMPL;
828 }
829
830 static HRESULT WINAPI HTMLDocument_get_onmousemove(IHTMLDocument2 *iface, VARIANT *p)
831 {
832     FIXME("(%p)->(%p)\n", iface, p);
833     return E_NOTIMPL;
834 }
835
836 static HRESULT WINAPI HTMLDocument_put_onmouseout(IHTMLDocument2 *iface, VARIANT v)
837 {
838     FIXME("(%p)\n", iface);
839     return E_NOTIMPL;
840 }
841
842 static HRESULT WINAPI HTMLDocument_get_onmouseout(IHTMLDocument2 *iface, VARIANT *p)
843 {
844     FIXME("(%p)->(%p)\n", iface, p);
845     return E_NOTIMPL;
846 }
847
848 static HRESULT WINAPI HTMLDocument_put_onmouseover(IHTMLDocument2 *iface, VARIANT v)
849 {
850     FIXME("(%p)\n", iface);
851     return E_NOTIMPL;
852 }
853
854 static HRESULT WINAPI HTMLDocument_get_onmouseover(IHTMLDocument2 *iface, VARIANT *p)
855 {
856     FIXME("(%p)->(%p)\n", iface, p);
857     return E_NOTIMPL;
858 }
859
860 static HRESULT WINAPI HTMLDocument_put_onreadystatechange(IHTMLDocument2 *iface, VARIANT v)
861 {
862     FIXME("(%p)\n", iface);
863     return E_NOTIMPL;
864 }
865
866 static HRESULT WINAPI HTMLDocument_get_onreadystatechange(IHTMLDocument2 *iface, VARIANT *p)
867 {
868     FIXME("(%p)->(%p)\n", iface, p);
869     return E_NOTIMPL;
870 }
871
872 static HRESULT WINAPI HTMLDocument_put_onafterupdate(IHTMLDocument2 *iface, VARIANT v)
873 {
874     FIXME("(%p)\n", iface);
875     return E_NOTIMPL;
876 }
877
878 static HRESULT WINAPI HTMLDocument_get_onafterupdate(IHTMLDocument2 *iface, VARIANT *p)
879 {
880     FIXME("(%p)->(%p)\n", iface, p);
881     return E_NOTIMPL;
882 }
883
884 static HRESULT WINAPI HTMLDocument_put_onrowexit(IHTMLDocument2 *iface, VARIANT v)
885 {
886     FIXME("(%p)\n", iface);
887     return E_NOTIMPL;
888 }
889
890 static HRESULT WINAPI HTMLDocument_get_onrowexit(IHTMLDocument2 *iface, VARIANT *p)
891 {
892     FIXME("(%p)->(%p)\n", iface, p);
893     return E_NOTIMPL;
894 }
895
896 static HRESULT WINAPI HTMLDocument_put_onrowenter(IHTMLDocument2 *iface, VARIANT v)
897 {
898     FIXME("(%p)\n", iface);
899     return E_NOTIMPL;
900 }
901
902 static HRESULT WINAPI HTMLDocument_get_onrowenter(IHTMLDocument2 *iface, VARIANT *p)
903 {
904     FIXME("(%p)->(%p)\n", iface, p);
905     return E_NOTIMPL;
906 }
907
908 static HRESULT WINAPI HTMLDocument_put_ondragstart(IHTMLDocument2 *iface, VARIANT v)
909 {
910     FIXME("(%p)\n", iface);
911     return E_NOTIMPL;
912 }
913
914 static HRESULT WINAPI HTMLDocument_get_ondragstart(IHTMLDocument2 *iface, VARIANT *p)
915 {
916     FIXME("(%p)->(%p)\n", iface, p);
917     return E_NOTIMPL;
918 }
919
920 static HRESULT WINAPI HTMLDocument_put_onselectstart(IHTMLDocument2 *iface, VARIANT v)
921 {
922     FIXME("(%p)\n", iface);
923     return E_NOTIMPL;
924 }
925
926 static HRESULT WINAPI HTMLDocument_get_onselectstart(IHTMLDocument2 *iface, VARIANT *p)
927 {
928     FIXME("(%p)->(%p)\n", iface, p);
929     return E_NOTIMPL;
930 }
931
932 static HRESULT WINAPI HTMLDocument_elementFromPoint(IHTMLDocument2 *iface, long x, long y,
933                                                         IHTMLElement **elementHit)
934 {
935     FIXME("(%p)->(%ld %ld %p)\n", iface, x, y, elementHit);
936     return E_NOTIMPL;
937 }
938
939 static HRESULT WINAPI HTMLDocument_get_parentWindow(IHTMLDocument2 *iface, IHTMLWindow2 **p)
940 {
941     HTMLDocument *This = HTMLDOC_THIS(iface);
942
943     TRACE("(%p)->(%p)\n", This, p);
944
945     *p = HTMLWINDOW2(This->window);
946     IHTMLWindow2_AddRef(*p);
947     return S_OK;
948 }
949
950 static HRESULT WINAPI HTMLDocument_get_styleSheets(IHTMLDocument2 *iface,
951                                                     IHTMLStyleSheetsCollection **p)
952 {
953     FIXME("(%p)->(%p)\n", iface, p);
954     return E_NOTIMPL;
955 }
956
957 static HRESULT WINAPI HTMLDocument_put_onbeforeupdate(IHTMLDocument2 *iface, VARIANT v)
958 {
959     FIXME("(%p)\n", iface);
960     return E_NOTIMPL;
961 }
962
963 static HRESULT WINAPI HTMLDocument_get_onbeforeupdate(IHTMLDocument2 *iface, VARIANT *p)
964 {
965     FIXME("(%p)->(%p)\n", iface, p);
966     return E_NOTIMPL;
967 }
968
969 static HRESULT WINAPI HTMLDocument_put_onerrorupdate(IHTMLDocument2 *iface, VARIANT v)
970 {
971     FIXME("(%p)\n", iface);
972     return E_NOTIMPL;
973 }
974
975 static HRESULT WINAPI HTMLDocument_get_onerrorupdate(IHTMLDocument2 *iface, VARIANT *p)
976 {
977     FIXME("(%p)->(%p)\n", iface, p);
978     return E_NOTIMPL;
979 }
980
981 static HRESULT WINAPI HTMLDocument_toString(IHTMLDocument2 *iface, BSTR *String)
982 {
983     FIXME("(%p)->(%p)\n", iface, String);
984     return E_NOTIMPL;
985 }
986
987 static HRESULT WINAPI HTMLDocument_createStyleSheet(IHTMLDocument2 *iface, BSTR bstrHref,
988                                             long lIndex, IHTMLStyleSheet **ppnewStyleSheet)
989 {
990     HTMLDocument *This = HTMLDOC_THIS(iface);
991
992     FIXME("(%p)->(%s %ld %p) semi-stub\n", This, debugstr_w(bstrHref), lIndex, ppnewStyleSheet);
993
994     *ppnewStyleSheet = HTMLStyleSheet_Create();
995     return S_OK;
996 }
997
998 static const IHTMLDocument2Vtbl HTMLDocumentVtbl = {
999     HTMLDocument_QueryInterface,
1000     HTMLDocument_AddRef,
1001     HTMLDocument_Release,
1002     HTMLDocument_GetTypeInfoCount,
1003     HTMLDocument_GetTypeInfo,
1004     HTMLDocument_GetIDsOfNames,
1005     HTMLDocument_Invoke,
1006     HTMLDocument_get_Script,
1007     HTMLDocument_get_all,
1008     HTMLDocument_get_body,
1009     HTMLDocument_get_activeElement,
1010     HTMLDocument_get_images,
1011     HTMLDocument_get_applets,
1012     HTMLDocument_get_links,
1013     HTMLDocument_get_forms,
1014     HTMLDocument_get_anchors,
1015     HTMLDocument_put_title,
1016     HTMLDocument_get_title,
1017     HTMLDocument_get_scripts,
1018     HTMLDocument_put_designMode,
1019     HTMLDocument_get_designMode,
1020     HTMLDocument_get_selection,
1021     HTMLDocument_get_readyState,
1022     HTMLDocument_get_frames,
1023     HTMLDocument_get_embeds,
1024     HTMLDocument_get_plugins,
1025     HTMLDocument_put_alinkColor,
1026     HTMLDocument_get_alinkColor,
1027     HTMLDocument_put_bgColor,
1028     HTMLDocument_get_bgColor,
1029     HTMLDocument_put_fgColor,
1030     HTMLDocument_get_fgColor,
1031     HTMLDocument_put_linkColor,
1032     HTMLDocument_get_linkColor,
1033     HTMLDocument_put_vlinkColor,
1034     HTMLDocument_get_vlinkColor,
1035     HTMLDocument_get_referrer,
1036     HTMLDocument_get_location,
1037     HTMLDocument_get_lastModified,
1038     HTMLDocument_put_URL,
1039     HTMLDocument_get_URL,
1040     HTMLDocument_put_domain,
1041     HTMLDocument_get_domain,
1042     HTMLDocument_put_cookie,
1043     HTMLDocument_get_cookie,
1044     HTMLDocument_put_expando,
1045     HTMLDocument_get_expando,
1046     HTMLDocument_put_charset,
1047     HTMLDocument_get_charset,
1048     HTMLDocument_put_defaultCharset,
1049     HTMLDocument_get_defaultCharset,
1050     HTMLDocument_get_mimeType,
1051     HTMLDocument_get_fileSize,
1052     HTMLDocument_get_fileCreatedDate,
1053     HTMLDocument_get_fileModifiedDate,
1054     HTMLDocument_get_fileUpdatedDate,
1055     HTMLDocument_get_security,
1056     HTMLDocument_get_protocol,
1057     HTMLDocument_get_nameProp,
1058     HTMLDocument_write,
1059     HTMLDocument_writeln,
1060     HTMLDocument_open,
1061     HTMLDocument_close,
1062     HTMLDocument_clear,
1063     HTMLDocument_queryCommandSupported,
1064     HTMLDocument_queryCommandEnabled,
1065     HTMLDocument_queryCommandState,
1066     HTMLDocument_queryCommandIndeterm,
1067     HTMLDocument_queryCommandText,
1068     HTMLDocument_queryCommandValue,
1069     HTMLDocument_execCommand,
1070     HTMLDocument_execCommandShowHelp,
1071     HTMLDocument_createElement,
1072     HTMLDocument_put_onhelp,
1073     HTMLDocument_get_onhelp,
1074     HTMLDocument_put_onclick,
1075     HTMLDocument_get_onclick,
1076     HTMLDocument_put_ondblclick,
1077     HTMLDocument_get_ondblclick,
1078     HTMLDocument_put_onkeyup,
1079     HTMLDocument_get_onkeyup,
1080     HTMLDocument_put_onkeydown,
1081     HTMLDocument_get_onkeydown,
1082     HTMLDocument_put_onkeypress,
1083     HTMLDocument_get_onkeypress,
1084     HTMLDocument_put_onmouseup,
1085     HTMLDocument_get_onmouseup,
1086     HTMLDocument_put_onmousedown,
1087     HTMLDocument_get_onmousedown,
1088     HTMLDocument_put_onmousemove,
1089     HTMLDocument_get_onmousemove,
1090     HTMLDocument_put_onmouseout,
1091     HTMLDocument_get_onmouseout,
1092     HTMLDocument_put_onmouseover,
1093     HTMLDocument_get_onmouseover,
1094     HTMLDocument_put_onreadystatechange,
1095     HTMLDocument_get_onreadystatechange,
1096     HTMLDocument_put_onafterupdate,
1097     HTMLDocument_get_onafterupdate,
1098     HTMLDocument_put_onrowexit,
1099     HTMLDocument_get_onrowexit,
1100     HTMLDocument_put_onrowenter,
1101     HTMLDocument_get_onrowenter,
1102     HTMLDocument_put_ondragstart,
1103     HTMLDocument_get_ondragstart,
1104     HTMLDocument_put_onselectstart,
1105     HTMLDocument_get_onselectstart,
1106     HTMLDocument_elementFromPoint,
1107     HTMLDocument_get_parentWindow,
1108     HTMLDocument_get_styleSheets,
1109     HTMLDocument_put_onbeforeupdate,
1110     HTMLDocument_get_onbeforeupdate,
1111     HTMLDocument_put_onerrorupdate,
1112     HTMLDocument_get_onerrorupdate,
1113     HTMLDocument_toString,
1114     HTMLDocument_createStyleSheet
1115 };
1116
1117 HRESULT HTMLDocument_Create(IUnknown *pUnkOuter, REFIID riid, void** ppvObject)
1118 {
1119     HTMLDocument *ret;
1120     HRESULT hres;
1121
1122     TRACE("(%p %s %p)\n", pUnkOuter, debugstr_guid(riid), ppvObject);
1123
1124     ret = mshtml_alloc(sizeof(HTMLDocument));
1125     ret->lpHTMLDocument2Vtbl = &HTMLDocumentVtbl;
1126     ret->ref = 0;
1127     ret->nscontainer = NULL;
1128     ret->nodes = NULL;
1129     ret->readystate = READYSTATE_UNINITIALIZED;
1130     ret->window = NULL;
1131
1132     list_init(&ret->selection_list);
1133
1134     hres = IHTMLDocument_QueryInterface(HTMLDOC(ret), riid, ppvObject);
1135     if(FAILED(hres)) {
1136         mshtml_free(ret);
1137         return hres;
1138     }
1139
1140     LOCK_MODULE();
1141
1142     HTMLDocument_HTMLDocument3_Init(ret);
1143     HTMLDocument_Persist_Init(ret);
1144     HTMLDocument_OleCmd_Init(ret);
1145     HTMLDocument_OleObj_Init(ret);
1146     HTMLDocument_View_Init(ret);
1147     HTMLDocument_Window_Init(ret);
1148     HTMLDocument_Service_Init(ret);
1149     HTMLDocument_Hlink_Init(ret);
1150
1151     ConnectionPoint_Init(&ret->cp_propnotif, CONPTCONT(&ret->cp_container),
1152             &IID_IPropertyNotifySink, NULL);
1153     ConnectionPoint_Init(&ret->cp_htmldocevents, CONPTCONT(&ret->cp_container),
1154             &DIID_HTMLDocumentEvents, &ret->cp_propnotif);
1155     ConnectionPoint_Init(&ret->cp_htmldocevents2, CONPTCONT(&ret->cp_container),
1156             &DIID_HTMLDocumentEvents2, &ret->cp_htmldocevents);
1157     ConnectionPointContainer_Init(&ret->cp_container, &ret->cp_propnotif, (IUnknown*)HTMLDOC(ret));
1158
1159     ret->nscontainer = NSContainer_Create(ret, NULL);
1160     ret->window = HTMLWindow_Create(ret);
1161
1162     get_thread_hwnd();
1163
1164     return hres;
1165 }