/*
* eXist Open Source Native XML Database
* Copyright (C) 2001-04 Wolfgang M. Meier
* wolfgang@exist-db.org
* http://exist-db.org
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*
* $Id$
*/
package org.exist.memtree;
import org.exist.Namespaces;
import org.exist.dom.QName;
import org.exist.dom.QNameable;
import org.exist.xquery.value.Type;
import org.w3c.dom.Attr;
import org.w3c.dom.DOMException;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.TypeInfo;
/**
* A dynamically constructed namespace node. Used to track namespace
* declarations in elements. Implements Attr, so it can be treated as a normal
* attribute.
*
* @author wolf
*/
public class NamespaceNode extends NodeImpl implements Attr, QNameable {
/**
* @param doc
* @param nodeNumber
*/
public NamespaceNode(DocumentImpl doc, int nodeNumber) {
super(doc, nodeNumber);
}
/* (non-Javadoc)
* @see org.exist.memtree.NodeImpl#getNodeType()
*/
public short getNodeType() {
//TOUNDERSTAND : return value
//XQuery doesn't support namespace nodes
//so, mapping as an attribute at *serialization tile* makes sense
//however, the Query parser should not accept them in constructors !
return Node.ATTRIBUTE_NODE;
}
/* (non-Javadoc)
* @see org.exist.memtree.NodeImpl#getType()
*/
public int getType() {
return Type.NAMESPACE;
}
public String getPrefix() {
return getQName().getPrefix();
}
public String getNamespaceURI() {
return Namespaces.XMLNS_NS;
}
public boolean getSpecified() {
return true;
}
public QName getQName() {
return document.namespaceCode[nodeNumber];
}
/* (non-Javadoc)
* @see org.w3c.dom.Node#getLocalName()
*/
public String getLocalName() {
return getQName().getLocalName();
}
/* (non-Javadoc)
* @see org.w3c.dom.Node#getNodeName()
*/
public String getNodeName() {
return getQName().getStringValue();
}
public String getName() {
return getQName().getStringValue();
}
/* (non-Javadoc)
* @see org.w3c.dom.Attr#getValue()
*/
public String getValue() {
return getQName().getNamespaceURI();
}
/* (non-Javadoc)
* @see org.w3c.dom.Attr#setValue(java.lang.String)
*/
public void setValue(String value) throws DOMException {
}
public String getNodeValue() throws DOMException {
return getQName().getNamespaceURI();
}
/* (non-Javadoc)
* @see org.w3c.dom.Attr#getOwnerElement()
*/
public Element getOwnerElement() {
return (Element)document.getNode(document.namespaceParent[nodeNumber]);
}
/** ? @see org.w3c.dom.Attr#getSchemaTypeInfo()
*/
public TypeInfo getSchemaTypeInfo() {
// maybe TODO - new DOM interfaces - Java 5.0
return null;
}
/** ? @see org.w3c.dom.Attr#isId()
*/
public boolean isId() {
// maybe TODO - new DOM interfaces - Java 5.0
return false;
}
public int getItemType() {
return Type.NAMESPACE;
}
//Untested
public String toString() {
StringBuilder result = new StringBuilder();
result.append("in-memory#");
result.append("namespace {");
result.append(getPrefix());
result.append("}");
result.append("{");
result.append(getValue());
result.append("} ");
return result.toString();
}
}