All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.caucho.vfs.PathWrapper Maven / Gradle / Ivy

There is a newer version: 4.0.66
Show newest version
/*
 * Copyright (c) 1998-2018 Caucho Technology -- all rights reserved
 *
 * This file is part of Resin(R) Open Source
 *
 * Each copy or derived work must preserve the copyright notice and this
 * notice unmodified.
 *
 * Resin Open Source is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * Resin Open Source 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, or any warranty
 * of NON-INFRINGEMENT.  See the GNU General Public License for more
 * details.
 *
 * You should have received a copy of the GNU General Public License
 * along with Resin Open Source; if not, write to the
 *
 *   Free Software Foundation, Inc.
 *   59 Temple Place, Suite 330
 *   Boston, MA 02111-1307  USA
 *
 * @author Scott Ferguson
 */

package com.caucho.vfs;

import com.caucho.util.L10N;

import java.io.IOException;
import java.io.OutputStream;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.Map;

/**
 * Wraps a path object.
 */
public abstract class PathWrapper extends Path {
  protected final static L10N L = new L10N(PathWrapper.class);

  private final Path _path;

  /**
   * Creates a new Path object.
   *
   * @param path the new Path root.
   */
  protected PathWrapper(Path path)
  {
    super(path);

    _path = path;
  }

  /**
   * Returns the wrapped path.
   */
  public Path getWrappedPath()
  {
    return _path;
  }

  /**
   * Returns a new path relative to the current one.
   *
   * 

Path only handles scheme:xxx. Subclasses of Path will specialize * the xxx. * * @param userPath relative or absolute path, essentially any url. * @param newAttributes attributes for the new path. * * @return the new path or null if the scheme doesn't exist */ public Path lookup(String userPath, Map newAttributes) { return getWrappedPath().lookup(userPath, newAttributes); } /** * Returns a new path relative to the current one. * *

Path only handles scheme:xxx. Subclasses of Path will specialize * the xxx. * * @param userPath relative or absolute path, essentially any url. * @param newAttributes attributes for the new path. * * @return the new path or null if the scheme doesn't exist */ @Override public Path lookupImpl(String userPath, Map newAttributes, boolean isAllowRoot) { return getWrappedPath().lookupImpl(userPath, newAttributes, isAllowRoot); } /** * Looks up a native path, adding attributes. */ public Path lookupNative(String name, Map attributes) { return getWrappedPath().lookupNative(name, attributes); } /** * Looks up all the resources matching a name. (Generally only useful * with MergePath. */ public ArrayList getResources(String name) { return getWrappedPath().getResources(name); } /** * Looks up all the existing resources. (Generally only useful * with MergePath. */ public ArrayList getResources() { return getWrappedPath().getResources(); } /** * Returns the parent path. */ public Path getParent() { return getWrappedPath().getParent(); } /** * Path-specific lookup. Path implementations will override this. * * @param userPath the user's lookup() path. * @param newAttributes the attributes for the new path. * @param newPath the lookup() path * @param offset offset into newPath to start lookup. * * @return the found path */ @Override public Path schemeWalk(String userPath, Map newAttributes, String newPath, int offset) { return getWrappedPath().schemeWalk(userPath, newAttributes, newPath, offset); } /** * Returns the full url for the given path. */ public String getURL() { return getWrappedPath().getURL(); } /** * Returns the url scheme */ public String getScheme() { return getWrappedPath().getScheme(); } /** * Returns the hostname */ public String getHost() { return getWrappedPath().getHost(); } /** * Returns the port. */ public int getPort() { return getWrappedPath().getPort(); } /** * Returns the path. e.g. for HTTP, returns the part after the * host and port. */ public String getPath() { return getWrappedPath().getPath(); } /** * Returns the last segment of the path. * *

e.g. for http://www.caucho.com/products/index.html, getTail() * returns 'index.html' */ public String getTail() { return getWrappedPath().getTail(); } /** * Returns the query string of the path. */ public String getQuery() { return getWrappedPath().getQuery(); } /** * Returns the native representation of the path. * * On Windows, getNativePath() returns 'd:\\foo\bar.html', * getPath() returns '/d:/foo/bar.html' */ public String getNativePath() { return getWrappedPath().getNativePath(); } /** * Returns the last string used as a lookup, if available. This allows * parsers to give intelligent error messages, with the user's path * instead of the whole path. * * The following will print '../test.html': *

   * Path path = Pwd.lookup("/some/dir").lookup("../test.html");
   * System.out.println(path.getUserPath());
   * 
* */ public String getUserPath() { return getWrappedPath().getUserPath(); } /** * Sets the user path. Useful for temporary files caching another * URL. */ public void setUserPath(String userPath) { getWrappedPath().setUserPath(userPath); } /** * Returns the full path, including the restricted root. * *

For the following, path.getPath() returns '/file.html', while * path.getFullPath() returns '/chroot/file.html'. *

   * Path chroot = Pwd.lookup("/chroot").createRoot();
   * Path path = chroot.lookup("/file.html");
   * 
*/ public String getFullPath() { return getWrappedPath().getFullPath(); } /** * For union paths like MergePath, return the relative path into * that path. */ public String getRelativePath() { return getWrappedPath().getRelativePath(); } /** * Tests if the file exists. */ public boolean exists() { return getWrappedPath().exists(); } /** * Returns the mime-type of the file. *

Mime-type ignorant filesystems return 'application/octet-stream' */ public String getContentType() { return getWrappedPath().getContentType(); } /** * Tests if the path refers to a directory. */ public boolean isDirectory() { return getWrappedPath().isDirectory(); } /** * Tests if the path refers to a file. */ public boolean isFile() { return getWrappedPath().isFile(); } /** * Tests if the path refers to an object. */ public boolean isObject() { return getWrappedPath().isObject(); } /** * Returns the length of the file in bytes. * @return 0 for non-files */ public long getLength() { return getWrappedPath().getLength(); } /** * Returns the last modified time of the file. According to the jdk, * this may not correspond to the system time. * @return 0 for non-files. */ public long getLastModified() { return getWrappedPath().getLastModified(); } public void setLastModified(long time) { getWrappedPath().setLastModified(time); } /** * Returns the last access time of the file. * * @return 0 for non-files. */ public long getLastAccessTime() { return getWrappedPath().getLastAccessTime(); } /** * Returns the create time of the file. * * @return 0 for non-files. */ public long getCreateTime() { return getWrappedPath().getCreateTime(); } /** * Tests if the file can be read. */ public boolean canRead() { return getWrappedPath().canRead(); } /** * Tests if the file can be written. */ public boolean canWrite() { return getWrappedPath().canWrite(); } /** * Changes the permissions */ public boolean chmod(int value) { return getWrappedPath().chmod(value); } /** * @return The contents of this directory or null if the path does not * refer to a directory. */ public String []list() throws IOException { return getWrappedPath().list(); } /** * Returns a jdk1.2 Iterator for the contents of this directory. */ public Iterator iterator() throws IOException { return getWrappedPath().iterator(); } /** * Creates the directory named by this path. * @return true if successful. */ public boolean mkdir() throws IOException { return getWrappedPath().mkdir(); } /** * Creates the directory named by this path and any parent directories. * @return true if successful. */ public boolean mkdirs() throws IOException { return getWrappedPath().mkdirs(); } /** * Removes the file or directory named by this path. * @return true if successful. */ public boolean remove() throws IOException { return getWrappedPath().remove(); } /** * Removes the all files and directories below this path. * * @return true if successful. */ public boolean removeAll() throws IOException { return getWrappedPath().removeAll(); } /** * Renames the file or directory to the name given by the path. * @return true if successful */ public boolean renameTo(Path path) throws IOException { return getWrappedPath().renameTo(path); } /** * Creates a restricted root, like the Unix chroot call. * Restricted roots cannot access schemes, so file:/etc/passwd cannot * be used. * *

createRoot is useful for restricting JavaScript scripts without * resorting to the dreadfully slow security manager. */ public Path createRoot() { return getWrappedPath().createRoot(); } public Path createRoot(SchemeMap schemeMap) { return getWrappedPath().createRoot(schemeMap); } /** * Binds the context to the current path. Later lookups will return * the new context instead of the current path. Essentially, this is a * software symbolic link. */ public void bind(Path context) { getWrappedPath().bind(context); } /** * unbinds a link. */ public void unbind() { getWrappedPath().unbind(); } /** * Gets the object at the path. Normal filesystems will generally * typically return null. * *

A bean filesystem or a mime-type aware filesystem could deserialize * the contents of the file. */ public Object getValue() throws Exception { return getWrappedPath().getValue(); } /** * Sets the object at the path. * *

Normal filesystems will generally do nothing. However, a bean * filesystem or a mime-type aware filesystem could serialize the object * and store it. */ public void setValue(Object obj) throws Exception { getWrappedPath().setValue(obj); } /** * Gets an attribute of the object. */ public Object getAttribute(String name) throws IOException { return getWrappedPath().getAttribute(name); } /** * Returns a iterator of all attribute names set for this object. * @return null if path has no attributes. */ public Iterator getAttributeNames() throws IOException { return getWrappedPath().getAttributeNames(); } /** * Opens a resin ReadWritePair for reading and writing. * *

A chat channel, for example, would open its socket using this * interface. */ public ReadWritePair openReadWrite() throws IOException { return getWrappedPath().openReadWrite(); } /** * Opens a resin ReadWritePair for reading and writing. * *

A chat channel, for example, would open its socket using this * interface. * * @param is pre-allocated ReadStream to be initialized * @param os pre-allocated WriteStream to be initialized */ public void openReadWrite(ReadStream is, WriteStream os) throws IOException { getWrappedPath().openReadWrite(is, os); } /** * Opens a resin stream for appending. */ public WriteStream openAppend() throws IOException { return getWrappedPath().openAppend(); } /** * Opens a random-access stream. */ public RandomAccessStream openRandomAccess() throws IOException { return getWrappedPath().openRandomAccess(); } /** * Creates the file named by this Path and returns true if the * file is new. */ public boolean createNewFile() throws IOException { return getWrappedPath().createNewFile(); } /** * Creates a unique temporary file as a child of this directory. * * @param prefix filename prefix * @param suffix filename suffix, defaults to .tmp * @return Path to the new file. */ public Path createTempFile(String prefix, String suffix) throws IOException { return getWrappedPath().createTempFile(prefix, suffix); } /** * Utility to write the contents of this path to the destination stream. * * @param os destination stream. */ public void writeToStream(OutputStream os) throws IOException { getWrappedPath().writeToStream(os); } /** * Utility to write the contents of this path to the destination stream. * * @param os destination stream. */ public void writeToStream(OutputStreamWithBuffer os) throws IOException { getWrappedPath().writeToStream(os); } /** * Returns the crc64 code. */ public long getCrc64() { return getWrappedPath().getCrc64(); } /** * Returns the object at this path. Normally, only paths like JNDI * will support this. */ public Object getObject() throws IOException { return getWrappedPath().getObject(); } /** * Sets the object at this path. Normally, only paths like JNDI * will support this. */ public void setObject(Object obj) throws IOException { getWrappedPath().setObject(obj); } public long getInode() { return getWrappedPath().getInode(); } public boolean isExecutable() { return getWrappedPath().isExecutable(); } public boolean setExecutable(boolean isExecutable) { return getWrappedPath().setExecutable(isExecutable); } public int getGroup() { return getWrappedPath().getGroup(); } public boolean changeGroup(int gid) throws IOException { return getWrappedPath().changeGroup(gid); } public boolean changeGroup(String groupName) throws IOException { return getWrappedPath().changeGroup(groupName); } public int getOwner() { return getWrappedPath().getOwner(); } public boolean changeOwner(int uid) throws IOException { return getWrappedPath().changeOwner(uid); } public boolean changeOwner(String ownerName) throws IOException { return getWrappedPath().changeOwner(ownerName); } public long getDiskSpaceFree() { return getWrappedPath().getDiskSpaceFree(); } public long getDiskSpaceTotal() { return getWrappedPath().getDiskSpaceTotal(); } public int hashCode() { return getWrappedPath().hashCode(); } public boolean equals(Object o) { return o.equals(getWrappedPath()); } public String toString() { return getWrappedPath().toString(); } public StreamImpl openReadImpl() throws IOException { return getWrappedPath().openReadImpl(); } public StreamImpl openWriteImpl() throws IOException { return getWrappedPath().openWriteImpl(); } public StreamImpl openReadWriteImpl() throws IOException { return getWrappedPath().openReadWriteImpl(); } public StreamImpl openAppendImpl() throws IOException { return getWrappedPath().openAppendImpl(); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy