Want to protect your cyber security and still get fast solutions? Ask a secure question today.Go Premium

x
?
Solved

Can't access MS XML DOM once passed across a DCOM boundary ?

Posted on 2002-04-19
4
Medium Priority
?
321 Views
Last Modified: 2008-02-01
I'm using C++ (but it's not a C++ problem) with the MS XML DOM in order to build well formed XML data files and apply XSLT to these to get nice output. That all works fine. However when I try to pass the DOM Interface across to another DCOM object I've defined (an optional component) and access it this causes an exception -

First-chance exception in MSServer.exe (KERNEL32.DLL): 0xC0010000: (no name).
First-chance exception in MSServer.exe (KERNEL32.DLL): 0xE06D7363: Microsoft C++ Exception.

The Microsoft support knowledgebase has the following to say -

http://support.microsoft.com/default.aspx?scid=kb;EN-US;q259004

Which isn't solving the proble at all, it's just sweeping it under the carpet ... I can't believe it's not possible to pass an XML DOM interface across to another DCOM component and use it from there, that's the whole point of DCOM really !

Any insights anyone ?
0
Comment
Question by:s_stirley
  • 2
4 Comments
 
LVL 23

Expert Comment

by:b1xml2
ID: 6954432
We have had this chat with Microsoft Premier Support and all they can say is that:

1. Do not pass DOM objects by reference or even by value across DCOM Objects. Pass XML String.

2. This problem relates to context switching and loss of pointers.

and thus this is the same thing in the URL mentioned:

>>
If you want to use XML across execution contexts, define a method on your wrappers that passes the raw XML data back to the caller (which you obtain through the use of IXMLDOMDocument::get_XML()). The caller can then call IXMLDOMDocument::loadXML(BSTR) on this string to restore the XML object locally.
<<
0
 
LVL 23

Expert Comment

by:b1xml2
ID: 6954441
or rather the pointers are no longer valid references
0
 
LVL 27

Accepted Solution

by:
BigRat earned 1200 total points
ID: 6962412
"I can't believe it's not possible to pass an XML DOM interface across to another DCOM component and use it from there, that's the whole point of DCOM really !"

The XML DOM may be declared as an interface but it is actually an in-process object.

In DCOM you can get objects to source and sink themselves only if the support certain types of marshalling and, most importantly, they run in their own process space - called the threading model. In which case proxy objects actually do the work in passing the parameters and returning the result with little messages.

There is a very readable book "Learning DCOM" from O'Reilly which explains exactly how this all works, including the delta pings and all the other nasty complexities.

As Brandon says get the DOM to XML source in a BSTR and just pass that along. The time taken to destruct and construct the DOM will be negligable compared to the DCOM message passing.

0
 

Author Comment

by:s_stirley
ID: 6962859
Using get_xml sending it across as a BSTR and then reloading that to another DOM in the client does work fine, and is quite quick.

Seems a shame I can't pass the object, but that's life sometimes ! thanks for both answers, I'd split the points but it won't let me :(  they go to BigRat for the in-depth reason why it won't work and the book suggestion.

Thanks.
0

Featured Post

Get expert help—faster!

Need expert help—fast? Use the Help Bell for personalized assistance getting answers to your important questions.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Introduction In my previous article (http://www.experts-exchange.com/Microsoft/Development/MS-SQL-Server/SSIS/A_9150-Loading-XML-Using-SSIS.html) I showed you how the XML Source component can be used to load XML files into a SQL Server database, us…
Browsing the questions asked to the Experts of this forum, you will be amazed to see how many times people are headaching about monster regular expressions (regex) to select that specific part of some HTML or XML file they want to extract. The examp…
Exchange organizations may use the Journaling Agent of the Transport Service to archive messages going through Exchange. However, if the Transport Service is integrated with some email content management application (such as an anti-spam), the admin…
How can you see what you are working on when you want to see it while you to save a copy? Add a "Save As" icon to the Quick Access Toolbar, or QAT. That way, when you save a copy of a query, form, report, or other object you are modifying, you…
Suggested Courses

569 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question