views:

587

answers:

4

When programming in C++ against the browser's DOM each engine has a different set of interfaces, IE has the COM based MSHTML, Mozilla has the XPCOM based Gecko DOM etc.

Is there a common API that has adapters for major browsers (and versions)?


As a clarification, the application in question is a desktop application written in C++ which interacts with browsers, currently we have separate code bases for support of IE and Mozilla and I'm trying to reduce duplications of logic and allow adding new browsers with less effort.

A concrete example can be getting the innerHTML property of an HTML element.

// Firefox
nsAutoString html;
nsCOMPtr<nsIDOMNSHTMLElement> elem = do_QueryInterface(obj);
if (elem)
    elem->GetInnerHTML(html); 

// IE
CComBSTR html;
MSHTML::IHTMLElementPtr elem = obj;
if (elem) 
     elem->get_innerHTML(&html);
+1  A: 

I've never seen one. For my software, I simple wrote the extension in Firefox's javascript, and then created an Internet Explorer BHO (which I haven't finished yet).

Hach-Que
A: 

Any reason why it has to be C++? Can't you use jQuery? Or something like http://webkit.org/blog/156/queryselector-and-queryselectorall/ in WebKit might do the trick..

Henrik Hartz
+5  A: 

Your best bet seems to be to define your own interface and write different adapters. In the likeliness that your C++ code won't be employing all DOM traversing capabilities, your interface will only have to define a compact set of traversal functions.

As a bonus of defining your own interface, you can easily write a mock adapter for your unit testing.

Ates Goral
A: 

Moonlight is released under LGPL, they may have something usable for you, if the licensing is ok.

Fredrik Jansson
What is moonlight? I see that there's a Mono implementation of Silverlight with that name but that doesn't seem to be relevant here.
Motti