org.mortbay.resource
Class FileResource

java.lang.Object
  extended by org.mortbay.resource.Resource
      extended by org.mortbay.resource.URLResource
          extended by org.mortbay.resource.FileResource
All Implemented Interfaces:
Serializable

public class FileResource
extends URLResource

File Resource. Handle resources of implied or explicit file type. This class can check for aliasing in the filesystem (eg case insensitivity). By default this is turned on if the platform does not have the "/" path separator, or it can be controlled with the "org.mortbay.util.FileResource.checkAliases" system parameter. If alias checking is turned on, then aliased resources are treated as if they do not exist, nor can they be created.

Author:
Greg Wilkins (gregw)
See Also:
Serialized Form

Field Summary
private static boolean __checkAliases
           
private  URL _alias
           
private  boolean _aliasChecked
           
private  File _file
           
 
Fields inherited from class org.mortbay.resource.URLResource
_connection, _in, _url, _urlString
 
Fields inherited from class org.mortbay.resource.Resource
_associate
 
Constructor Summary
FileResource(URL url)
           
FileResource(URL url, URLConnection connection, File file)
           
 
Method Summary
 Resource addPath(String path)
          Returns the resource contained inside the current resource with the given name
 boolean delete()
          Deletes the given resource
 String encode(String uri)
          Encode according to this resource type.
 boolean equals(Object o)
           
 boolean exists()
          Returns true if the resource exists.
 URL getAlias()
           
static boolean getCheckAliases()
          getCheckAliases.
 File getFile()
          Returns an File representing the given resource or NULL if this is not possible.
 InputStream getInputStream()
          Returns an input stream to the resource
 String getName()
          Returns the name of the resource
 OutputStream getOutputStream()
          Returns an output stream to the resource
 int hashCode()
           
 boolean isDirectory()
          Returns true if the respresenetd resource is a container/directory.
 long lastModified()
          Returns the last modified time
 long length()
          Return the length of the resource
 String[] list()
          Returns a list of resources contained in the given resource
 boolean renameTo(Resource dest)
          Rename the given resource
static void setCheckAliases(boolean checkAliases)
          setCheckAliases.
 
Methods inherited from class org.mortbay.resource.URLResource
checkConnection, getURL, release, toString
 
Methods inherited from class org.mortbay.resource.Resource
finalize, getAssociate, getListHTML, newResource, newResource, newSystemResource, setAssociate, writeTo
 
Methods inherited from class java.lang.Object
clone, getClass, notify, notifyAll, wait, wait, wait
 

Field Detail

__checkAliases

private static boolean __checkAliases

_file

private File _file

_alias

private transient URL _alias

_aliasChecked

private transient boolean _aliasChecked
Constructor Detail

FileResource

FileResource(URL url)
       throws IOException,
              URISyntaxException
Throws:
IOException
URISyntaxException

FileResource

FileResource(URL url,
             URLConnection connection,
             File file)
Method Detail

setCheckAliases

public static void setCheckAliases(boolean checkAliases)
setCheckAliases.

Parameters:
checkAliases - True of resource aliases are to be checked for (eg case insensitivity or 8.3 short names) and treated as not found.

getCheckAliases

public static boolean getCheckAliases()
getCheckAliases.

Returns:
True of resource aliases are to be checked for (eg case insensitivity or 8.3 short names) and treated as not found.

addPath

public Resource addPath(String path)
                 throws IOException,
                        MalformedURLException
Description copied from class: URLResource
Returns the resource contained inside the current resource with the given name

Overrides:
addPath in class URLResource
Parameters:
path - The path segment to add, which should be encoded by the encode method.
Throws:
IOException
MalformedURLException

getAlias

public URL getAlias()
Overrides:
getAlias in class Resource
Returns:
The canonical Alias of this resource or null if none.

exists

public boolean exists()
Returns true if the resource exists.

Overrides:
exists in class URLResource

lastModified

public long lastModified()
Returns the last modified time

Overrides:
lastModified in class URLResource

isDirectory

public boolean isDirectory()
Returns true if the respresenetd resource is a container/directory.

Overrides:
isDirectory in class URLResource

length

public long length()
Return the length of the resource

Overrides:
length in class URLResource

getName

public String getName()
Returns the name of the resource

Overrides:
getName in class URLResource

getFile

public File getFile()
Returns an File representing the given resource or NULL if this is not possible.

Overrides:
getFile in class URLResource

getInputStream

public InputStream getInputStream()
                           throws IOException
Returns an input stream to the resource

Overrides:
getInputStream in class URLResource
Throws:
IOException

getOutputStream

public OutputStream getOutputStream()
                             throws IOException,
                                    SecurityException
Returns an output stream to the resource

Overrides:
getOutputStream in class URLResource
Throws:
IOException
SecurityException

delete

public boolean delete()
               throws SecurityException
Deletes the given resource

Overrides:
delete in class URLResource
Throws:
SecurityException

renameTo

public boolean renameTo(Resource dest)
                 throws SecurityException
Rename the given resource

Overrides:
renameTo in class URLResource
Throws:
SecurityException

list

public String[] list()
Returns a list of resources contained in the given resource

Overrides:
list in class URLResource

encode

public String encode(String uri)
Encode according to this resource type. File URIs are encoded.

Overrides:
encode in class Resource
Parameters:
uri - URI to encode.
Returns:
The uri unchanged.

equals

public boolean equals(Object o)
Overrides:
equals in class URLResource
Parameters:
o -
Returns:

hashCode

public int hashCode()
Overrides:
hashCode in class URLResource
Returns:
the hashcode.