org.jdom
Class Namespace


public final class Namespace

Namespace defines both a factory for creating XML namespaces, and a namespace itself. This class represents an XML namespace in Java.

Elements and Attributes containing Namespaces can be serialized; however the Namespace class itself does not implement java.io.Serializable. This works because the Element and Attribute classes handle serialization of their Namespaces manually. The classes use the getNamespace() method on deserialization to ensure there may be only one unique Namespace object for any unique prefix/uri pair, something needed for efficiency reasons.

Author:
Brett McLaughlin, Elliotte Rusty Harold, Wesley Biggs
Version: 1.0

Field Summary
 final static NamespaceNO_NAMESPACE
          Define a Namespace for when not in a namespace
 final static NamespaceXML_NAMESPACE
           

Method Summary
 booleanequals(Object ob)
           This tests for equality - Two Namespaces are equal if and only if their URIs are byte-for-byte equals and their prefixes are equal.
 static NamespacegetNamespace(String prefix, String uri)
           This will retrieve (if in existence) or create (if not) a Namespace for the supplied prefix and URI.
 static NamespacegetNamespace(String uri)
           This will retrieve (if in existence) or create (if not) a Namespace for the supplied URI, and make it usable as a default namespace, as no prefix is supplied.
 StringgetPrefix()
           This returns the prefix mapped to this Namespace.
 StringgetURI()
           This returns the namespace URI for this Namespace.
 inthashCode()
           This returns a probably unique hash code for the Namespace.
 StringtoString()
           This returns a String representation of this Namespace, suitable for use in debugging.

Field Detail

NO_NAMESPACE

public final static Namespace NO_NAMESPACE
Define a Namespace for when not in a namespace

XML_NAMESPACE

public final static Namespace XML_NAMESPACE
Method Detail

equals

public boolean equals(Object ob)

This tests for equality - Two Namespaces are equal if and only if their URIs are byte-for-byte equals and their prefixes are equal.

Parameters:
ob - Object to compare to this Namespace.
Returns: boolean - whether the supplied object is equal to this Namespace.

getNamespace

public static Namespace getNamespace(String prefix, String uri)

This will retrieve (if in existence) or create (if not) a Namespace for the supplied prefix and URI.

Note: Because the prefix of an XML namespace is both non-normative and not an intrinsic part of the Namespace, it is possible that the supplied uri is already attached to a Namespace, and a different prefix is used by it. In this case, the existing Namespace is returned, with the different prefix, and the supplied prefix is ignored. This is perfectly legal XML namespace behavior.

Parameters:
prefix - String prefix to map to Namespace.
uri - String URI of new Namespace.
Returns: Namespace - ready to use namespace.

getNamespace

public static Namespace getNamespace(String uri)

This will retrieve (if in existence) or create (if not) a Namespace for the supplied URI, and make it usable as a default namespace, as no prefix is supplied.

Parameters:
uri - String URI of new Namespace.
Returns: Namespace - ready to use namespace.

getPrefix

public String getPrefix()

This returns the prefix mapped to this Namespace.

Returns: String - prefix for this Namespace.

getURI

public String getURI()

This returns the namespace URI for this Namespace.

Returns: String - URI for this Namespace.

hashCode

public int hashCode()

This returns a probably unique hash code for the Namespace. If two namespaces have the same URI, they are equal and have the same hash code, even if they have different prefixes.

Returns: int - hash code for this Namespace.

toString

public String toString()

This returns a String representation of this Namespace, suitable for use in debugging.

Returns: String - information about this instance.

Association Links

to Class java.util.HashMap

Factory list of namespaces. Keys are prefix&URI. Values are Namespace objects

to Class java.util.HashMap

Factory list of mappings

to Class org.jdom.Namespace

Define a Namespace for when not in a namespace

to Class org.jdom.Namespace

to Class java.lang.String

The prefix mapped to this namespace

to Class java.lang.String

The URI for this namespace