/*
* JBoss, Home of Professional Open Source.
* Copyright 2011, Red Hat, Inc., and individual contributors
* as indicated by the @author tags. See the copyright.txt file in the
* distribution for a full listing of individual contributors.
*
* This 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.1 of
* the License, or (at your option) any later version.
*
* This software 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 software; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
*/
package org.teiid.jboss;
import java.util.HashMap;
import java.util.Map;
enum Namespace {
// must be first
UNKNOWN(null),
TEIID_1_1("urn:jboss:domain:teiid:1.1"); //$NON-NLS-1$
/**
* The current namespace version.
*/
public static final Namespace CURRENT = TEIID_1_1;
private final String uri;
Namespace(String uri) {
this.uri = uri;
}
/**
* Get the URI of this namespace.
*
* @return the URI
*/
public String getUri() {
return uri;
}
private static final Map<String, Namespace> namespaces;
static {
final Map<String, Namespace> map = new HashMap<String, Namespace>();
for (Namespace namespace : values()) {
final String name = namespace.getUri();
if (name != null) map.put(name, namespace);
}
namespaces = map;
}
/**
* Converts the specified uri to a {@link Namespace}.
* @param uri a namespace uri
* @return the matching namespace enum.
*/
public static Namespace forUri(String uri) {
final Namespace element = namespaces.get(uri);
return element == null ? UNKNOWN : element;
}
}