207 lines
5.6 KiB
C++
207 lines
5.6 KiB
C++
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*-
|
|
*
|
|
* (C) Copyright The MITRE Corporation 1999 All rights reserved.
|
|
*
|
|
* The contents of this file are subject to the Mozilla Public License
|
|
* Version 1.0 (the "License"); you may not use this file except in
|
|
* compliance with the License. You may obtain a copy of the License at
|
|
* http://www.mozilla.org/MPL/
|
|
*
|
|
* The program provided "as is" without any warranty express or
|
|
* implied, including the warranty of non-infringement and the implied
|
|
* warranties of merchantibility and fitness for a particular purpose.
|
|
* The Copyright owner will not be liable for any damages suffered by
|
|
* you as a result of using the Program. In no event will the Copyright
|
|
* owner be liable for any special, indirect or consequential damages or
|
|
* lost profits even if the Copyright owner has been advised of the
|
|
* possibility of their occurrence.
|
|
*
|
|
* Please see release.txt distributed with this file for more information.
|
|
*
|
|
*/
|
|
// Tom Kneeland (3/29/99)
|
|
//
|
|
// Implementation of the Document Object Model Level 1 Core
|
|
// Implementation of the Attr class
|
|
//
|
|
|
|
#include "dom.h"
|
|
#include "txAtoms.h"
|
|
#include "XMLUtils.h"
|
|
|
|
//
|
|
//Construct an Attribute object using the specified name and document owner
|
|
//
|
|
Attr::Attr(const String& name, Document* owner):
|
|
NodeDefinition(Node::ATTRIBUTE_NODE, name, NULL_STRING, owner)
|
|
{
|
|
int idx = nodeName.indexOf(':');
|
|
if (idx == kNotFound) {
|
|
mLocalName = TX_GET_ATOM(nodeName);
|
|
if (mLocalName == txXMLAtoms::xmlns)
|
|
mNamespaceID = kNameSpaceID_XMLNS;
|
|
else
|
|
mNamespaceID = kNameSpaceID_None;
|
|
}
|
|
else {
|
|
String tmp;
|
|
nodeName.subString(idx + 1, tmp);
|
|
mLocalName = TX_GET_ATOM(tmp);
|
|
// namespace handling has to be handled late, the attribute must
|
|
// be added to the tree to resolve the prefix, unless it's
|
|
// xmlns or xml, try to do that here
|
|
String prefix;
|
|
nodeName.subString(0, idx, prefix);
|
|
txAtom* prefixAtom = TX_GET_ATOM(prefix);
|
|
if (prefixAtom == txXMLAtoms::xmlns)
|
|
mNamespaceID = kNameSpaceID_XMLNS;
|
|
else if (prefixAtom == txXMLAtoms::xml)
|
|
mNamespaceID = kNameSpaceID_XML;
|
|
else
|
|
mNamespaceID = kNameSpaceID_Unknown;
|
|
TX_IF_RELEASE_ATOM(prefixAtom);
|
|
}
|
|
}
|
|
|
|
Attr::Attr(const String& aNamespaceURI,
|
|
const String& aName,
|
|
Document* aOwner) :
|
|
NodeDefinition(Node::ATTRIBUTE_NODE, aName, NULL_STRING, aOwner)
|
|
{
|
|
if (aNamespaceURI.IsEmpty())
|
|
mNamespaceID = kNameSpaceID_None;
|
|
else
|
|
mNamespaceID = txNamespaceManager::getNamespaceID(aNamespaceURI);
|
|
|
|
String localPart;
|
|
XMLUtils::getLocalPart(nodeName, localPart);
|
|
mLocalName = TX_GET_ATOM(localPart);
|
|
}
|
|
|
|
//
|
|
//Release the mLocalName
|
|
//
|
|
Attr::~Attr()
|
|
{
|
|
TX_IF_RELEASE_ATOM(mLocalName);
|
|
}
|
|
|
|
//
|
|
//Retrieve the value of the attribute. This is a comma-deliminated string
|
|
//representation of the Attribute's children.
|
|
//
|
|
const String& Attr::getValue()
|
|
{
|
|
nodeValue = NULL_STRING;
|
|
|
|
Node* child = getFirstChild();
|
|
while (child) {
|
|
if (child->getNodeType() != Node::ENTITY_REFERENCE_NODE) {
|
|
nodeValue.Append(child->getNodeValue());
|
|
child = child->getNextSibling();
|
|
if (child)
|
|
nodeValue.Append(PRUnichar(','));
|
|
} else {
|
|
child = child->getNextSibling();
|
|
}
|
|
}
|
|
return nodeValue;
|
|
}
|
|
|
|
//
|
|
//Create a new Text node and add it to the Attribute's list of children. Also
|
|
//set the Specified flag to true.
|
|
//
|
|
void Attr::setValue(const String& newValue)
|
|
{
|
|
NodeDefinition::DeleteChildren();
|
|
|
|
appendChild(getOwnerDocument()->createTextNode(newValue));
|
|
}
|
|
|
|
|
|
//
|
|
//Override the set node value member function to create a new TEXT node with
|
|
//the String and to add it as the Attribute's child.
|
|
// NOTE: Not currently impemented, just execute the default setNodeValue
|
|
//
|
|
void Attr::setNodeValue(const String& nodeValue)
|
|
{
|
|
setValue(nodeValue);
|
|
}
|
|
|
|
//
|
|
//Return a String represening the value of this node. If the value is an
|
|
//Entity Reference then return the value of the reference. Otherwise, it is a
|
|
//simple conversion of the text value.
|
|
// NOTE: Not currently implemented, just execute the default getNodeValue
|
|
//
|
|
const String& Attr::getNodeValue()
|
|
{
|
|
return getValue();
|
|
}
|
|
|
|
//
|
|
//First check to see if the new node is an allowable child for an Attr. If it
|
|
//is, call NodeDefinition's implementation of AppendChild. If not, return
|
|
//null as an error.
|
|
//
|
|
Node* Attr::appendChild(Node* newChild)
|
|
{
|
|
switch (newChild->getNodeType())
|
|
{
|
|
case Node::TEXT_NODE :
|
|
{
|
|
// Remove the "newChild" if it is already a child of this node
|
|
NodeDefinition* pNewChild = (NodeDefinition*)newChild;
|
|
if (pNewChild->getParentNode() == this)
|
|
pNewChild = implRemoveChild(pNewChild);
|
|
|
|
return implAppendChild(pNewChild);
|
|
}
|
|
default:
|
|
break;
|
|
}
|
|
|
|
return nsnull;
|
|
}
|
|
|
|
//
|
|
//Return the attributes local (unprefixed) name atom.
|
|
//
|
|
MBool Attr::getLocalName(txAtom** aLocalName)
|
|
{
|
|
if (!aLocalName)
|
|
return MB_FALSE;
|
|
*aLocalName = mLocalName;
|
|
TX_ADDREF_ATOM(*aLocalName);
|
|
return MB_TRUE;
|
|
}
|
|
|
|
//
|
|
//Return the namespace the attribute belongs to. If the attribute doesn't
|
|
//have a prefix it doesn't belong to any namespace per the namespace spec,
|
|
//and is handled in the constructor.
|
|
//
|
|
PRInt32 Attr::getNamespaceID()
|
|
{
|
|
if (mNamespaceID >= 0)
|
|
return mNamespaceID;
|
|
|
|
int idx = nodeName.indexOf(':');
|
|
String prefix;
|
|
nodeName.subString(0, idx, prefix);
|
|
txAtom* prefixAtom = TX_GET_ATOM(prefix);
|
|
mNamespaceID = lookupNamespaceID(prefixAtom);
|
|
TX_IF_RELEASE_ATOM(prefixAtom);
|
|
return mNamespaceID;
|
|
}
|
|
|
|
//
|
|
//Return the attributes owning element
|
|
//
|
|
Node* Attr::getXPathParent()
|
|
{
|
|
return ownerElement;
|
|
}
|