msvcp90: Fix parsing in num_get<>::_Getifld.
[wine] / dlls / mshtml / htmliframe.c
1 /*
2  * Copyright 2008 Jacek Caban for CodeWeavers
3  *
4  * This library is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU Lesser General Public
6  * License as published by the Free Software Foundation; either
7  * version 2.1 of the License, or (at your option) any later version.
8  *
9  * This library is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12  * Lesser General Public License for more details.
13  *
14  * You should have received a copy of the GNU Lesser General Public
15  * License along with this library; if not, write to the Free Software
16  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
17  */
18
19 #include <stdarg.h>
20
21 #define COBJMACROS
22
23 #include "windef.h"
24 #include "winbase.h"
25 #include "winuser.h"
26 #include "ole2.h"
27
28 #include "mshtml_private.h"
29
30 #include "wine/debug.h"
31
32 WINE_DEFAULT_DEBUG_CHANNEL(mshtml);
33
34 typedef struct {
35     HTMLFrameBase framebase;
36     IHTMLIFrameElement IHTMLIFrameElement_iface;
37     IHTMLIFrameElement2 IHTMLIFrameElement2_iface;
38     IHTMLIFrameElement3 IHTMLIFrameElement3_iface;
39 } HTMLIFrame;
40
41 static inline HTMLIFrame *impl_from_IHTMLIFrameElement(IHTMLIFrameElement *iface)
42 {
43     return CONTAINING_RECORD(iface, HTMLIFrame, IHTMLIFrameElement_iface);
44 }
45
46 static HRESULT WINAPI HTMLIFrameElement_QueryInterface(IHTMLIFrameElement *iface,
47         REFIID riid, void **ppv)
48 {
49     HTMLIFrame *This = impl_from_IHTMLIFrameElement(iface);
50
51     return IHTMLDOMNode_QueryInterface(&This->framebase.element.node.IHTMLDOMNode_iface, riid, ppv);
52 }
53
54 static ULONG WINAPI HTMLIFrameElement_AddRef(IHTMLIFrameElement *iface)
55 {
56     HTMLIFrame *This = impl_from_IHTMLIFrameElement(iface);
57
58     return IHTMLDOMNode_AddRef(&This->framebase.element.node.IHTMLDOMNode_iface);
59 }
60
61 static ULONG WINAPI HTMLIFrameElement_Release(IHTMLIFrameElement *iface)
62 {
63     HTMLIFrame *This = impl_from_IHTMLIFrameElement(iface);
64
65     return IHTMLDOMNode_Release(&This->framebase.element.node.IHTMLDOMNode_iface);
66 }
67
68 static HRESULT WINAPI HTMLIFrameElement_GetTypeInfoCount(IHTMLIFrameElement *iface, UINT *pctinfo)
69 {
70     HTMLIFrame *This = impl_from_IHTMLIFrameElement(iface);
71     return IDispatchEx_GetTypeInfoCount(&This->framebase.element.node.dispex.IDispatchEx_iface,
72             pctinfo);
73 }
74
75 static HRESULT WINAPI HTMLIFrameElement_GetTypeInfo(IHTMLIFrameElement *iface, UINT iTInfo,
76         LCID lcid, ITypeInfo **ppTInfo)
77 {
78     HTMLIFrame *This = impl_from_IHTMLIFrameElement(iface);
79     return IDispatchEx_GetTypeInfo(&This->framebase.element.node.dispex.IDispatchEx_iface, iTInfo,
80             lcid, ppTInfo);
81 }
82
83 static HRESULT WINAPI HTMLIFrameElement_GetIDsOfNames(IHTMLIFrameElement *iface, REFIID riid,
84         LPOLESTR *rgszNames, UINT cNames, LCID lcid, DISPID *rgDispId)
85 {
86     HTMLIFrame *This = impl_from_IHTMLIFrameElement(iface);
87     return IDispatchEx_GetIDsOfNames(&This->framebase.element.node.dispex.IDispatchEx_iface, riid,
88             rgszNames, cNames, lcid, rgDispId);
89 }
90
91 static HRESULT WINAPI HTMLIFrameElement_Invoke(IHTMLIFrameElement *iface, DISPID dispIdMember,
92         REFIID riid, LCID lcid, WORD wFlags, DISPPARAMS *pDispParams,
93         VARIANT *pVarResult, EXCEPINFO *pExcepInfo, UINT *puArgErr)
94 {
95     HTMLIFrame *This = impl_from_IHTMLIFrameElement(iface);
96     return IDispatchEx_Invoke(&This->framebase.element.node.dispex.IDispatchEx_iface, dispIdMember,
97             riid, lcid, wFlags, pDispParams, pVarResult, pExcepInfo, puArgErr);
98 }
99
100 static HRESULT WINAPI HTMLIFrameElement_put_vspace(IHTMLIFrameElement *iface, LONG v)
101 {
102     HTMLIFrame *This = impl_from_IHTMLIFrameElement(iface);
103     FIXME("(%p)->(%d)\n", This, v);
104     return E_NOTIMPL;
105 }
106
107 static HRESULT WINAPI HTMLIFrameElement_get_vspace(IHTMLIFrameElement *iface, LONG *p)
108 {
109     HTMLIFrame *This = impl_from_IHTMLIFrameElement(iface);
110     FIXME("(%p)->(%p)\n", This, p);
111     return E_NOTIMPL;
112 }
113
114 static HRESULT WINAPI HTMLIFrameElement_put_hspace(IHTMLIFrameElement *iface, LONG v)
115 {
116     HTMLIFrame *This = impl_from_IHTMLIFrameElement(iface);
117     FIXME("(%p)->(%d)\n", This, v);
118     return E_NOTIMPL;
119 }
120
121 static HRESULT WINAPI HTMLIFrameElement_get_hspace(IHTMLIFrameElement *iface, LONG *p)
122 {
123     HTMLIFrame *This = impl_from_IHTMLIFrameElement(iface);
124     FIXME("(%p)->(%p)\n", This, p);
125     return E_NOTIMPL;
126 }
127
128 static HRESULT WINAPI HTMLIFrameElement_put_align(IHTMLIFrameElement *iface, BSTR v)
129 {
130     HTMLIFrame *This = impl_from_IHTMLIFrameElement(iface);
131     FIXME("(%p)->(%s)\n", This, debugstr_w(v));
132     return E_NOTIMPL;
133 }
134
135 static HRESULT WINAPI HTMLIFrameElement_get_align(IHTMLIFrameElement *iface, BSTR *p)
136 {
137     HTMLIFrame *This = impl_from_IHTMLIFrameElement(iface);
138     FIXME("(%p)->(%p)\n", This, p);
139     return E_NOTIMPL;
140 }
141
142 static const IHTMLIFrameElementVtbl HTMLIFrameElementVtbl = {
143     HTMLIFrameElement_QueryInterface,
144     HTMLIFrameElement_AddRef,
145     HTMLIFrameElement_Release,
146     HTMLIFrameElement_GetTypeInfoCount,
147     HTMLIFrameElement_GetTypeInfo,
148     HTMLIFrameElement_GetIDsOfNames,
149     HTMLIFrameElement_Invoke,
150     HTMLIFrameElement_put_vspace,
151     HTMLIFrameElement_get_vspace,
152     HTMLIFrameElement_put_hspace,
153     HTMLIFrameElement_get_hspace,
154     HTMLIFrameElement_put_align,
155     HTMLIFrameElement_get_align
156 };
157
158 static inline HTMLIFrame *impl_from_IHTMLIFrameElement2(IHTMLIFrameElement2 *iface)
159 {
160     return CONTAINING_RECORD(iface, HTMLIFrame, IHTMLIFrameElement2_iface);
161 }
162
163 static HRESULT WINAPI HTMLIFrameElement2_QueryInterface(IHTMLIFrameElement2 *iface,
164         REFIID riid, void **ppv)
165 {
166     HTMLIFrame *This = impl_from_IHTMLIFrameElement2(iface);
167
168     return IHTMLDOMNode_QueryInterface(&This->framebase.element.node.IHTMLDOMNode_iface, riid, ppv);
169 }
170
171 static ULONG WINAPI HTMLIFrameElement2_AddRef(IHTMLIFrameElement2 *iface)
172 {
173     HTMLIFrame *This = impl_from_IHTMLIFrameElement2(iface);
174
175     return IHTMLDOMNode_AddRef(&This->framebase.element.node.IHTMLDOMNode_iface);
176 }
177
178 static ULONG WINAPI HTMLIFrameElement2_Release(IHTMLIFrameElement2 *iface)
179 {
180     HTMLIFrame *This = impl_from_IHTMLIFrameElement2(iface);
181
182     return IHTMLDOMNode_Release(&This->framebase.element.node.IHTMLDOMNode_iface);
183 }
184
185 static HRESULT WINAPI HTMLIFrameElement2_GetTypeInfoCount(IHTMLIFrameElement2 *iface, UINT *pctinfo)
186 {
187     HTMLIFrame *This = impl_from_IHTMLIFrameElement2(iface);
188     return IDispatchEx_GetTypeInfoCount(&This->framebase.element.node.dispex.IDispatchEx_iface,
189             pctinfo);
190 }
191
192 static HRESULT WINAPI HTMLIFrameElement2_GetTypeInfo(IHTMLIFrameElement2 *iface, UINT iTInfo,
193         LCID lcid, ITypeInfo **ppTInfo)
194 {
195     HTMLIFrame *This = impl_from_IHTMLIFrameElement2(iface);
196     return IDispatchEx_GetTypeInfo(&This->framebase.element.node.dispex.IDispatchEx_iface, iTInfo,
197             lcid, ppTInfo);
198 }
199
200 static HRESULT WINAPI HTMLIFrameElement2_GetIDsOfNames(IHTMLIFrameElement2 *iface, REFIID riid,
201         LPOLESTR *rgszNames, UINT cNames, LCID lcid, DISPID *rgDispId)
202 {
203     HTMLIFrame *This = impl_from_IHTMLIFrameElement2(iface);
204     return IDispatchEx_GetIDsOfNames(&This->framebase.element.node.dispex.IDispatchEx_iface, riid,
205             rgszNames, cNames, lcid, rgDispId);
206 }
207
208 static HRESULT WINAPI HTMLIFrameElement2_Invoke(IHTMLIFrameElement2 *iface, DISPID dispIdMember,
209         REFIID riid, LCID lcid, WORD wFlags, DISPPARAMS *pDispParams,
210         VARIANT *pVarResult, EXCEPINFO *pExcepInfo, UINT *puArgErr)
211 {
212     HTMLIFrame *This = impl_from_IHTMLIFrameElement2(iface);
213     return IDispatchEx_Invoke(&This->framebase.element.node.dispex.IDispatchEx_iface, dispIdMember,
214             riid, lcid, wFlags, pDispParams, pVarResult, pExcepInfo, puArgErr);
215 }
216
217 static HRESULT WINAPI HTMLIFrameElement2_put_height(IHTMLIFrameElement2 *iface, VARIANT v)
218 {
219     HTMLIFrame *This = impl_from_IHTMLIFrameElement2(iface);
220     FIXME("(%p)->(%s)\n", This, debugstr_variant(&v));
221     return E_NOTIMPL;
222 }
223
224 static HRESULT WINAPI HTMLIFrameElement2_get_height(IHTMLIFrameElement2 *iface, VARIANT *p)
225 {
226     HTMLIFrame *This = impl_from_IHTMLIFrameElement2(iface);
227     FIXME("(%p)->(%p)\n", This, p);
228     return E_NOTIMPL;
229 }
230
231 static HRESULT WINAPI HTMLIFrameElement2_put_width(IHTMLIFrameElement2 *iface, VARIANT v)
232 {
233     HTMLIFrame *This = impl_from_IHTMLIFrameElement2(iface);
234     FIXME("(%p)->(%s)\n", This, debugstr_variant(&v));
235     return E_NOTIMPL;
236 }
237
238 static HRESULT WINAPI HTMLIFrameElement2_get_width(IHTMLIFrameElement2 *iface, VARIANT *p)
239 {
240     HTMLIFrame *This = impl_from_IHTMLIFrameElement2(iface);
241     FIXME("(%p)->(%p)\n", This, p);
242     return E_NOTIMPL;
243 }
244
245 static const IHTMLIFrameElement2Vtbl HTMLIFrameElement2Vtbl = {
246     HTMLIFrameElement2_QueryInterface,
247     HTMLIFrameElement2_AddRef,
248     HTMLIFrameElement2_Release,
249     HTMLIFrameElement2_GetTypeInfoCount,
250     HTMLIFrameElement2_GetTypeInfo,
251     HTMLIFrameElement2_GetIDsOfNames,
252     HTMLIFrameElement2_Invoke,
253     HTMLIFrameElement2_put_height,
254     HTMLIFrameElement2_get_height,
255     HTMLIFrameElement2_put_width,
256     HTMLIFrameElement2_get_width
257 };
258
259 static inline HTMLIFrame *impl_from_IHTMLIFrameElement3(IHTMLIFrameElement3 *iface)
260 {
261     return CONTAINING_RECORD(iface, HTMLIFrame, IHTMLIFrameElement3_iface);
262 }
263
264 static HRESULT WINAPI HTMLIFrameElement3_QueryInterface(IHTMLIFrameElement3 *iface,
265         REFIID riid, void **ppv)
266 {
267     HTMLIFrame *This = impl_from_IHTMLIFrameElement3(iface);
268
269     return IHTMLDOMNode_QueryInterface(&This->framebase.element.node.IHTMLDOMNode_iface, riid, ppv);
270 }
271
272 static ULONG WINAPI HTMLIFrameElement3_AddRef(IHTMLIFrameElement3 *iface)
273 {
274     HTMLIFrame *This = impl_from_IHTMLIFrameElement3(iface);
275
276     return IHTMLDOMNode_AddRef(&This->framebase.element.node.IHTMLDOMNode_iface);
277 }
278
279 static ULONG WINAPI HTMLIFrameElement3_Release(IHTMLIFrameElement3 *iface)
280 {
281     HTMLIFrame *This = impl_from_IHTMLIFrameElement3(iface);
282
283     return IHTMLDOMNode_Release(&This->framebase.element.node.IHTMLDOMNode_iface);
284 }
285
286 static HRESULT WINAPI HTMLIFrameElement3_GetTypeInfoCount(IHTMLIFrameElement3 *iface, UINT *pctinfo)
287 {
288     HTMLIFrame *This = impl_from_IHTMLIFrameElement3(iface);
289     return IDispatchEx_GetTypeInfoCount(&This->framebase.element.node.dispex.IDispatchEx_iface,
290             pctinfo);
291 }
292
293 static HRESULT WINAPI HTMLIFrameElement3_GetTypeInfo(IHTMLIFrameElement3 *iface, UINT iTInfo,
294         LCID lcid, ITypeInfo **ppTInfo)
295 {
296     HTMLIFrame *This = impl_from_IHTMLIFrameElement3(iface);
297     return IDispatchEx_GetTypeInfo(&This->framebase.element.node.dispex.IDispatchEx_iface, iTInfo,
298             lcid, ppTInfo);
299 }
300
301 static HRESULT WINAPI HTMLIFrameElement3_GetIDsOfNames(IHTMLIFrameElement3 *iface, REFIID riid,
302         LPOLESTR *rgszNames, UINT cNames, LCID lcid, DISPID *rgDispId)
303 {
304     HTMLIFrame *This = impl_from_IHTMLIFrameElement3(iface);
305     return IDispatchEx_GetIDsOfNames(&This->framebase.element.node.dispex.IDispatchEx_iface, riid,
306             rgszNames, cNames, lcid, rgDispId);
307 }
308
309 static HRESULT WINAPI HTMLIFrameElement3_Invoke(IHTMLIFrameElement3 *iface, DISPID dispIdMember,
310         REFIID riid, LCID lcid, WORD wFlags, DISPPARAMS *pDispParams,
311         VARIANT *pVarResult, EXCEPINFO *pExcepInfo, UINT *puArgErr)
312 {
313     HTMLIFrame *This = impl_from_IHTMLIFrameElement3(iface);
314     return IDispatchEx_Invoke(&This->framebase.element.node.dispex.IDispatchEx_iface, dispIdMember,
315             riid, lcid, wFlags, pDispParams, pVarResult, pExcepInfo, puArgErr);
316 }
317
318 static HRESULT WINAPI HTMLIFrameElement3_get_contentDocument(IHTMLIFrameElement3 *iface, IDispatch **p)
319 {
320     HTMLIFrame *This = impl_from_IHTMLIFrameElement3(iface);
321     IHTMLDocument2 *doc;
322     HRESULT hres;
323
324     TRACE("(%p)->(%p)\n", This, p);
325
326     if(!This->framebase.content_window) {
327         *p = NULL;
328         return S_OK;
329     }
330
331     hres = IHTMLWindow2_get_document(&This->framebase.content_window->base.IHTMLWindow2_iface, &doc);
332     *p = (IDispatch*)doc;
333     return hres;
334 }
335
336 static HRESULT WINAPI HTMLIFrameElement3_put_src(IHTMLIFrameElement3 *iface, BSTR v)
337 {
338     HTMLIFrame *This = impl_from_IHTMLIFrameElement3(iface);
339     FIXME("(%p)->(%s)\n", This, debugstr_w(v));
340     return E_NOTIMPL;
341 }
342
343 static HRESULT WINAPI HTMLIFrameElement3_get_src(IHTMLIFrameElement3 *iface, BSTR *p)
344 {
345     HTMLIFrame *This = impl_from_IHTMLIFrameElement3(iface);
346     FIXME("(%p)->(%p)\n", This, p);
347     return E_NOTIMPL;
348 }
349
350 static HRESULT WINAPI HTMLIFrameElement3_put_longDesc(IHTMLIFrameElement3 *iface, BSTR v)
351 {
352     HTMLIFrame *This = impl_from_IHTMLIFrameElement3(iface);
353     FIXME("(%p)->(%s)\n", This, debugstr_w(v));
354     return E_NOTIMPL;
355 }
356
357 static HRESULT WINAPI HTMLIFrameElement3_get_longDesc(IHTMLIFrameElement3 *iface, BSTR *p)
358 {
359     HTMLIFrame *This = impl_from_IHTMLIFrameElement3(iface);
360     FIXME("(%p)->(%p)\n", This, p);
361     return E_NOTIMPL;
362 }
363
364 static HRESULT WINAPI HTMLIFrameElement3_put_frameBorder(IHTMLIFrameElement3 *iface, BSTR v)
365 {
366     HTMLIFrame *This = impl_from_IHTMLIFrameElement3(iface);
367     FIXME("(%p)->(%s)\n", This, debugstr_w(v));
368     return E_NOTIMPL;
369 }
370
371 static HRESULT WINAPI HTMLIFrameElement3_get_frameBorder(IHTMLIFrameElement3 *iface, BSTR *p)
372 {
373     HTMLIFrame *This = impl_from_IHTMLIFrameElement3(iface);
374     FIXME("(%p)->(%p)\n", This, p);
375     return E_NOTIMPL;
376 }
377
378 static const IHTMLIFrameElement3Vtbl HTMLIFrameElement3Vtbl = {
379     HTMLIFrameElement3_QueryInterface,
380     HTMLIFrameElement3_AddRef,
381     HTMLIFrameElement3_Release,
382     HTMLIFrameElement3_GetTypeInfoCount,
383     HTMLIFrameElement3_GetTypeInfo,
384     HTMLIFrameElement3_GetIDsOfNames,
385     HTMLIFrameElement3_Invoke,
386     HTMLIFrameElement3_get_contentDocument,
387     HTMLIFrameElement3_put_src,
388     HTMLIFrameElement3_get_src,
389     HTMLIFrameElement3_put_longDesc,
390     HTMLIFrameElement3_get_longDesc,
391     HTMLIFrameElement3_put_frameBorder,
392     HTMLIFrameElement3_get_frameBorder
393 };
394
395 static inline HTMLIFrame *impl_from_HTMLDOMNode(HTMLDOMNode *iface)
396 {
397     return CONTAINING_RECORD(iface, HTMLIFrame, framebase.element.node);
398 }
399
400 static HRESULT HTMLIFrame_QI(HTMLDOMNode *iface, REFIID riid, void **ppv)
401 {
402     HTMLIFrame *This = impl_from_HTMLDOMNode(iface);
403
404     if(IsEqualGUID(&IID_IHTMLIFrameElement, riid)) {
405         TRACE("(%p)->(IID_IHTMLIFrameElement %p)\n", This, ppv);
406         *ppv = &This->IHTMLIFrameElement_iface;
407     }else if(IsEqualGUID(&IID_IHTMLIFrameElement2, riid)) {
408         TRACE("(%p)->(IID_IHTMLIFrameElement2 %p)\n", This, ppv);
409         *ppv = &This->IHTMLIFrameElement2_iface;
410     }else if(IsEqualGUID(&IID_IHTMLIFrameElement3, riid)) {
411         TRACE("(%p)->(IID_IHTMLIFrameElement3 %p)\n", This, ppv);
412         *ppv = &This->IHTMLIFrameElement3_iface;
413     }else {
414         return HTMLFrameBase_QI(&This->framebase, riid, ppv);
415     }
416
417     IUnknown_AddRef((IUnknown*)*ppv);
418     return S_OK;
419 }
420
421 static void HTMLIFrame_destructor(HTMLDOMNode *iface)
422 {
423     HTMLIFrame *This = impl_from_HTMLDOMNode(iface);
424
425     HTMLFrameBase_destructor(&This->framebase);
426 }
427
428 static HRESULT HTMLIFrame_get_document(HTMLDOMNode *iface, IDispatch **p)
429 {
430     HTMLIFrame *This = impl_from_HTMLDOMNode(iface);
431
432     if(!This->framebase.content_window || !This->framebase.content_window->base.inner_window->doc) {
433         *p = NULL;
434         return S_OK;
435     }
436
437     *p = (IDispatch*)&This->framebase.content_window->base.inner_window->doc->basedoc.IHTMLDocument2_iface;
438     IDispatch_AddRef(*p);
439     return S_OK;
440 }
441
442 static HRESULT HTMLIFrame_get_dispid(HTMLDOMNode *iface, BSTR name,
443         DWORD grfdex, DISPID *pid)
444 {
445     HTMLIFrame *This = impl_from_HTMLDOMNode(iface);
446
447     if(!This->framebase.content_window)
448         return DISP_E_UNKNOWNNAME;
449
450     return search_window_props(This->framebase.content_window->base.inner_window, name, grfdex, pid);
451 }
452
453 static HRESULT HTMLIFrame_invoke(HTMLDOMNode *iface, DISPID id, LCID lcid,
454         WORD flags, DISPPARAMS *params, VARIANT *res, EXCEPINFO *ei, IServiceProvider *caller)
455 {
456     HTMLIFrame *This = impl_from_HTMLDOMNode(iface);
457
458     if(!This->framebase.content_window) {
459         ERR("no content window to invoke on\n");
460         return E_FAIL;
461     }
462
463     return IDispatchEx_InvokeEx(&This->framebase.content_window->base.IDispatchEx_iface, id, lcid,
464             flags, params, res, ei, caller);
465 }
466
467 static HRESULT HTMLIFrame_get_readystate(HTMLDOMNode *iface, BSTR *p)
468 {
469     HTMLIFrame *This = impl_from_HTMLDOMNode(iface);
470
471     return IHTMLFrameBase2_get_readyState(&This->framebase.IHTMLFrameBase2_iface, p);
472 }
473
474 static HRESULT HTMLIFrame_bind_to_tree(HTMLDOMNode *iface)
475 {
476     HTMLIFrame *This = impl_from_HTMLDOMNode(iface);
477     nsIDOMDocument *nsdoc;
478     nsresult nsres;
479     HRESULT hres;
480
481     nsres = nsIDOMHTMLIFrameElement_GetContentDocument(This->framebase.nsiframe, &nsdoc);
482     if(NS_FAILED(nsres) || !nsdoc) {
483         ERR("GetContentDocument failed: %08x\n", nsres);
484         return E_FAIL;
485     }
486
487     hres = set_frame_doc(&This->framebase, nsdoc);
488     nsIDOMDocument_Release(nsdoc);
489     return hres;
490 }
491
492 static const NodeImplVtbl HTMLIFrameImplVtbl = {
493     HTMLIFrame_QI,
494     HTMLIFrame_destructor,
495     HTMLElement_clone,
496     HTMLElement_handle_event,
497     HTMLElement_get_attr_col,
498     NULL,
499     NULL,
500     NULL,
501     NULL,
502     HTMLIFrame_get_document,
503     HTMLIFrame_get_readystate,
504     HTMLIFrame_get_dispid,
505     HTMLIFrame_invoke,
506     HTMLIFrame_bind_to_tree
507 };
508
509 static const tid_t HTMLIFrame_iface_tids[] = {
510     HTMLELEMENT_TIDS,
511     IHTMLFrameBase_tid,
512     IHTMLFrameBase2_tid,
513     IHTMLIFrameElement_tid,
514     IHTMLIFrameElement2_tid,
515     IHTMLIFrameElement3_tid,
516     0
517 };
518
519 static dispex_static_data_t HTMLIFrame_dispex = {
520     NULL,
521     DispHTMLIFrame_tid,
522     NULL,
523     HTMLIFrame_iface_tids
524 };
525
526 HRESULT HTMLIFrame_Create(HTMLDocumentNode *doc, nsIDOMHTMLElement *nselem, HTMLElement **elem)
527 {
528     HTMLIFrame *ret;
529
530     ret = heap_alloc_zero(sizeof(HTMLIFrame));
531     if(!ret)
532         return E_OUTOFMEMORY;
533
534     ret->IHTMLIFrameElement_iface.lpVtbl = &HTMLIFrameElementVtbl;
535     ret->IHTMLIFrameElement2_iface.lpVtbl = &HTMLIFrameElement2Vtbl;
536     ret->IHTMLIFrameElement3_iface.lpVtbl = &HTMLIFrameElement3Vtbl;
537     ret->framebase.element.node.vtbl = &HTMLIFrameImplVtbl;
538
539     HTMLFrameBase_Init(&ret->framebase, doc, nselem, &HTMLIFrame_dispex);
540
541     *elem = &ret->framebase.element;
542     return S_OK;
543 }