View Javadoc

1   /*** 
2    * 
3    * Copyright 2004 Protique Ltd
4    * 
5    * Licensed under the Apache License, Version 2.0 (the "License"); 
6    * you may not use this file except in compliance with the License. 
7    * You may obtain a copy of the License at 
8    * 
9    * http://www.apache.org/licenses/LICENSE-2.0
10   * 
11   * Unless required by applicable law or agreed to in writing, software
12   * distributed under the License is distributed on an "AS IS" BASIS, 
13   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 
14   * See the License for the specific language governing permissions and 
15   * limitations under the License. 
16   * 
17   **/
18  package org.codehaus.activesoap.util;
19  
20  import javax.xml.namespace.QName;
21  import javax.xml.namespace.NamespaceContext;
22  
23  /***
24   * @version $Revision: 1.1 $
25   */
26  public class QNameHelper {
27      public static String getQualifiedName(QName qname) {
28          String prefix = qname.getPrefix();
29          String localPart = qname.getLocalPart();
30          if (prefix != null && prefix.length() > 0) {
31              return prefix + ":" + localPart;
32          }
33          return localPart;
34      }
35  
36      /***
37       * Turns the given String into a QName using the current namespace context
38       */
39      public static QName asQName(NamespaceContext context, String text) {
40          int idx = text.indexOf(':');
41          if (idx >= 0) {
42              String prefix = text.substring(0, idx);
43              String localPart = text.substring(idx + 1);
44              String uri = context.getNamespaceURI(prefix);
45              return new QName(uri, localPart, prefix);
46          }
47          else {
48              return new QName(text);
49          }
50      }
51  }