Changing the way content elements store their name information, previously the elements generally stored a name atom and a namespace ID, now they store a pointer to a shared structure containing the name atom, the prefix atom and the namespace ID. This structure is shared between nodes with unique names (ie same name, prefix and ns ID) within a document. Documents now hold a hash table of the names in the document. The changes to mozilla/rdf are not reviewed but they are approved by waterson@netscape.com and the changes to mozilla/layout are reviewed by buster@netscape.com.
git-svn-id: svn://10.0.0.236/trunk@69034 18797224-902f-48f8-a5cc-f745e15eee43
This commit is contained in:
@@ -42,7 +42,7 @@ class nsHTMLTableColElement : public nsIDOMHTMLTableColElement,
|
||||
public nsIHTMLContent
|
||||
{
|
||||
public:
|
||||
nsHTMLTableColElement(nsIAtom* aTag);
|
||||
nsHTMLTableColElement(nsINodeInfo *aNodeInfo);
|
||||
virtual ~nsHTMLTableColElement();
|
||||
|
||||
// nsISupports
|
||||
@@ -88,13 +88,13 @@ protected:
|
||||
};
|
||||
|
||||
nsresult
|
||||
NS_NewHTMLTableColElement(nsIHTMLContent** aInstancePtrResult, nsIAtom* aTag)
|
||||
NS_NewHTMLTableColElement(nsIHTMLContent** aInstancePtrResult,
|
||||
nsINodeInfo *aNodeInfo)
|
||||
{
|
||||
NS_PRECONDITION(nsnull != aInstancePtrResult, "null ptr");
|
||||
if (nsnull == aInstancePtrResult) {
|
||||
return NS_ERROR_NULL_POINTER;
|
||||
}
|
||||
nsIHTMLContent* it = new nsHTMLTableColElement(aTag);
|
||||
NS_ENSURE_ARG_POINTER(aInstancePtrResult);
|
||||
NS_ENSURE_ARG_POINTER(aNodeInfo);
|
||||
|
||||
nsIHTMLContent* it = new nsHTMLTableColElement(aNodeInfo);
|
||||
if (nsnull == it) {
|
||||
return NS_ERROR_OUT_OF_MEMORY;
|
||||
}
|
||||
@@ -102,10 +102,10 @@ NS_NewHTMLTableColElement(nsIHTMLContent** aInstancePtrResult, nsIAtom* aTag)
|
||||
}
|
||||
|
||||
|
||||
nsHTMLTableColElement::nsHTMLTableColElement(nsIAtom* aTag)
|
||||
nsHTMLTableColElement::nsHTMLTableColElement(nsINodeInfo *aNodeInfo)
|
||||
{
|
||||
NS_INIT_REFCNT();
|
||||
mInner.Init(this, aTag);
|
||||
mInner.Init(this, aNodeInfo);
|
||||
}
|
||||
|
||||
nsHTMLTableColElement::~nsHTMLTableColElement()
|
||||
@@ -138,7 +138,7 @@ nsHTMLTableColElement::QueryInterface(REFNSIID aIID, void** aInstancePtr)
|
||||
nsresult
|
||||
nsHTMLTableColElement::CloneNode(PRBool aDeep, nsIDOMNode** aReturn)
|
||||
{
|
||||
nsHTMLTableColElement* it = new nsHTMLTableColElement(mInner.mTag);
|
||||
nsHTMLTableColElement* it = new nsHTMLTableColElement(mInner.mNodeInfo);
|
||||
if (nsnull == it) {
|
||||
return NS_ERROR_OUT_OF_MEMORY;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user