You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

SimpleResourceAccessor.java 2.3KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. /*
  2. * Licensed to the Apache Software Foundation (ASF) under one or more
  3. * contributor license agreements. See the NOTICE file distributed with
  4. * this work for additional information regarding copyright ownership.
  5. * The ASF licenses this file to You under the Apache License, Version 2.0
  6. * (the "License"); you may not use this file except in compliance with
  7. * the License. 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. /* $Id$ */
  18. package org.apache.fop.afp.util;
  19. import java.io.File;
  20. import java.io.IOException;
  21. import java.io.InputStream;
  22. import java.net.URI;
  23. import java.net.URL;
  24. /**
  25. * Simple implementation of the {@link ResourceAccessor} interface for access relative to a
  26. * base URI.
  27. */
  28. public class SimpleResourceAccessor implements ResourceAccessor {
  29. private URI baseURI;
  30. /**
  31. * Creates a new simple resource accessor.
  32. * @param baseURI the base URI to resolve relative URIs against (may be null)
  33. */
  34. public SimpleResourceAccessor(URI baseURI) {
  35. this.baseURI = baseURI;
  36. }
  37. /**
  38. * Creates a new simple resource accessor.
  39. * @param baseDir the base directory to resolve relative filenames against (may be null)
  40. */
  41. public SimpleResourceAccessor(File baseDir) {
  42. this(baseDir != null ? baseDir.toURI() : null);
  43. }
  44. /**
  45. * Returns the base URI.
  46. * @return the base URI (or null if no base URI was set)
  47. */
  48. public URI getBaseURI() {
  49. return this.baseURI;
  50. }
  51. /**
  52. * Resolve the given URI against the baseURI.
  53. * @param uri the URI to resolve
  54. * @return the resolved URI
  55. */
  56. protected URI resolveAgainstBase(URI uri) {
  57. return (getBaseURI() != null ? getBaseURI().resolve(uri) : uri);
  58. }
  59. /** {@inheritDoc} */
  60. public InputStream createInputStream(URI uri) throws IOException {
  61. URI resolved = resolveAgainstBase(uri);
  62. URL url = resolved.toURL();
  63. return url.openStream();
  64. }
  65. }