X-Git-Url: http://git.argeo.org/?a=blobdiff_plain;ds=sidebyside;f=org.argeo.slc.server%2Fsrc%2Fmain%2Fjava%2Forg%2Fargeo%2Fslc%2Fweb%2Fmvc%2FXsltMarshallerViewResolver.java;fp=org.argeo.slc.server%2Fsrc%2Fmain%2Fjava%2Forg%2Fargeo%2Fslc%2Fweb%2Fmvc%2FXsltMarshallerViewResolver.java;h=0000000000000000000000000000000000000000;hb=cdb5a9f10678f41914d6eeebd6620c0a84dbd208;hp=62af08ea653bdd675d770c2573af9117e43a99de;hpb=7a8f034133c1112e187e2a2bfd2c56a8d2452345;p=gpl%2Fargeo-slc.git diff --git a/org.argeo.slc.server/src/main/java/org/argeo/slc/web/mvc/XsltMarshallerViewResolver.java b/org.argeo.slc.server/src/main/java/org/argeo/slc/web/mvc/XsltMarshallerViewResolver.java deleted file mode 100644 index 62af08ea6..000000000 --- a/org.argeo.slc.server/src/main/java/org/argeo/slc/web/mvc/XsltMarshallerViewResolver.java +++ /dev/null @@ -1,85 +0,0 @@ -package org.argeo.slc.web.mvc; - -import java.io.IOException; -import java.util.Map; -import java.util.TreeMap; - -import javax.xml.transform.Source; -import javax.xml.transform.TransformerException; -import javax.xml.transform.URIResolver; -import javax.xml.transform.stream.StreamSource; - -import org.apache.commons.logging.Log; -import org.apache.commons.logging.LogFactory; -import org.argeo.slc.core.SlcException; -import org.springframework.core.io.Resource; -import org.springframework.oxm.Marshaller; -import org.springframework.web.servlet.view.AbstractUrlBasedView; -import org.springframework.web.servlet.view.xslt.XsltViewResolver; - -public class XsltMarshallerViewResolver extends XsltViewResolver implements - URIResolver { - private final static Log log = LogFactory - .getLog(XsltMarshallerViewResolver.class); - - private Marshaller marshaller; - private Map cacheUriResolver = new TreeMap(); - - public XsltMarshallerViewResolver() { - setUriResolver(this); - } - - @Override - protected AbstractUrlBasedView buildView(String viewName) throws Exception { - AbstractUrlBasedView viewT = super.buildView(viewName); - XsltMarshallerView view = (XsltMarshallerView) viewT; - view.setMarshaller(marshaller); - return view; - } - - public void setMarshaller(Marshaller marshaller) { - this.marshaller = marshaller; - } - - public Source resolve(String href, String base) throws TransformerException { - if (log.isTraceEnabled()) - log.trace("Resolve URI for href=" + href + " base=" + base); - - Source res = null; - if (isCache()) - res = cacheUriResolver.get(href); - - if (res == null) - res = getStylesheetSource(href); - - if (res == null) - res = getStylesheetSource(getPrefix() + href); - - if (res == null) - throw new SlcException("Can't resolve URI for href=" + href - + " base=" + base); - - if (isCache() && !cacheUriResolver.containsKey(href)) - cacheUriResolver.put(href, res); - - return res; - } - - protected Source getStylesheetSource(String url) { - if (log.isDebugEnabled()) { - log.debug("Loading XSLT stylesheet from '" + url + "'"); - } - try { - final Resource stylesheetResource = getApplicationContext() - .getResource(url); - String systemId = url.substring(0, url.lastIndexOf('/') + 1); - return new StreamSource(stylesheetResource.getInputStream(), - systemId); - } catch (IOException e) { - if (log.isTraceEnabled()) - log.trace("Cannot load stylesheet " + url, e); - return null; - } - } - -}