org.h2.test.unit
Class FileSystemDatabase

java.lang.Object
  extended by org.h2.store.fs.FileSystem
      extended by org.h2.test.unit.FileSystemDatabase

public class FileSystemDatabase
extends FileSystem

This file system stores everything in a database.


Method Summary
protected  boolean accepts(java.lang.String fileName)
          Check if the file system is responsible for this file name.
 boolean canWrite(java.lang.String fileName)
          Check if the file is writable.
 void createDirs(java.lang.String fileName)
          Create all required directories that are required for this file.
 boolean createNewFile(java.lang.String fileName)
          Create a new file.
 void delete(java.lang.String fileName)
          Delete a file.
 void deleteRecursive(java.lang.String fileName, boolean tryOnly)
          Delete a directory or file and all subdirectories and files.
 boolean exists(java.lang.String fileName)
          Checks if a file exists.
 boolean fileStartsWith(java.lang.String fileName, java.lang.String prefix)
          Check if a file starts with a given prefix.
 java.lang.String getCanonicalPath(java.lang.String fileName)
          Normalize a file name.
 java.lang.String getFileName(java.lang.String fileName)
          Get the file name (without directory part).
 long getLastModified(java.lang.String fileName)
          Get the last modified date of a file
 java.lang.String getParent(java.lang.String fileName)
          Get the parent directory of a file or directory.
 boolean isAbsolute(java.lang.String fileName)
          Check if the file name includes a path.
 boolean isDirectory(java.lang.String fileName)
          Check if it is a file or a directory.
 boolean isReadOnly(java.lang.String fileName)
          Check if a file is read-only.
 long length(java.lang.String fileName)
          Get the length of a file.
 java.lang.String[] listFiles(java.lang.String path)
          List the files in the given directory.
 java.io.InputStream openFileInputStream(java.lang.String fileName)
          Create an input stream to read from the file.
 FileObject openFileObject(java.lang.String fileName, java.lang.String mode)
          Open a random access file object.
 java.io.OutputStream openFileOutputStream(java.lang.String fileName, boolean append)
          Create an output stream to write into the file.
static FileSystemDatabase register(java.lang.String url)
           
 void rename(java.lang.String oldName, java.lang.String newName)
          Rename a file if this is allowed.
 boolean setReadOnly(java.lang.String fileName)
          Disable the ability to write.
 boolean tryDelete(java.lang.String fileName)
          Try to delete a file.
 void unregister()
          Close the underlying database and unregister the file system.
 java.lang.String unwrap(java.lang.String fileName)
          Get the unwrapped file name (without wrapper prefixes if wrapping / delegating file systems are used).
 
Methods inherited from class org.h2.store.fs.FileSystem
createTempFile, getInstance, getNextTempFileNamePart, register, unregister
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Method Detail

accepts

protected boolean accepts(java.lang.String fileName)
Description copied from class: FileSystem
Check if the file system is responsible for this file name.

Specified by:
accepts in class FileSystem
Parameters:
fileName - the file name
Returns:
true if it is

register

public static FileSystemDatabase register(java.lang.String url)

unregister

public void unregister()
Close the underlying database and unregister the file system.


canWrite

public boolean canWrite(java.lang.String fileName)
Description copied from class: FileSystem
Check if the file is writable.

Specified by:
canWrite in class FileSystem
Parameters:
fileName - the file name
Returns:
if the file is writable

createDirs

public void createDirs(java.lang.String fileName)
Description copied from class: FileSystem
Create all required directories that are required for this file.

Specified by:
createDirs in class FileSystem
Parameters:
fileName - the file name (not directory name)

createNewFile

public boolean createNewFile(java.lang.String fileName)
Description copied from class: FileSystem
Create a new file.

Specified by:
createNewFile in class FileSystem
Parameters:
fileName - the file name
Returns:
true if creating was successful

delete

public void delete(java.lang.String fileName)
Description copied from class: FileSystem
Delete a file.

Specified by:
delete in class FileSystem
Parameters:
fileName - the file name

deleteRecursive

public void deleteRecursive(java.lang.String fileName,
                            boolean tryOnly)
Description copied from class: FileSystem
Delete a directory or file and all subdirectories and files.

Specified by:
deleteRecursive in class FileSystem
Parameters:
fileName - the directory
tryOnly - whether errors should be ignored

exists

public boolean exists(java.lang.String fileName)
Description copied from class: FileSystem
Checks if a file exists.

Specified by:
exists in class FileSystem
Parameters:
fileName - the file name
Returns:
true if it exists

fileStartsWith

public boolean fileStartsWith(java.lang.String fileName,
                              java.lang.String prefix)
Description copied from class: FileSystem
Check if a file starts with a given prefix.

Specified by:
fileStartsWith in class FileSystem
Parameters:
fileName - the complete file name
prefix - the prefix
Returns:
true if it starts with the prefix

getFileName

public java.lang.String getFileName(java.lang.String fileName)
Description copied from class: FileSystem
Get the file name (without directory part).

Specified by:
getFileName in class FileSystem
Parameters:
fileName - the directory and file name
Returns:
just the file name

getLastModified

public long getLastModified(java.lang.String fileName)
Description copied from class: FileSystem
Get the last modified date of a file

Specified by:
getLastModified in class FileSystem
Parameters:
fileName - the file name
Returns:
the last modified date

getParent

public java.lang.String getParent(java.lang.String fileName)
Description copied from class: FileSystem
Get the parent directory of a file or directory.

Specified by:
getParent in class FileSystem
Parameters:
fileName - the file or directory name
Returns:
the parent directory name

isAbsolute

public boolean isAbsolute(java.lang.String fileName)
Description copied from class: FileSystem
Check if the file name includes a path.

Specified by:
isAbsolute in class FileSystem
Parameters:
fileName - the file name
Returns:
if the file name is absolute

isDirectory

public boolean isDirectory(java.lang.String fileName)
Description copied from class: FileSystem
Check if it is a file or a directory.

Specified by:
isDirectory in class FileSystem
Parameters:
fileName - the file or directory name
Returns:
true if it is a directory

isReadOnly

public boolean isReadOnly(java.lang.String fileName)
Description copied from class: FileSystem
Check if a file is read-only.

Specified by:
isReadOnly in class FileSystem
Parameters:
fileName - the file name
Returns:
if it is read only

setReadOnly

public boolean setReadOnly(java.lang.String fileName)
Description copied from class: FileSystem
Disable the ability to write.

Specified by:
setReadOnly in class FileSystem
Parameters:
fileName - the file name
Returns:
true if the call was successful

length

public long length(java.lang.String fileName)
Description copied from class: FileSystem
Get the length of a file.

Specified by:
length in class FileSystem
Parameters:
fileName - the file name
Returns:
the length in bytes

listFiles

public java.lang.String[] listFiles(java.lang.String path)
Description copied from class: FileSystem
List the files in the given directory.

Specified by:
listFiles in class FileSystem
Parameters:
path - the directory
Returns:
the list of fully qualified file names

getCanonicalPath

public java.lang.String getCanonicalPath(java.lang.String fileName)
Description copied from class: FileSystem
Normalize a file name.

Specified by:
getCanonicalPath in class FileSystem
Parameters:
fileName - the file name
Returns:
the normalized file name

openFileInputStream

public java.io.InputStream openFileInputStream(java.lang.String fileName)
                                        throws java.io.IOException
Description copied from class: FileSystem
Create an input stream to read from the file.

Specified by:
openFileInputStream in class FileSystem
Parameters:
fileName - the file name
Returns:
the input stream
Throws:
java.io.IOException

openFileObject

public FileObject openFileObject(java.lang.String fileName,
                                 java.lang.String mode)
                          throws java.io.IOException
Description copied from class: FileSystem
Open a random access file object.

Specified by:
openFileObject in class FileSystem
Parameters:
fileName - the file name
mode - the access mode. Supported are r, rw, rws, rwd
Returns:
the file object
Throws:
java.io.IOException

openFileOutputStream

public java.io.OutputStream openFileOutputStream(java.lang.String fileName,
                                                 boolean append)
Description copied from class: FileSystem
Create an output stream to write into the file.

Specified by:
openFileOutputStream in class FileSystem
Parameters:
fileName - the file name
append - if true, the file will grow, if false, the file will be truncated first
Returns:
the output stream

rename

public void rename(java.lang.String oldName,
                   java.lang.String newName)
Description copied from class: FileSystem
Rename a file if this is allowed.

Specified by:
rename in class FileSystem
Parameters:
oldName - the old fully qualified file name
newName - the new fully qualified file name

tryDelete

public boolean tryDelete(java.lang.String fileName)
Description copied from class: FileSystem
Try to delete a file.

Specified by:
tryDelete in class FileSystem
Parameters:
fileName - the file name
Returns:
true if it could be deleted

unwrap

public java.lang.String unwrap(java.lang.String fileName)
Description copied from class: FileSystem
Get the unwrapped file name (without wrapper prefixes if wrapping / delegating file systems are used).

Specified by:
unwrap in class FileSystem
Parameters:
fileName - the file name
Returns:
the unwrapped