/******************************************************************************
* Copyright (c) 2006, 2010 VMware Inc.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* and Apache License v2.0 which accompanies this distribution.
* The Eclipse Public License is available at
* http://www.eclipse.org/legal/epl-v10.html and the Apache License v2.0
* is available at http://www.opensource.org/licenses/apache2.0.php.
* You may elect to redistribute this code under either of these licenses.
*
* Contributors:
* VMware Inc.
*****************************************************************************/
package org.eclipse.gemini.blueprint.context.support;
import java.util.Iterator;
import java.util.LinkedHashMap;
import java.util.Map;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.springframework.beans.factory.xml.NamespaceHandler;
import org.springframework.beans.factory.xml.NamespaceHandlerResolver;
import org.springframework.util.Assert;
/**
* Delegated XML namespace handler resolver.
*
* @author Costin Leau
*
*/
class DelegatedNamespaceHandlerResolver implements NamespaceHandlerResolver {
/** logger */
private static final Log log = LogFactory.getLog(DelegatedNamespaceHandlerResolver.class);
private final Map<NamespaceHandlerResolver, String> resolvers = new LinkedHashMap<NamespaceHandlerResolver, String>(
2);
public void addNamespaceHandler(NamespaceHandlerResolver resolver, String resolverToString) {
Assert.notNull(resolver);
resolvers.put(resolver, resolverToString);
}
public NamespaceHandler resolve(String namespaceUri) {
boolean trace = log.isTraceEnabled();
for (Iterator<Map.Entry<NamespaceHandlerResolver, String>> iterator = resolvers.entrySet().iterator(); iterator.hasNext();) {
Map.Entry<NamespaceHandlerResolver, String> entry = iterator.next();
NamespaceHandlerResolver handlerResolver = entry.getKey();
if (trace)
log.trace("Trying to resolve namespace [" + namespaceUri + "] through resolver " + entry.getValue());
NamespaceHandler handler = handlerResolver.resolve(namespaceUri);
String resolvedMsg = (handler != null ? "" : "not ");
if (trace)
log.trace("Namespace [" + namespaceUri + "] was " + resolvedMsg + "resolved through handler resolver "
+ entry.getValue());
if (handler != null) {
return handler;
}
}
return null;
}
}