annotate WebServiceExtensionsV1.1/WebServiceToolWorkflow_REST_SOAP/lib/SAWADLParser/src/javax/xml/namespace/QName.java @ 0:049760c677de default tip

Galaxy WSExtensions added successfully
author uga-galaxy-group
date Tue, 05 Jul 2011 19:34:18 -0400
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
1 //$Id: QName.java,v 1.10 2004/02/09 23:41:21 jsuttor Exp $
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
2
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
3 /*
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
4 * Copyright 2004 Sun Microsystems, Inc. All rights reserved.
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
5 * SUN PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
6 */
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
7
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
8 package javax.xml.namespace;
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
9
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
10 import java.io.Serializable;
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
11
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
12 import javax.xml.XMLConstants;
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
13
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
14 /**
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
15 * <p><code>QName</code> represents a <strong>qualified name</strong>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
16 * as defined in the XML specifications: <a
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
17 * href="http://www.w3.org/TR/xmlschema-2/#QName">XML Schema Part2:
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
18 * Datatypes specification</a>, <a
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
19 * href="http://www.w3.org/TR/REC-xml-names/#ns-qualnames">Namespaces
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
20 * in XML</a>, <a
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
21 * href="http://www.w3.org/XML/xml-names-19990114-errata">Namespaces
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
22 * in XML Errata</a>.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
23 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
24 * <p>The value of a <code>QName</code> contains a <strong>Namespace
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
25 * URI</strong>, <strong>local part</strong> and
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
26 * <strong>prefix</strong>.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
27 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
28 * <p>The prefix is included in <code>QName</code> to retain lexical
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
29 * information <strong><em>when present</em></strong> in an {@link
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
30 * javax.xml.transform.Source XML input source}. The prefix is
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
31 * <strong><em>NOT</em></strong> used in {@link #equals(Object)
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
32 * QName.equals(Object)} or to compute the {@link #hashCode()
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
33 * QName.hashCode()}. Equality and the hash code are defined using
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
34 * <strong><em>only</em></strong> the Namespace URI and local part.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
35 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
36 * <p>If not specified, the Namespace URI is set to {@link
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
37 * javax.xml.XMLConstants#NULL_NS_URI XMLConstants.NULL_NS_URI}.
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
38 * If not specified, the prefix is set to {@link
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
39 * javax.xml.XMLConstants#DEFAULT_NS_PREFIX
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
40 * XMLConstants.DEFAULT_NS_PREFIX}.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
41 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
42 * <p><code>QName</code> is immutable.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
43 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
44 * @author <a href="mailto:Jeff.Suttor@Sun.com">Jeff Suttor</a>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
45 * @version $Revision: 1.10 $, $Date: 2004/02/09 23:41:21 $
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
46 * @see <a href="http://www.w3.org/TR/xmlschema-2/#QName">XML Schema Part2: Datatypes specification</a>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
47 * @see <a href="http://www.w3.org/TR/REC-xml-names/#ns-qualnames">Namespaces in XML</a>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
48 * @see <a href="http://www.w3.org/XML/xml-names-19990114-errata">Namespaces in XML Errata</a>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
49 * @since 1.5
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
50 */
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
51
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
52 public class QName implements Serializable {
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
53
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
54 /**
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
55 * <p>Stream Unique Identifier.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
56 */
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
57 private static final long serialVersionUID = 4418622981026545151L;
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
58
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
59 /**
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
60 * <p>Namespace URI of this <code>QName</code>.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
61 */
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
62 private final String namespaceURI;
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
63
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
64 /**
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
65 * <p>local part of this <code>QName</code>.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
66 */
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
67 private final String localPart;
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
68
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
69 /**
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
70 * <p>prefix of this <code>QName</code>.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
71 */
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
72 private final String prefix;
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
73
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
74 /**
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
75 * <p><code>QName</code> constructor specifying the Namespace URI
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
76 * and local part.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
77 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
78 * <p>If the Namespace URI is <code>null</code>, it is set to
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
79 * {@link javax.xml.XMLConstants#NULL_NS_URI
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
80 * XMLConstants.NULL_NS_URI}. This value represents no
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
81 * explicitly defined Namespace as defined by the <a
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
82 * href="http://www.w3.org/TR/REC-xml-names/#ns-qualnames">Namespaces
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
83 * in XML</a> specification. This action preserves compatible
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
84 * behavior with QName 1.0. Explicitly providing the {@link
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
85 * javax.xml.XMLConstants#NULL_NS_URI
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
86 * XMLConstants.NULL_NS_URI} value is the preferred coding
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
87 * style.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
88 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
89 * <p>If the local part is <code>null</code> an
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
90 * <code>IllegalArgumentException</code> is thrown.
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
91 * A local part of "" is allowed to preserve
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
92 * compatible behavior with QName 1.0. </p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
93 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
94 * <p>When using this constructor, the prefix is set to {@link
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
95 * javax.xml.XMLConstants#DEFAULT_NS_PREFIX
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
96 * XMLConstants.DEFAULT_NS_PREFIX}.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
97 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
98 * <p>The Namespace URI is not validated as a
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
99 * <a href="http://www.ietf.org/rfc/rfc2396.txt">URI reference</a>.
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
100 * The local part is not validated as a
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
101 * <a href="http://www.w3.org/TR/REC-xml-names/#NT-NCName">NCName</a>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
102 * as specified in <a href="http://www.w3.org/TR/REC-xml-names/">Namespaces
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
103 * in XML</a>.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
104 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
105 * @param namespaceURI Namespace URI of the <code>QName</code>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
106 * @param localPart local part of the <code>QName</code>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
107 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
108 * @see #QName(String namespaceURI, String localPart, String
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
109 * prefix) QName(String namespaceURI, String localPart, String
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
110 * prefix)
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
111 */
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
112 public QName(final String namespaceURI, final String localPart) {
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
113 this(namespaceURI, localPart, XMLConstants.DEFAULT_NS_PREFIX);
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
114 }
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
115
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
116 /**
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
117 * <p><code>QName</code> constructor specifying the Namespace URI,
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
118 * local part and prefix.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
119 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
120 * <p>If the Namespace URI is <code>null</code>, it is set to
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
121 * {@link javax.xml.XMLConstants#NULL_NS_URI
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
122 * XMLConstants.NULL_NS_URI}. This value represents no
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
123 * explicitly defined Namespace as defined by the <a
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
124 * href="http://www.w3.org/TR/REC-xml-names/#ns-qualnames">Namespaces
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
125 * in XML</a> specification. This action preserves compatible
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
126 * behavior with QName 1.0. Explicitly providing the {@link
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
127 * javax.xml.XMLConstants#NULL_NS_URI
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
128 * XMLConstants.NULL_NS_URI} value is the preferred coding
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
129 * style.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
130 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
131 * <p>If the local part is <code>null</code> an
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
132 * <code>IllegalArgumentException</code> is thrown.
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
133 * A local part of "" is allowed to preserve
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
134 * compatible behavior with QName 1.0. </p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
135 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
136 * <p>If the prefix is <code>null</code>, an
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
137 * <code>IllegalArgumentException</code> is thrown. Use {@link
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
138 * javax.xml.XMLConstants#DEFAULT_NS_PREFIX
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
139 * XMLConstants.DEFAULT_NS_PREFIX} to explicitly indicate that no
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
140 * prefix is present or the prefix is not relevant.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
141 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
142 * <p>The Namespace URI is not validated as a
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
143 * <a href="http://www.ietf.org/rfc/rfc2396.txt">URI reference</a>.
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
144 * The local part and prefix are not validated as a
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
145 * <a href="http://www.w3.org/TR/REC-xml-names/#NT-NCName">NCName</a>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
146 * as specified in <a href="http://www.w3.org/TR/REC-xml-names/">Namespaces
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
147 * in XML</a>.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
148 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
149 * @param namespaceURI Namespace URI of the <code>QName<code>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
150 * @param localPart local part of the <code>QName<code>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
151 * @param prefix prefix of the <code>QName<code>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
152 */
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
153 public QName(String namespaceURI, String localPart, String prefix) {
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
154
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
155 // map null Namespace URI to default to preserve compatibility with QName 1.0
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
156 if (namespaceURI == null) {
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
157 this.namespaceURI = XMLConstants.NULL_NS_URI;
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
158 } else {
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
159 this.namespaceURI = namespaceURI;
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
160 }
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
161
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
162 // local part is required. "" is allowed to preserve compatibility with QName 1.0
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
163 if (localPart == null) {
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
164 throw new IllegalArgumentException("local part cannot be \"null\" when creating a QName");
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
165 }
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
166 this.localPart = localPart;
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
167
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
168 // prefix is required
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
169 if (prefix == null) {
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
170 throw new IllegalArgumentException("prefix cannot be \"null\" when creating a QName");
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
171 }
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
172 this.prefix = prefix;
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
173 }
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
174
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
175 /**
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
176 * <p><code>QName</code> constructor specifying the local part.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
177 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
178 * <p>If the local part is <code>null</code> an
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
179 * <code>IllegalArgumentException</code> is thrown.
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
180 * A local part of "" is allowed to preserve
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
181 * compatible behavior with QName 1.0. </p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
182 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
183 * <p>When using this constructor, the Namespace URI is set to
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
184 * {@link javax.xml.XMLConstants#NULL_NS_URI
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
185 * XMLConstants.NULL_NS_URI} and the prefix is set to {@link
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
186 * javax.xml.XMLConstants#DEFAULT_NS_PREFIX
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
187 * XMLConstants.DEFAULT_NS_PREFIX}.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
188 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
189 * <p><em>In an XML context, all Element and Attribute names exist
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
190 * in the context of a Namespace. Making this explicit during the
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
191 * construction of a <code>QName</code> helps prevent hard to
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
192 * diagnosis XML validity errors. The constructors {@link
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
193 * #QName(String namespaceURI, String localPart) QName(String
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
194 * namespaceURI, String localPart)} and
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
195 * {@link #QName(String namespaceURI, String localPart, String prefix)}
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
196 * are preferred.</em></p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
197 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
198 * <p>The local part is not validated as a
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
199 * <a href="http://www.w3.org/TR/REC-xml-names/#NT-NCName">NCName</a>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
200 * as specified in <a href="http://www.w3.org/TR/REC-xml-names/">Namespaces
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
201 * in XML</a>.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
202 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
203 * @param localPart local part of the <code>QName</code>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
204 * @see #QName(String namespaceURI, String localPart) QName(String
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
205 * namespaceURI, String localPart)
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
206 * @see #QName(String namespaceURI, String localPart, String
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
207 * prefix) QName(String namespaceURI, String localPart, String
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
208 * prefix)
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
209 */
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
210 public QName(String localPart) {
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
211 this(
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
212 XMLConstants.NULL_NS_URI,
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
213 localPart,
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
214 XMLConstants.DEFAULT_NS_PREFIX);
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
215 }
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
216
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
217 /**
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
218 * <p>Get the Namespace URI of this <code>QName</code>.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
219 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
220 * @return Namespace URI of this <code>QName</code>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
221 */
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
222 public String getNamespaceURI() {
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
223 return namespaceURI;
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
224 }
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
225
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
226 /**
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
227 * <p>Get the local part of this <code>QName</code>.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
228 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
229 * @return local part of this <code>QName</code>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
230 */
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
231 public String getLocalPart() {
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
232 return localPart;
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
233 }
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
234
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
235 /**
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
236 * <p>Get the prefix of this <code>QName</code>.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
237 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
238 * <p>The prefix assigned to a <code>QName</code> might
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
239 * <strong><em>NOT</em></strong> be valid in a different
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
240 * context. For example, a <code>QName</code> may be assigned a
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
241 * prefix in the context of parsing a document but that prefix may
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
242 * be invalid in the context of a different document.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
243 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
244 * @return prefix of this <code>QName</code>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
245 */
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
246 public String getPrefix() {
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
247 return prefix;
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
248 }
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
249
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
250 /**
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
251 * <p>Test this <code>QName</code> for equality with another
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
252 * <code>Object</code>.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
253 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
254 * <p>If the <code>Object</code> to be tested is not a
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
255 * <code>QName</code> or is <code>null</code>, then this method
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
256 * returns <code>false</code>.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
257 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
258 * <p>Two <code>QName</code>s are considered equal if and only if
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
259 * both the Namespace URI and local part are equal. This method
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
260 * uses <code>String.equals()</code> to check equality of the
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
261 * Namespace URI and local part. The prefix is
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
262 * <strong><em>NOT</em></strong> used to determine equality.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
263 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
264 * <p>This method satisfies the general contract of {@link
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
265 * java.lang.Object#equals(Object) Object.equals(Object)}</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
266 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
267 * @param objectToTest the <code>Object</code> to test for
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
268 * equality with this <code>QName</code>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
269 * @return <code>true</code> if the given <code>Object</code> is
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
270 * equal to this <code>QName</code> else <code>false</code>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
271 */
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
272 public final boolean equals(Object objectToTest) {
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
273 if (objectToTest == null || !(objectToTest instanceof QName)) {
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
274 return false;
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
275 }
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
276
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
277 QName qName = (QName) objectToTest;
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
278
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
279 return namespaceURI.equals(qName.namespaceURI)
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
280 && localPart.equals(qName.localPart);
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
281 }
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
282
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
283 /**
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
284 * <p>Generate the hash code for this <code>QName</code>.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
285 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
286 * <p>The hash code is calculated using both the Namespace URI and
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
287 * the local part of the <code>QName</code>. The prefix is
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
288 * <strong><em>NOT</em></strong> used to calculate the hash
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
289 * code.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
290 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
291 * <p>This method satisfies the general contract of {@link
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
292 * java.lang.Object#hashCode() Object.hashCode()}.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
293 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
294 * @return hash code for this <code>QName</code> <code>Object</code>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
295 */
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
296 public final int hashCode() {
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
297 return namespaceURI.hashCode() ^ localPart.hashCode();
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
298 }
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
299
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
300 /**
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
301 * <p><code>String</code> representation of this
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
302 * <code>QName</code>.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
303 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
304 * <p>The commonly accepted way of representing a <code>QName</code>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
305 * as a <code>String</code> was <a href="http://jclark.com/xml/xmlns.htm">defined</a>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
306 * by James Clark. Although this is not a <em>standard</em>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
307 * specification, it is in common use, e.g. {@link javax.xml.transform.Transformer#setParameter(String name, Object value)}.
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
308 * This implementation represents a <code>QName</code> as:
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
309 * "{" + Namespace URI + "}" + local part. If the Namespace URI
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
310 * <code>.equals(XMLConstants.NULL_NS_URI)</code>, only the
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
311 * local part is returned. An appropriate use of this method is
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
312 * for debugging or logging for human consumption.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
313 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
314 * <p>Note the prefix value is <strong><em>NOT</em></strong>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
315 * returned as part of the <code>String</code> representation.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
316 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
317 * <p>This method satisfies the general contract of {@link
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
318 * java.lang.Object#toString() Object.toString()}.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
319 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
320 * @return <code>String</code> representation of this <code>QName</code>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
321 */
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
322 public String toString() {
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
323 if (namespaceURI.equals(XMLConstants.NULL_NS_URI)) {
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
324 return localPart;
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
325 } else {
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
326 return "{" + namespaceURI + "}" + localPart;
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
327 }
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
328 }
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
329
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
330 /**
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
331 * <p><code>QName</code> derived from parsing the formatted
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
332 * <code>String</code>.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
333 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
334 * <p>If the <code>String</code> is <code>null</code> or does not conform to
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
335 * {@link #toString() QName.toString()} formatting, an
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
336 * <code>IllegalArgumentException</code> is thrown.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
337 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
338 * <p><em>The <code>String</code> <strong>MUST</strong> be in the
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
339 * form returned by {@link #toString() QName.toString()}.</em></p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
340
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
341 * <p>The commonly accepted way of representing a <code>QName</code>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
342 * as a <code>String</code> was <a href="http://jclark.com/xml/xmlns.htm">defined</a>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
343 * by James Clark. Although this is not a <em>standard</em>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
344 * specification, it is in common use, e.g. {@link javax.xml.transform.Transformer#setParameter(String name, Object value)}.
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
345 * This implementation parses a <code>String</code> formatted
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
346 * as: "{" + Namespace URI + "}" + local part. If the Namespace
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
347 * URI <code>.equals(XMLConstants.NULL_NS_URI)</code>, only the
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
348 * local part should be provided.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
349 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
350 * <p>The prefix value <strong><em>CANNOT</em></strong> be
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
351 * represented in the <code>String</code> and will be set to
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
352 * {@link javax.xml.XMLConstants#DEFAULT_NS_PREFIX
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
353 * XMLConstants.DEFAULT_NS_PREFIX}.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
354 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
355 * <p>This method does not do full validation of the resulting
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
356 * <code>QName</code>.
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
357 * <p>The Namespace URI is not validated as a
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
358 * <a href="http://www.ietf.org/rfc/rfc2396.txt">URI reference</a>.
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
359 * The local part is not validated as a
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
360 * <a href="http://www.w3.org/TR/REC-xml-names/#NT-NCName">NCName</a>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
361 * as specified in
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
362 * <a href="http://www.w3.org/TR/REC-xml-names/">Namespaces in XML</a>.</p>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
363 *
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
364 * @param qNameAsString <code>String</code> representation
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
365 * of the <code>QName</code>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
366 * @return <code>QName</code> corresponding to the given <code>String</code>
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
367 * @see #toString() QName.toString()
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
368 */
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
369 public static QName valueOf(String qNameAsString) {
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
370
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
371 // null is not valid
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
372 if (qNameAsString == null) {
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
373 throw new IllegalArgumentException("cannot create QName from \"null\" or \"\" String");
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
374 }
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
375
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
376 // "" local part is valid to preserve compatible behavior with QName 1.0
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
377 if (qNameAsString.length() == 0) {
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
378 return new QName(
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
379 XMLConstants.NULL_NS_URI,
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
380 qNameAsString,
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
381 XMLConstants.DEFAULT_NS_PREFIX);
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
382 }
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
383
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
384 // local part only?
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
385 if (qNameAsString.charAt(0) != '{') {
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
386 return new QName(
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
387 XMLConstants.NULL_NS_URI,
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
388 qNameAsString,
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
389 XMLConstants.DEFAULT_NS_PREFIX);
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
390 }
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
391
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
392 // Namespace URI improperly specified?
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
393 if (qNameAsString.startsWith("{" + XMLConstants.NULL_NS_URI + "}")) {
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
394 throw new IllegalArgumentException(
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
395 "Namespace URI .equals(XMLConstants.NULL_NS_URI), "
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
396 + ".equals(\"" + XMLConstants.NULL_NS_URI + "\"), "
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
397 + "only the local part, "
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
398 + "\"" + qNameAsString.substring(2 + XMLConstants.NULL_NS_URI.length()) + "\", "
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
399 + "should be provided.");
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
400 }
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
401
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
402 // Namespace URI and local part specified
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
403 int endOfNamespaceURI = qNameAsString.indexOf('}');
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
404 if (endOfNamespaceURI == -1) {
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
405 throw new IllegalArgumentException(
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
406 "cannot create QName from \""
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
407 + qNameAsString
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
408 + "\", missing closing \"}\"");
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
409 }
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
410 return new QName(
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
411 qNameAsString.substring(1, endOfNamespaceURI),
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
412 qNameAsString.substring(endOfNamespaceURI + 1),
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
413 XMLConstants.DEFAULT_NS_PREFIX);
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
414 }
049760c677de Galaxy WSExtensions added successfully
uga-galaxy-group
parents:
diff changeset
415 }