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:
jst%netscape.com
2000-05-10 13:13:39 +00:00
parent 5c4b1fc694
commit 0f0b4d6367
197 changed files with 3128 additions and 2424 deletions

View File

@@ -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;
}