From 431c52c35a973c6ee6931cdcbc58f85ea49d9776 Mon Sep 17 00:00:00 2001 From: "locka%iol.ie" Date: Thu, 19 Aug 1999 21:00:44 +0000 Subject: [PATCH] Changes to DHTML model --- webshell/embed/ActiveX/IEHtmlDocument.cpp | 132 +++++++++++++++++- webshell/embed/ActiveX/IEHtmlElement.cpp | 31 +++- webshell/embed/ActiveX/IEHtmlElement.h | 2 + .../embed/ActiveX/IEHtmlElementCollection.cpp | 43 +++++- .../embed/ActiveX/IEHtmlElementCollection.h | 17 ++- 5 files changed, 214 insertions(+), 11 deletions(-) diff --git a/webshell/embed/ActiveX/IEHtmlDocument.cpp b/webshell/embed/ActiveX/IEHtmlDocument.cpp index adb6723f1634..b1b62e48104c 100644 --- a/webshell/embed/ActiveX/IEHtmlDocument.cpp +++ b/webshell/embed/ActiveX/IEHtmlDocument.cpp @@ -20,6 +20,7 @@ #include "IEHtmlElementCollection.h" #include "MozillaBrowser.h" +#include CIEHtmlDocument::CIEHtmlDocument() { @@ -31,11 +32,13 @@ CIEHtmlDocument::~CIEHtmlDocument() { } + void CIEHtmlDocument::SetParent(CMozillaBrowser *parent) { m_pParent = parent; } + HRESULT CIEHtmlDocument::GetIDispatch(IDispatch **pDispatch) { if (pDispatch == NULL) @@ -57,6 +60,19 @@ HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_Script(IDispatch __RPC_FAR *__RPC /////////////////////////////////////////////////////////////////////////////// // IHTMLDocument2 methods +struct HtmlPos +{ + CIPtr(IHTMLElementCollection) m_cpCollection; + long m_nPos; + + HtmlPos(IHTMLElementCollection *pCol, long nPos) : + m_cpCollection(pCol), + m_nPos(nPos) + { + } +}; + + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_all(IHTMLElementCollection __RPC_FAR *__RPC_FAR *p) { // Validate parameters @@ -67,408 +83,484 @@ HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_all(IHTMLElementCollection __RPC_ *p = NULL; - // TODO get all elements + std::vector< CIPtr(IDispatch) > cNodeList; + + // Get all elements CIEHtmlElementCollectionInstance *pCollection = NULL; - CIEHtmlElementCollection::CreateFromParentNode(this, (CIEHtmlElementCollection **) &pCollection); + CIEHtmlElementCollection::CreateFromParentNode(this, (CIEHtmlElementCollection **) &pCollection, TRUE); if (pCollection) { pCollection->AddRef(); - *p = pCollection; } + *p = pCollection; + return S_OK; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_body(IHTMLElement __RPC_FAR *__RPC_FAR *p) { *p = NULL; return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_activeElement(IHTMLElement __RPC_FAR *__RPC_FAR *p) { *p = NULL; return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_images(IHTMLElementCollection __RPC_FAR *__RPC_FAR *p) { *p = NULL; return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_applets(IHTMLElementCollection __RPC_FAR *__RPC_FAR *p) { *p = NULL; return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_links(IHTMLElementCollection __RPC_FAR *__RPC_FAR *p) { *p = NULL; return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_forms(IHTMLElementCollection __RPC_FAR *__RPC_FAR *p) { *p = NULL; return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_anchors(IHTMLElementCollection __RPC_FAR *__RPC_FAR *p) { *p = NULL; return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::put_title(BSTR v) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_title(BSTR __RPC_FAR *p) { *p = NULL; return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_scripts(IHTMLElementCollection __RPC_FAR *__RPC_FAR *p) { *p = NULL; return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::put_designMode(BSTR v) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_designMode(BSTR __RPC_FAR *p) { *p = NULL; return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_selection(IHTMLSelectionObject __RPC_FAR *__RPC_FAR *p) { *p = NULL; return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_readyState(BSTR __RPC_FAR *p) { *p = NULL; return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_frames(IHTMLFramesCollection2 __RPC_FAR *__RPC_FAR *p) { *p = NULL; return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_embeds(IHTMLElementCollection __RPC_FAR *__RPC_FAR *p) { *p = NULL; return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_plugins(IHTMLElementCollection __RPC_FAR *__RPC_FAR *p) { *p = NULL; return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::put_alinkColor(VARIANT v) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_alinkColor(VARIANT __RPC_FAR *p) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::put_bgColor(VARIANT v) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_bgColor(VARIANT __RPC_FAR *p) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::put_fgColor(VARIANT v) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_fgColor(VARIANT __RPC_FAR *p) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::put_linkColor(VARIANT v) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_linkColor(VARIANT __RPC_FAR *p) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::put_vlinkColor(VARIANT v) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_vlinkColor(VARIANT __RPC_FAR *p) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_referrer(BSTR __RPC_FAR *p) { *p = NULL; return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_location(IHTMLLocation __RPC_FAR *__RPC_FAR *p) { *p = NULL; return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_lastModified(BSTR __RPC_FAR *p) { *p = NULL; return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::put_URL(BSTR v) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_URL(BSTR __RPC_FAR *p) { *p = NULL; return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::put_domain(BSTR v) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_domain(BSTR __RPC_FAR *p) { *p = NULL; return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::put_cookie(BSTR v) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_cookie(BSTR __RPC_FAR *p) { *p = NULL; return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::put_expando(VARIANT_BOOL v) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_expando(VARIANT_BOOL __RPC_FAR *p) { *p = NULL; return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::put_charset(BSTR v) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_charset(BSTR __RPC_FAR *p) { *p = NULL; return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::put_defaultCharset(BSTR v) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_defaultCharset(BSTR __RPC_FAR *p) { *p = NULL; return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_mimeType(BSTR __RPC_FAR *p) { *p = NULL; return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_fileSize(BSTR __RPC_FAR *p) { *p = NULL; return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_fileCreatedDate(BSTR __RPC_FAR *p) { *p = NULL; return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_fileModifiedDate(BSTR __RPC_FAR *p) { *p = NULL; return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_fileUpdatedDate(BSTR __RPC_FAR *p) { *p = NULL; return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_security(BSTR __RPC_FAR *p) { *p = NULL; return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_protocol(BSTR __RPC_FAR *p) { *p = NULL; return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_nameProp(BSTR __RPC_FAR *p) { *p = NULL; return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::write(SAFEARRAY __RPC_FAR * psarray) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::writeln(SAFEARRAY __RPC_FAR * psarray) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::open(BSTR url, VARIANT name, VARIANT features, VARIANT replace, IDispatch __RPC_FAR *__RPC_FAR *pomWindowResult) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::close(void) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::clear(void) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::queryCommandSupported(BSTR cmdID, VARIANT_BOOL __RPC_FAR *pfRet) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::queryCommandEnabled(BSTR cmdID, VARIANT_BOOL __RPC_FAR *pfRet) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::queryCommandState(BSTR cmdID, VARIANT_BOOL __RPC_FAR *pfRet) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::queryCommandIndeterm(BSTR cmdID, VARIANT_BOOL __RPC_FAR *pfRet) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::queryCommandText(BSTR cmdID, BSTR __RPC_FAR *pcmdText) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::queryCommandValue(BSTR cmdID, VARIANT __RPC_FAR *pcmdValue) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::execCommand(BSTR cmdID, VARIANT_BOOL showUI, VARIANT value, VARIANT_BOOL __RPC_FAR *pfRet) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::execCommandShowHelp(BSTR cmdID, VARIANT_BOOL __RPC_FAR *pfRet) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::createElement(BSTR eTag, IHTMLElement __RPC_FAR *__RPC_FAR *newElem) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::put_onhelp(VARIANT v) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_onhelp(VARIANT __RPC_FAR *p) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::put_onclick(VARIANT v) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_onclick(VARIANT __RPC_FAR *p) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::put_ondblclick(VARIANT v) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_ondblclick(VARIANT __RPC_FAR *p) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::put_onkeyup(VARIANT v) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_onkeyup(VARIANT __RPC_FAR *p) { return E_NOTIMPL; + } HRESULT STDMETHODCALLTYPE CIEHtmlDocument::put_onkeydown(VARIANT v) @@ -476,171 +568,205 @@ HRESULT STDMETHODCALLTYPE CIEHtmlDocument::put_onkeydown(VARIANT v) return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_onkeydown(VARIANT __RPC_FAR *p) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::put_onkeypress(VARIANT v) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_onkeypress(VARIANT __RPC_FAR *p) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::put_onmouseup(VARIANT v) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_onmouseup(VARIANT __RPC_FAR *p) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::put_onmousedown(VARIANT v) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_onmousedown(VARIANT __RPC_FAR *p) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::put_onmousemove(VARIANT v) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_onmousemove(VARIANT __RPC_FAR *p) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::put_onmouseout(VARIANT v) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_onmouseout(VARIANT __RPC_FAR *p) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::put_onmouseover(VARIANT v) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_onmouseover(VARIANT __RPC_FAR *p) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::put_onreadystatechange(VARIANT v) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_onreadystatechange(VARIANT __RPC_FAR *p) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::put_onafterupdate(VARIANT v) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_onafterupdate(VARIANT __RPC_FAR *p) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::put_onrowexit(VARIANT v) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_onrowexit(VARIANT __RPC_FAR *p) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::put_onrowenter(VARIANT v) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_onrowenter(VARIANT __RPC_FAR *p) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::put_ondragstart(VARIANT v) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_ondragstart(VARIANT __RPC_FAR *p) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::put_onselectstart(VARIANT v) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_onselectstart(VARIANT __RPC_FAR *p) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::elementFromPoint(long x, long y, IHTMLElement __RPC_FAR *__RPC_FAR *elementHit) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_parentWindow(IHTMLWindow2 __RPC_FAR *__RPC_FAR *p) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_styleSheets(IHTMLStyleSheetsCollection __RPC_FAR *__RPC_FAR *p) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::put_onbeforeupdate(VARIANT v) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_onbeforeupdate(VARIANT __RPC_FAR *p) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::put_onerrorupdate(VARIANT v) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::get_onerrorupdate(VARIANT __RPC_FAR *p) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::toString(BSTR __RPC_FAR *String) { return E_NOTIMPL; } + HRESULT STDMETHODCALLTYPE CIEHtmlDocument::createStyleSheet(BSTR bstrHref, long lIndex, IHTMLStyleSheet __RPC_FAR *__RPC_FAR *ppnewStyleSheet) { return E_NOTIMPL; diff --git a/webshell/embed/ActiveX/IEHtmlElement.cpp b/webshell/embed/ActiveX/IEHtmlElement.cpp index acba7815bfa0..8ec6be0287d2 100644 --- a/webshell/embed/ActiveX/IEHtmlElement.cpp +++ b/webshell/embed/ActiveX/IEHtmlElement.cpp @@ -40,6 +40,30 @@ HRESULT CIEHtmlElement::GetIDispatch(IDispatch **pDispatch) return QueryInterface(IID_IDispatch, (void **) pDispatch); } + +HRESULT CIEHtmlElement::GetChildren(CIEHtmlElementCollectionInstance **ppCollection) +{ + // Validate parameters + if (ppCollection == NULL) + { + return E_INVALIDARG; + } + + *ppCollection = NULL; + + // Create a collection representing the children of this node + CIEHtmlElementCollectionInstance *pCollection = NULL; + CIEHtmlElementCollection::CreateFromParentNode(this, (CIEHtmlElementCollection **) &pCollection); + if (pCollection) + { + pCollection->AddRef(); + *ppCollection = pCollection; + } + + return S_OK; +} + + /////////////////////////////////////////////////////////////////////////////// // IHTMLElement implementation @@ -626,14 +650,13 @@ HRESULT STDMETHODCALLTYPE CIEHtmlElement::get_children(IDispatch __RPC_FAR *__RP // Create a collection representing the children of this node CIEHtmlElementCollectionInstance *pCollection = NULL; - CIEHtmlElementCollection::CreateFromParentNode(this, (CIEHtmlElementCollection **) &pCollection); - if (pCollection) + HRESULT hr = GetChildren(&pCollection); + if (SUCCEEDED(hr)) { - pCollection->AddRef(); *p = pCollection; } - return S_OK; + return hr; } HRESULT STDMETHODCALLTYPE CIEHtmlElement::get_all(IDispatch __RPC_FAR *__RPC_FAR *p) diff --git a/webshell/embed/ActiveX/IEHtmlElement.h b/webshell/embed/ActiveX/IEHtmlElement.h index c93d1350956b..42d0eea98f71 100644 --- a/webshell/embed/ActiveX/IEHtmlElement.h +++ b/webshell/embed/ActiveX/IEHtmlElement.h @@ -19,6 +19,7 @@ #define IEHTMLELEMENT_H #include "IEHtmlNode.h" +#include "IEHtmlElementCollection.h" class CIEHtmlElement : public CIEHtmlNode, public IDispatchImpl @@ -36,6 +37,7 @@ BEGIN_COM_MAP(CIEHtmlElement) END_COM_MAP() virtual HRESULT GetIDispatch(IDispatch **pDispatch); + virtual HRESULT GetChildren(CIEHtmlElementCollectionInstance **ppCollection); // Implementation of IHTMLElement virtual HRESULT STDMETHODCALLTYPE setAttribute(BSTR strAttributeName, VARIANT AttributeValue, LONG lFlags); diff --git a/webshell/embed/ActiveX/IEHtmlElementCollection.cpp b/webshell/embed/ActiveX/IEHtmlElementCollection.cpp index 834f327c9e32..5abd5fe8e58a 100644 --- a/webshell/embed/ActiveX/IEHtmlElementCollection.cpp +++ b/webshell/embed/ActiveX/IEHtmlElementCollection.cpp @@ -16,6 +16,9 @@ * Reserved. */ #include "stdafx.h" + +#include + #include "IEHtmlElement.h" #include "IEHtmlElementCollection.h" @@ -34,7 +37,25 @@ HRESULT CIEHtmlElementCollection::SetParentNode(IDispatch *pIDispParent) return S_OK; } -HRESULT CIEHtmlElementCollection::CreateFromParentNode(CIEHtmlNode *pParentNode, CIEHtmlElementCollection **pInstance) + +struct NodeListPos +{ + nsIDOMNodeList *m_pIDOMNodeList; + PRUint32 m_nListPos; + + NodeListPos(nsIDOMNodeList *pIDOMNodeList, PRUint32 nListPos) : + m_pIDOMNodeList(pIDOMNodeList), + m_nListPos(nListPos) + { + } + + NodeListPos() + { + }; +}; + + +HRESULT CIEHtmlElementCollection::CreateFromParentNode(CIEHtmlNode *pParentNode, CIEHtmlElementCollection **pInstance, BOOL bRecurseChildren) { if (pInstance == NULL) { @@ -63,13 +84,25 @@ HRESULT CIEHtmlElementCollection::CreateFromParentNode(CIEHtmlNode *pParentNode, pCollection->SetParentNode(cpDispNode); // Get elements + + std::stack< NodeListPos > cNodeStack; + nsIDOMNodeList *pIDOMNodeList = nsnull; pIDOMNode->GetChildNodes(&pIDOMNodeList); + if (pIDOMNodeList) { + cNodeStack.push(NodeListPos(pIDOMNodeList, 0)); + } + while (!cNodeStack.empty()) + { + NodeListPos pos = cNodeStack.top(); + cNodeStack.pop(); + + nsIDOMNodeList *pIDOMNodeList = pos.m_pIDOMNodeList; PRUint32 aLength = 0; pIDOMNodeList->GetLength(&aLength); - for (PRUint32 i = 0; i < aLength; i++) + for (PRUint32 i = pos.m_nListPos; i < aLength; i++) { nsIDOMNode *pChildNode = nsnull; pIDOMNodeList->Item(i, &pChildNode); @@ -86,6 +119,12 @@ HRESULT CIEHtmlElementCollection::CreateFromParentNode(CIEHtmlNode *pParentNode, pElement->SetDOMNode(pChildNode); pElement->SetParentNode(pCollection->m_pIDispParent); pCollection->AddNode(pElement); + + if (bRecurseChildren) + { + // TODO recurse through + CIPtr(IHTMLElementCollection) cpCollection; + } } pChildNode->Release(); } diff --git a/webshell/embed/ActiveX/IEHtmlElementCollection.h b/webshell/embed/ActiveX/IEHtmlElementCollection.h index e1205b81e439..236b1ee6739a 100644 --- a/webshell/embed/ActiveX/IEHtmlElementCollection.h +++ b/webshell/embed/ActiveX/IEHtmlElementCollection.h @@ -22,13 +22,20 @@ class CIEHtmlElement; + + class CIEHtmlElementCollection : public CComObjectRootEx, public IDispatchImpl { - std::vector< CComQIPtr > m_cNodeList; +public: + typedef std::vector< CIPtr(IDispatch) > ElementList; + +private: + ElementList m_cNodeList; public: CIEHtmlElementCollection(); + protected: virtual ~CIEHtmlElementCollection(); @@ -43,7 +50,13 @@ public: virtual HRESULT SetParentNode(IDispatch *pIDispParent); // Helper method creates a collection from a parent node - static HRESULT CreateFromParentNode(CIEHtmlNode *pParentNode, CIEHtmlElementCollection **pInstance); + static HRESULT CreateFromParentNode(CIEHtmlNode *pParentNode, CIEHtmlElementCollection **pInstance, BOOL bRecurseChildren = FALSE); + + + ElementList &GetElements() + { + return m_cNodeList; + } BEGIN_COM_MAP(CIEHtmlElementCollection) COM_INTERFACE_ENTRY_IID(IID_IDispatch, IHTMLElementCollection)