msxml3: Remove appendChild() forward.
[wine] / dlls / msxml3 / pi.c
1 /*
2  *    DOM processing instruction node implementation
3  *
4  * Copyright 2006 Huw Davies
5  *
6  * This library is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU Lesser General Public
8  * License as published by the Free Software Foundation; either
9  * version 2.1 of the License, or (at your option) any later version.
10  *
11  * This library is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14  * Lesser General Public License for more details.
15  *
16  * You should have received a copy of the GNU Lesser General Public
17  * License along with this library; if not, write to the Free Software
18  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
19  */
20
21 #define COBJMACROS
22
23 #include "config.h"
24
25 #include <stdarg.h>
26 #include "windef.h"
27 #include "winbase.h"
28 #include "winuser.h"
29 #include "ole2.h"
30 #include "msxml6.h"
31
32 #include "msxml_private.h"
33
34 #include "wine/debug.h"
35
36 WINE_DEFAULT_DEBUG_CHANNEL(msxml);
37
38 #ifdef HAVE_LIBXML2
39
40 typedef struct _dom_pi
41 {
42     xmlnode node;
43     IXMLDOMProcessingInstruction IXMLDOMProcessingInstruction_iface;
44     LONG ref;
45 } dom_pi;
46
47 static inline dom_pi *impl_from_IXMLDOMProcessingInstruction( IXMLDOMProcessingInstruction *iface )
48 {
49     return CONTAINING_RECORD(iface, dom_pi, IXMLDOMProcessingInstruction_iface);
50 }
51
52 static HRESULT WINAPI dom_pi_QueryInterface(
53     IXMLDOMProcessingInstruction *iface,
54     REFIID riid,
55     void** ppvObject )
56 {
57     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
58     TRACE("(%p)->(%s %p)\n", This, debugstr_guid(riid), ppvObject);
59
60     if ( IsEqualGUID( riid, &IID_IXMLDOMProcessingInstruction ) ||
61          IsEqualGUID( riid, &IID_IXMLDOMNode ) ||
62          IsEqualGUID( riid, &IID_IDispatch ) ||
63          IsEqualGUID( riid, &IID_IUnknown ) )
64     {
65         *ppvObject = iface;
66     }
67     else if(node_query_interface(&This->node, riid, ppvObject))
68     {
69         return *ppvObject ? S_OK : E_NOINTERFACE;
70     }
71     else
72     {
73         FIXME("Unsupported interface %s\n", debugstr_guid(riid));
74         return E_NOINTERFACE;
75     }
76
77     IUnknown_AddRef((IUnknown*)*ppvObject);
78     return S_OK;
79 }
80
81 static ULONG WINAPI dom_pi_AddRef(
82     IXMLDOMProcessingInstruction *iface )
83 {
84     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
85     return InterlockedIncrement( &This->ref );
86 }
87
88 static ULONG WINAPI dom_pi_Release(
89     IXMLDOMProcessingInstruction *iface )
90 {
91     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
92     ULONG ref;
93
94     ref = InterlockedDecrement( &This->ref );
95     if ( ref == 0 )
96     {
97         destroy_xmlnode(&This->node);
98         heap_free( This );
99     }
100
101     return ref;
102 }
103
104 static HRESULT WINAPI dom_pi_GetTypeInfoCount(
105     IXMLDOMProcessingInstruction *iface,
106     UINT* pctinfo )
107 {
108     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
109
110     TRACE("(%p)->(%p)\n", This, pctinfo);
111
112     *pctinfo = 1;
113
114     return S_OK;
115 }
116
117 static HRESULT WINAPI dom_pi_GetTypeInfo(
118     IXMLDOMProcessingInstruction *iface,
119     UINT iTInfo, LCID lcid,
120     ITypeInfo** ppTInfo )
121 {
122     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
123     HRESULT hr;
124
125     TRACE("(%p)->(%u %u %p)\n", This, iTInfo, lcid, ppTInfo);
126
127     hr = get_typeinfo(IXMLDOMProcessingInstruction_tid, ppTInfo);
128
129     return hr;
130 }
131
132 static HRESULT WINAPI dom_pi_GetIDsOfNames(
133     IXMLDOMProcessingInstruction *iface,
134     REFIID riid, LPOLESTR* rgszNames,
135     UINT cNames, LCID lcid, DISPID* rgDispId )
136 {
137     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
138     ITypeInfo *typeinfo;
139     HRESULT hr;
140
141     TRACE("(%p)->(%s %p %u %u %p)\n", This, debugstr_guid(riid), rgszNames, cNames,
142           lcid, rgDispId);
143
144     if(!rgszNames || cNames == 0 || !rgDispId)
145         return E_INVALIDARG;
146
147     hr = get_typeinfo(IXMLDOMProcessingInstruction_tid, &typeinfo);
148     if(SUCCEEDED(hr))
149     {
150         hr = ITypeInfo_GetIDsOfNames(typeinfo, rgszNames, cNames, rgDispId);
151         ITypeInfo_Release(typeinfo);
152     }
153
154     return hr;
155 }
156
157 static HRESULT WINAPI dom_pi_Invoke(
158     IXMLDOMProcessingInstruction *iface,
159     DISPID dispIdMember, REFIID riid, LCID lcid,
160     WORD wFlags, DISPPARAMS* pDispParams, VARIANT* pVarResult,
161     EXCEPINFO* pExcepInfo, UINT* puArgErr )
162 {
163     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
164     ITypeInfo *typeinfo;
165     HRESULT hr;
166
167     TRACE("(%p)->(%d %s %d %d %p %p %p %p)\n", This, dispIdMember, debugstr_guid(riid),
168           lcid, wFlags, pDispParams, pVarResult, pExcepInfo, puArgErr);
169
170     hr = get_typeinfo(IXMLDOMProcessingInstruction_tid, &typeinfo);
171     if(SUCCEEDED(hr))
172     {
173        hr = ITypeInfo_Invoke(typeinfo, &This->IXMLDOMProcessingInstruction_iface, dispIdMember,
174                 wFlags, pDispParams, pVarResult, pExcepInfo, puArgErr);
175         ITypeInfo_Release(typeinfo);
176     }
177
178     return hr;
179 }
180
181 static HRESULT WINAPI dom_pi_get_nodeName(
182     IXMLDOMProcessingInstruction *iface,
183     BSTR* p )
184 {
185     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
186
187     TRACE("(%p)->(%p)\n", This, p);
188
189     return node_get_nodeName(&This->node, p);
190 }
191
192 static HRESULT WINAPI dom_pi_get_nodeValue(
193     IXMLDOMProcessingInstruction *iface,
194     VARIANT* value)
195 {
196     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
197
198     TRACE("(%p)->(%p)\n", This, value);
199
200     return node_get_content(&This->node, value);
201 }
202
203 static HRESULT WINAPI dom_pi_put_nodeValue(
204     IXMLDOMProcessingInstruction *iface,
205     VARIANT value)
206 {
207     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
208     BSTR sTarget;
209     HRESULT hr;
210
211     TRACE("(%p)->(%s)\n", This, debugstr_variant(&value));
212
213     /* Cannot set data to a PI node whose target is 'xml' */
214     hr = dom_pi_get_nodeName(iface, &sTarget);
215     if(hr == S_OK)
216     {
217         static const WCHAR xmlW[] = {'x','m','l',0};
218         if(lstrcmpW( sTarget, xmlW) == 0)
219         {
220             SysFreeString(sTarget);
221             return E_FAIL;
222         }
223
224         SysFreeString(sTarget);
225     }
226
227     return node_put_value(&This->node, &value);
228 }
229
230 static HRESULT WINAPI dom_pi_get_nodeType(
231     IXMLDOMProcessingInstruction *iface,
232     DOMNodeType* domNodeType )
233 {
234     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
235
236     TRACE("(%p)->(%p)\n", This, domNodeType);
237
238     *domNodeType = NODE_PROCESSING_INSTRUCTION;
239     return S_OK;
240 }
241
242 static HRESULT WINAPI dom_pi_get_parentNode(
243     IXMLDOMProcessingInstruction *iface,
244     IXMLDOMNode** parent )
245 {
246     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
247
248     TRACE("(%p)->(%p)\n", This, parent);
249
250     return node_get_parent(&This->node, parent);
251 }
252
253 static HRESULT WINAPI dom_pi_get_childNodes(
254     IXMLDOMProcessingInstruction *iface,
255     IXMLDOMNodeList** outList)
256 {
257     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
258
259     TRACE("(%p)->(%p)\n", This, outList);
260
261     return node_get_child_nodes(&This->node, outList);
262 }
263
264 static HRESULT WINAPI dom_pi_get_firstChild(
265     IXMLDOMProcessingInstruction *iface,
266     IXMLDOMNode** domNode)
267 {
268     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
269
270     TRACE("(%p)->(%p)\n", This, domNode);
271
272     return return_null_node(domNode);
273 }
274
275 static HRESULT WINAPI dom_pi_get_lastChild(
276     IXMLDOMProcessingInstruction *iface,
277     IXMLDOMNode** domNode)
278 {
279     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
280
281     TRACE("(%p)->(%p)\n", This, domNode);
282
283     return return_null_node(domNode);
284 }
285
286 static HRESULT WINAPI dom_pi_get_previousSibling(
287     IXMLDOMProcessingInstruction *iface,
288     IXMLDOMNode** domNode)
289 {
290     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
291
292     TRACE("(%p)->(%p)\n", This, domNode);
293
294     return node_get_previous_sibling(&This->node, domNode);
295 }
296
297 static HRESULT WINAPI dom_pi_get_nextSibling(
298     IXMLDOMProcessingInstruction *iface,
299     IXMLDOMNode** domNode)
300 {
301     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
302
303     TRACE("(%p)->(%p)\n", This, domNode);
304
305     return node_get_next_sibling(&This->node, domNode);
306 }
307
308 static HRESULT WINAPI dom_pi_get_attributes(
309     IXMLDOMProcessingInstruction *iface,
310     IXMLDOMNamedNodeMap** attributeMap)
311 {
312     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
313
314     TRACE("(%p)->(%p)\n", This, attributeMap);
315
316     *attributeMap = create_nodemap((IXMLDOMNode*)&This->IXMLDOMProcessingInstruction_iface);
317     return S_OK;
318 }
319
320 static HRESULT WINAPI dom_pi_insertBefore(
321     IXMLDOMProcessingInstruction *iface,
322     IXMLDOMNode* newNode, VARIANT refChild,
323     IXMLDOMNode** outOldNode)
324 {
325     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
326
327     FIXME("(%p)->(%p %s %p) needs test\n", This, newNode, debugstr_variant(&refChild), outOldNode);
328
329     return node_insert_before(&This->node, newNode, &refChild, outOldNode);
330 }
331
332 static HRESULT WINAPI dom_pi_replaceChild(
333     IXMLDOMProcessingInstruction *iface,
334     IXMLDOMNode* newNode,
335     IXMLDOMNode* oldNode,
336     IXMLDOMNode** outOldNode)
337 {
338     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
339
340     FIXME("(%p)->(%p %p %p) needs test\n", This, newNode, oldNode, outOldNode);
341
342     return node_replace_child(&This->node, newNode, oldNode, outOldNode);
343 }
344
345 static HRESULT WINAPI dom_pi_removeChild(
346     IXMLDOMProcessingInstruction *iface,
347     IXMLDOMNode *child, IXMLDOMNode **oldChild)
348 {
349     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
350     TRACE("(%p)->(%p %p)\n", This, child, oldChild);
351     return node_remove_child(&This->node, child, oldChild);
352 }
353
354 static HRESULT WINAPI dom_pi_appendChild(
355     IXMLDOMProcessingInstruction *iface,
356     IXMLDOMNode *child, IXMLDOMNode **outChild)
357 {
358     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
359     TRACE("(%p)->(%p %p)\n", This, child, outChild);
360     return node_append_child(&This->node, child, outChild);
361 }
362
363 static HRESULT WINAPI dom_pi_hasChildNodes(
364     IXMLDOMProcessingInstruction *iface,
365     VARIANT_BOOL* pbool)
366 {
367     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
368     return IXMLDOMNode_hasChildNodes( &This->node.IXMLDOMNode_iface, pbool );
369 }
370
371 static HRESULT WINAPI dom_pi_get_ownerDocument(
372     IXMLDOMProcessingInstruction *iface,
373     IXMLDOMDocument** domDocument)
374 {
375     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
376     return IXMLDOMNode_get_ownerDocument( &This->node.IXMLDOMNode_iface, domDocument );
377 }
378
379 static HRESULT WINAPI dom_pi_cloneNode(
380     IXMLDOMProcessingInstruction *iface,
381     VARIANT_BOOL deep, IXMLDOMNode** outNode)
382 {
383     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
384     TRACE("(%p)->(%d %p)\n", This, deep, outNode);
385     return node_clone( &This->node, deep, outNode );
386 }
387
388 static HRESULT WINAPI dom_pi_get_nodeTypeString(
389     IXMLDOMProcessingInstruction *iface,
390     BSTR* p)
391 {
392     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
393     static const WCHAR processinginstructionW[] =
394         {'p','r','o','c','e','s','s','i','n','g','i','n','s','t','r','u','c','t','i','o','n',0};
395
396     TRACE("(%p)->(%p)\n", This, p);
397
398     return return_bstr(processinginstructionW, p);
399 }
400
401 static HRESULT WINAPI dom_pi_get_text(
402     IXMLDOMProcessingInstruction *iface,
403     BSTR* p)
404 {
405     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
406     return IXMLDOMNode_get_text( &This->node.IXMLDOMNode_iface, p );
407 }
408
409 static HRESULT WINAPI dom_pi_put_text(
410     IXMLDOMProcessingInstruction *iface,
411     BSTR p)
412 {
413     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
414     TRACE("(%p)->(%s)\n", This, debugstr_w(p));
415     return node_put_text( &This->node, p );
416 }
417
418 static HRESULT WINAPI dom_pi_get_specified(
419     IXMLDOMProcessingInstruction *iface,
420     VARIANT_BOOL* isSpecified)
421 {
422     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
423     FIXME("(%p)->(%p) stub!\n", This, isSpecified);
424     *isSpecified = VARIANT_TRUE;
425     return S_OK;
426 }
427
428 static HRESULT WINAPI dom_pi_get_definition(
429     IXMLDOMProcessingInstruction *iface,
430     IXMLDOMNode** definitionNode)
431 {
432     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
433     FIXME("(%p)->(%p)\n", This, definitionNode);
434     return E_NOTIMPL;
435 }
436
437 static HRESULT WINAPI dom_pi_get_nodeTypedValue(
438     IXMLDOMProcessingInstruction *iface,
439     VARIANT* var1)
440 {
441     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
442     FIXME("(%p)->(%p)\n", This, var1);
443     return return_null_var(var1);
444 }
445
446 static HRESULT WINAPI dom_pi_put_nodeTypedValue(
447     IXMLDOMProcessingInstruction *iface,
448     VARIANT typedValue)
449 {
450     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
451     FIXME("(%p)->(%s)\n", This, debugstr_variant(&typedValue));
452     return E_NOTIMPL;
453 }
454
455 static HRESULT WINAPI dom_pi_get_dataType(
456     IXMLDOMProcessingInstruction *iface,
457     VARIANT* typename)
458 {
459     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
460     TRACE("(%p)->(%p)\n", This, typename);
461     return return_null_var( typename );
462 }
463
464 static HRESULT WINAPI dom_pi_put_dataType(
465     IXMLDOMProcessingInstruction *iface,
466     BSTR p)
467 {
468     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
469
470     FIXME("(%p)->(%s)\n", This, debugstr_w(p));
471
472     if(!p)
473         return E_INVALIDARG;
474
475     return E_FAIL;
476 }
477
478 static HRESULT WINAPI dom_pi_get_xml(
479     IXMLDOMProcessingInstruction *iface,
480     BSTR* p)
481 {
482     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
483
484     TRACE("(%p)->(%p)\n", This, p);
485
486     return node_get_xml(&This->node, FALSE, FALSE, p);
487 }
488
489 static HRESULT WINAPI dom_pi_transformNode(
490     IXMLDOMProcessingInstruction *iface,
491     IXMLDOMNode* domNode, BSTR* p)
492 {
493     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
494     return IXMLDOMNode_transformNode( &This->node.IXMLDOMNode_iface, domNode, p );
495 }
496
497 static HRESULT WINAPI dom_pi_selectNodes(
498     IXMLDOMProcessingInstruction *iface,
499     BSTR p, IXMLDOMNodeList** outList)
500 {
501     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
502     return IXMLDOMNode_selectNodes( &This->node.IXMLDOMNode_iface, p, outList );
503 }
504
505 static HRESULT WINAPI dom_pi_selectSingleNode(
506     IXMLDOMProcessingInstruction *iface,
507     BSTR p, IXMLDOMNode** outNode)
508 {
509     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
510     return IXMLDOMNode_selectSingleNode( &This->node.IXMLDOMNode_iface, p, outNode );
511 }
512
513 static HRESULT WINAPI dom_pi_get_parsed(
514     IXMLDOMProcessingInstruction *iface,
515     VARIANT_BOOL* isParsed)
516 {
517     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
518     FIXME("(%p)->(%p) stub!\n", This, isParsed);
519     *isParsed = VARIANT_TRUE;
520     return S_OK;
521 }
522
523 static HRESULT WINAPI dom_pi_get_namespaceURI(
524     IXMLDOMProcessingInstruction *iface,
525     BSTR* p)
526 {
527     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
528     TRACE("(%p)->(%p)\n", This, p);
529     return node_get_namespaceURI(&This->node, p);
530 }
531
532 static HRESULT WINAPI dom_pi_get_prefix(
533     IXMLDOMProcessingInstruction *iface,
534     BSTR* prefix)
535 {
536     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
537     TRACE("(%p)->(%p)\n", This, prefix);
538     return return_null_bstr( prefix );
539 }
540
541 static HRESULT WINAPI dom_pi_get_baseName(
542     IXMLDOMProcessingInstruction *iface,
543     BSTR* name)
544 {
545     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
546     TRACE("(%p)->(%p)\n", This, name);
547     return node_get_base_name( &This->node, name );
548 }
549
550 static HRESULT WINAPI dom_pi_transformNodeToObject(
551     IXMLDOMProcessingInstruction *iface,
552     IXMLDOMNode* domNode, VARIANT var1)
553 {
554     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
555     FIXME("(%p)->(%p %s)\n", This, domNode, debugstr_variant(&var1));
556     return E_NOTIMPL;
557 }
558
559 static HRESULT WINAPI dom_pi_get_target(
560     IXMLDOMProcessingInstruction *iface,
561     BSTR *p)
562 {
563     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
564
565     TRACE("(%p)->(%p)\n", This, p);
566
567     /* target returns the same value as nodeName property */
568     return node_get_nodeName(&This->node, p);
569 }
570
571 static HRESULT WINAPI dom_pi_get_data(
572     IXMLDOMProcessingInstruction *iface,
573     BSTR *p)
574 {
575     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
576     HRESULT hr;
577     VARIANT ret;
578
579     TRACE("(%p)->(%p)\n", This, p);
580
581     if(!p)
582         return E_INVALIDARG;
583
584     hr = IXMLDOMProcessingInstruction_get_nodeValue( iface, &ret );
585     if(hr == S_OK)
586     {
587         *p = V_BSTR(&ret);
588     }
589
590     return hr;
591 }
592
593 static HRESULT WINAPI dom_pi_put_data(
594     IXMLDOMProcessingInstruction *iface,
595     BSTR data)
596 {
597     dom_pi *This = impl_from_IXMLDOMProcessingInstruction( iface );
598     HRESULT hr;
599     VARIANT val;
600     BSTR sTarget;
601
602     TRACE("(%p)->(%s)\n", This, debugstr_w(data) );
603
604     /* Cannot set data to a PI node whose target is 'xml' */
605     hr = dom_pi_get_nodeName(iface, &sTarget);
606     if(hr == S_OK)
607     {
608         static const WCHAR xmlW[] = {'x','m','l',0};
609         if(lstrcmpW( sTarget, xmlW) == 0)
610         {
611             SysFreeString(sTarget);
612             return E_FAIL;
613         }
614
615         SysFreeString(sTarget);
616     }
617
618     V_VT(&val) = VT_BSTR;
619     V_BSTR(&val) = data;
620
621     return IXMLDOMProcessingInstruction_put_nodeValue( iface, val );
622 }
623
624 static const struct IXMLDOMProcessingInstructionVtbl dom_pi_vtbl =
625 {
626     dom_pi_QueryInterface,
627     dom_pi_AddRef,
628     dom_pi_Release,
629     dom_pi_GetTypeInfoCount,
630     dom_pi_GetTypeInfo,
631     dom_pi_GetIDsOfNames,
632     dom_pi_Invoke,
633     dom_pi_get_nodeName,
634     dom_pi_get_nodeValue,
635     dom_pi_put_nodeValue,
636     dom_pi_get_nodeType,
637     dom_pi_get_parentNode,
638     dom_pi_get_childNodes,
639     dom_pi_get_firstChild,
640     dom_pi_get_lastChild,
641     dom_pi_get_previousSibling,
642     dom_pi_get_nextSibling,
643     dom_pi_get_attributes,
644     dom_pi_insertBefore,
645     dom_pi_replaceChild,
646     dom_pi_removeChild,
647     dom_pi_appendChild,
648     dom_pi_hasChildNodes,
649     dom_pi_get_ownerDocument,
650     dom_pi_cloneNode,
651     dom_pi_get_nodeTypeString,
652     dom_pi_get_text,
653     dom_pi_put_text,
654     dom_pi_get_specified,
655     dom_pi_get_definition,
656     dom_pi_get_nodeTypedValue,
657     dom_pi_put_nodeTypedValue,
658     dom_pi_get_dataType,
659     dom_pi_put_dataType,
660     dom_pi_get_xml,
661     dom_pi_transformNode,
662     dom_pi_selectNodes,
663     dom_pi_selectSingleNode,
664     dom_pi_get_parsed,
665     dom_pi_get_namespaceURI,
666     dom_pi_get_prefix,
667     dom_pi_get_baseName,
668     dom_pi_transformNodeToObject,
669
670     dom_pi_get_target,
671     dom_pi_get_data,
672     dom_pi_put_data
673 };
674
675 IUnknown* create_pi( xmlNodePtr pi )
676 {
677     dom_pi *This;
678
679     This = heap_alloc( sizeof *This );
680     if ( !This )
681         return NULL;
682
683     This->IXMLDOMProcessingInstruction_iface.lpVtbl = &dom_pi_vtbl;
684     This->ref = 1;
685
686     init_xmlnode(&This->node, pi, (IXMLDOMNode*)&This->IXMLDOMProcessingInstruction_iface, NULL);
687
688     return (IUnknown*)&This->IXMLDOMProcessingInstruction_iface;
689 }
690
691 #endif