blob: ea2a1ce1ac04b78dddae82dee9b05ff93288d4c4 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package org.apache.ode.bpel.compiler;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.net.MalformedURLException;
import java.net.URI;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
/**
* Basic implementation of the {@link ResourceFinder} interface. Resolves
* URIs relative to a base URI specified at the time of construction.
*
* @author Maciej Szefler - m s z e f l e r @ g m a i l . c o m
*
*/
public class DefaultResourceFinder implements ResourceFinder {
private static final Log __log = LogFactory.getLog(DefaultResourceFinder.class);
private File _relativeDir;
private File _absoluteDir;
/**
* Default constructor: resolve relative URIs against current working directory.
*/
public DefaultResourceFinder() {
_absoluteDir = new File("");
_relativeDir = _absoluteDir;
}
/**
* Constructor: resolve relative URIs against specified directory.
* @param relativeDir base path for relative URLs.
* @param absoluteDir base path for absolute URLs.
*/
public DefaultResourceFinder(File relativeDir, File absoluteDir) {
checkDir("relativeDir", relativeDir);
checkDir("absoluteDir", absoluteDir);
_relativeDir = relativeDir;
_absoluteDir = absoluteDir;
}
private void checkDir(String arg, File dir) {
if (dir == null) {
throw new IllegalArgumentException("Argument '"+arg+"' is null");
}
if (!dir.exists()) {
throw new IllegalArgumentException("Directory does not exist: " + dir);
}
}
public InputStream openResource(URI uri) throws MalformedURLException, IOException {
URI absolute = _absoluteDir.toURI();
if (__log.isDebugEnabled()) {
__log.debug("openResource: uri="+uri+" relativeDir="+_relativeDir+" absoluteDir="+_absoluteDir);
}
if (uri.isAbsolute() && uri.getScheme().equals("file")) {
try {
return uri.toURL().openStream();
} catch (Exception except) {
__log.fatal("openResource: unable to open file URL " + uri + "; " + except.toString());
return null;
}
}
// Note that if we get an absolute URI, the relativize operation will simply
// return the absolute URI.
URI relative = _relativeDir.toURI().relativize(uri);
if (relative.isAbsolute() && !relative.getScheme().equals("urn")) {
__log.fatal("openResource: invalid scheme (should be urn:) " + uri);
return null;
}
File f = new File(absolute.getPath(), relative.getPath());
if (!f.exists()) {
__log.debug("fileNotFound: " + f);
return null;
}
return new FileInputStream(f);
}
public URI getBaseResourceURI() {
return _absoluteDir.toURI();
}
}