Prev Class | Next Class | Frames | No Frames |
Summary: Nested | Field | Method | Constr | Detail: Nested | Field | Method | Constr |
java.lang.Object
org.apache.tools.ant.util.FileUtils
public class FileUtils
extends java.lang.Object
Field Summary | |
static long |
|
static long |
|
Constructor Summary | |
|
Method Summary | |
static void |
|
static void |
|
static void |
|
static void |
|
boolean |
|
boolean |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
void |
|
boolean |
|
boolean |
|
File |
|
static void |
|
boolean |
|
String |
|
long |
|
URL |
|
static FileUtils |
|
File |
|
static boolean |
|
boolean |
|
boolean |
|
boolean |
|
boolean |
|
boolean |
|
static FileUtils |
|
File |
|
static String |
|
static String |
|
String |
|
void |
|
File |
|
void |
|
String |
|
String |
|
public static final long FAT_FILE_TIMESTAMP_GRANULARITY
The granularity of timestamps under FAT.
- Field Value:
- 2000L
public static final long UNIX_FILE_TIMESTAMP_GRANULARITY
The granularity of timestamps under Unix.
- Field Value:
- 1000L
public static void close(InputStream device)
Close a stream without throwing any exception if something went wrong. Do not attempt to close it if the argument is null.
- Parameters:
device
- stream, can be null.
public static void close(OutputStream device)
Close a stream without throwing any exception if something went wrong. Do not attempt to close it if the argument is null.
- Parameters:
device
- stream, can be null.
public static void close(Reader device)
Close a stream without throwing any exception if something went wrong. Do not attempt to close it if the argument is null.
- Parameters:
device
- Reader, can be null.
public static void close(Writer device)
Close a Writer without throwing any exception if something went wrong. Do not attempt to close it if the argument is null.
- Parameters:
device
- output writer, can be null.
public boolean contentEquals(File f1, File f2) throws IOException
Compares the contents of two files.
- Parameters:
f1
- the file whose content is to be compared.f2
- the other file whose content is to be compared.
- Returns:
- true if the content of the files is the same.
public boolean contentEquals(File f1, File f2, boolean textfile) throws IOException
Compares the contents of two files.
- Parameters:
f1
- the file whose content is to be compared.f2
- the other file whose content is to be compared.textfile
- true if the file is to be treated as a text file and differences in kind of line break are to be ignored.
- Returns:
- true if the content of the files is the same.
- Since:
- Ant 1.6.3
public void copyFile(File sourceFile, File destFile) throws IOException
Convenience method to copy a file from a source to a destination. No filtering is performed.
- Parameters:
sourceFile
- the file to copy from. Must not benull
.destFile
- the file to copy to. Must not benull
.
public void copyFile(File sourceFile, File destFile, FilterSetCollection filters) throws IOException
Convenience method to copy a file from a source to a destination specifying if token filtering must be used.
- Parameters:
sourceFile
- the file to copy from. Must not benull
.destFile
- the file to copy to. Must not benull
.filters
- the collection of filters to apply to this copy.
public void copyFile(File sourceFile, File destFile, FilterSetCollection filters, Vector filterChains, boolean overwrite, boolean preserveLastModified, String inputEncoding, String outputEncoding, Project project) throws IOException
Convenience method to copy a file from a source to a destination specifying if token filtering must be used, if filter chains must be used, if source files may overwrite newer destination files and the last modified time ofdestFile
file should be made equal to the last modified time ofsourceFile
.
- Parameters:
sourceFile
- the file to copy from. Must not benull
.destFile
- the file to copy to. Must not benull
.filters
- the collection of filters to apply to this copy.filterChains
- filterChains to apply during the copy.overwrite
- Whether or not the destination file should be overwritten if it already exists.preserveLastModified
- Whether or not the last modified time of the resulting file should be set to that of the source file.inputEncoding
- the encoding used to read the files.outputEncoding
- the encoding used to write the files.project
- the project instance.
- Since:
- Ant 1.6
public void copyFile(File sourceFile, File destFile, FilterSetCollection filters, Vector filterChains, boolean overwrite, boolean preserveLastModified, String encoding, Project project) throws IOException
Convenience method to copy a file from a source to a destination specifying if token filtering must be used, if filter chains must be used, if source files may overwrite newer destination files and the last modified time ofdestFile
file should be made equal to the last modified time ofsourceFile
.
- Parameters:
sourceFile
- the file to copy from. Must not benull
.destFile
- the file to copy to. Must not benull
.filters
- the collection of filters to apply to this copy.filterChains
- filterChains to apply during the copy.overwrite
- Whether or not the destination file should be overwritten if it already exists.preserveLastModified
- Whether or not the last modified time of the resulting file should be set to that of the source file.encoding
- the encoding used to read and write the files.project
- the project instance.
- Since:
- Ant 1.5
public void copyFile(File sourceFile, File destFile, FilterSetCollection filters, boolean overwrite) throws IOException
Convenience method to copy a file from a source to a destination specifying if token filtering must be used and if source files may overwrite newer destination files.
- Parameters:
sourceFile
- the file to copy from. Must not benull
.destFile
- the file to copy to. Must not benull
.filters
- the collection of filters to apply to this copy.overwrite
- Whether or not the destination file should be overwritten if it already exists.
public void copyFile(File sourceFile, File destFile, FilterSetCollection filters, boolean overwrite, boolean preserveLastModified) throws IOException
Convenience method to copy a file from a source to a destination specifying if token filtering must be used, if source files may overwrite newer destination files and the last modified time ofdestFile
file should be made equal to the last modified time ofsourceFile
.
- Parameters:
sourceFile
- the file to copy from. Must not benull
.destFile
- the file to copy to. Must not benull
.filters
- the collection of filters to apply to this copy.overwrite
- Whether or not the destination file should be overwritten if it already exists.preserveLastModified
- Whether or not the last modified time of the resulting file should be set to that of the source file.
public void copyFile(File sourceFile, File destFile, FilterSetCollection filters, boolean overwrite, boolean preserveLastModified, String encoding) throws IOException
Convenience method to copy a file from a source to a destination specifying if token filtering must be used, if source files may overwrite newer destination files, the last modified time ofdestFile
file should be made equal to the last modified time ofsourceFile
and which character encoding to assume.
- Parameters:
sourceFile
- the file to copy from. Must not benull
.destFile
- the file to copy to. Must not benull
.filters
- the collection of filters to apply to this copy.overwrite
- Whether or not the destination file should be overwritten if it already exists.preserveLastModified
- Whether or not the last modified time of the resulting file should be set to that of the source file.encoding
- the encoding used to read and write the files.
- Since:
- Ant 1.5
public void copyFile(String sourceFile, String destFile) throws IOException
Convenience method to copy a file from a source to a destination. No filtering is performed.
- Parameters:
sourceFile
- Name of file to copy from. Must not benull
.destFile
- Name of file to copy to. Must not benull
.
public void copyFile(String sourceFile, String destFile, FilterSetCollection filters) throws IOException
Convenience method to copy a file from a source to a destination specifying if token filtering must be used.
- Parameters:
sourceFile
- Name of file to copy from. Must not benull
.destFile
- Name of file to copy to. Must not benull
.filters
- the collection of filters to apply to this copy.
public void copyFile(String sourceFile, String destFile, FilterSetCollection filters, Vector filterChains, boolean overwrite, boolean preserveLastModified, String inputEncoding, String outputEncoding, Project project) throws IOException
Convenience method to copy a file from a source to a destination specifying if token filtering must be used, if filter chains must be used, if source files may overwrite newer destination files and the last modified time ofdestFile
file should be made equal to the last modified time ofsourceFile
.
- Parameters:
sourceFile
- Name of file to copy from. Must not benull
.destFile
- Name of file to copy to. Must not benull
.filters
- the collection of filters to apply to this copy.filterChains
- filterChains to apply during the copy.overwrite
- Whether or not the destination file should be overwritten if it already exists.preserveLastModified
- Whether or not the last modified time of the resulting file should be set to that of the source file.inputEncoding
- the encoding used to read the files.outputEncoding
- the encoding used to write the files.project
- the project instance.
- Since:
- Ant 1.6
public void copyFile(String sourceFile, String destFile, FilterSetCollection filters, Vector filterChains, boolean overwrite, boolean preserveLastModified, String encoding, Project project) throws IOException
Convenience method to copy a file from a source to a destination specifying if token filtering must be used, if filter chains must be used, if source files may overwrite newer destination files and the last modified time ofdestFile
file should be made equal to the last modified time ofsourceFile
.
- Parameters:
sourceFile
- Name of file to copy from. Must not benull
.destFile
- Name of file to copy to. Must not benull
.filters
- the collection of filters to apply to this copy.filterChains
- filterChains to apply during the copy.overwrite
- Whether or not the destination file should be overwritten if it already exists.preserveLastModified
- Whether or not the last modified time of the resulting file should be set to that of the source file.encoding
- the encoding used to read and write the files.project
- the project instance.
- Since:
- Ant 1.5
public void copyFile(String sourceFile, String destFile, FilterSetCollection filters, boolean overwrite) throws IOException
Convenience method to copy a file from a source to a destination specifying if token filtering must be used and if source files may overwrite newer destination files.
- Parameters:
sourceFile
- Name of file to copy from. Must not benull
.destFile
- Name of file to copy to. Must not benull
.filters
- the collection of filters to apply to this copy.overwrite
- Whether or not the destination file should be overwritten if it already exists.
public void copyFile(String sourceFile, String destFile, FilterSetCollection filters, boolean overwrite, boolean preserveLastModified) throws IOException
Convenience method to copy a file from a source to a destination specifying if token filtering must be used, if source files may overwrite newer destination files and the last modified time ofdestFile
file should be made equal to the last modified time ofsourceFile
.
- Parameters:
sourceFile
- Name of file to copy from. Must not benull
.destFile
- Name of file to copy to. Must not benull
.filters
- the collection of filters to apply to this copy.overwrite
- Whether or not the destination file should be overwritten if it already exists.preserveLastModified
- Whether or not the last modified time of the resulting file should be set to that of the source file.
public void copyFile(String sourceFile, String destFile, FilterSetCollection filters, boolean overwrite, boolean preserveLastModified, String encoding) throws IOException
Convenience method to copy a file from a source to a destination specifying if token filtering must be used, if source files may overwrite newer destination files and the last modified time ofdestFile
file should be made equal to the last modified time ofsourceFile
.
- Parameters:
sourceFile
- Name of file to copy from. Must not benull
.destFile
- Name of file to copy to. Must not benull
.filters
- the collection of filters to apply to this copy.overwrite
- Whether or not the destination file should be overwritten if it already exists.preserveLastModified
- Whether or not the last modified time of the resulting file should be set to that of the source file.encoding
- the encoding used to read and write the files.
- Since:
- Ant 1.5
public boolean createNewFile(File f) throws IOException
This was originally an emulation of File.createNewFile for JDK 1.1, but it is now implemented using that method (Ant 1.6.3 onwards). This method has historically not guaranteed that the operation was atomic. In its current implementation it is.
- Parameters:
f
- the file to be created.
- Returns:
- true if the file did not exist already.
- Since:
- Ant 1.5
public boolean createNewFile(File f, boolean mkdirs) throws IOException
Create a new file, optionally creating parent directories.
- Parameters:
f
- the file to be created.mkdirs
-boolean
whether to create parent directories.
- Returns:
- true if the file did not exist already.
- Since:
- Ant 1.6.3
public File createTempFile(String prefix, String suffix, File parentDir)
Create a temporary file in a given directory. The file denoted by the returned abstract pathname did not exist before this method was invoked, any subsequent invocation of this method will yield a different file name. The filename is prefixNNNNNsuffix where NNNN is a random number. This method is different from File.createTempFile() of JDK 1.2 as it doesn't create the file itself. It uses the location pointed to by java.io.tmpdir when the parentDir attribute is null.
- Parameters:
prefix
- prefix before the random number.suffix
- file extension; include the '.'.parentDir
- Directory to create the temporary file in; java.io.tmpdir used if not specified.
- Returns:
- a File reference to the new temporary file.
- Since:
- Ant 1.5
public static void delete(File file)
Delete the file withFile.delete()
if the argument is not null. Do nothing on a null argument.
- Parameters:
file
- file to delete.
public boolean fileNameEquals(File f1, File f2)
Compares two filenames. Unlike java.io.File#equals this method will try to compare the absolute paths and "normalize" the filenames before comparing them.
- Parameters:
f1
- the file whose name is to be compared.f2
- the other file whose name is to be compared.
- Returns:
- true if the file are for the same file.
- Since:
- Ant 1.5.3
public String fromURI(String uri)
Constructs a file path from afile:
URI. Will be an absolute path if the given URI is absolute. Swallows '%' that are not followed by two characters, doesn't deal with non-ASCII characters.
- Parameters:
uri
- the URI designating a file in the local filesystem.
- Returns:
- the local file system path for the file.
- Since:
- Ant 1.6
public long getFileTimestampGranularity()
Get the granularity of file timestamps. The choice is made based on OS, which is incorrect--it should really be by filesystem. We do not have an easy way to probe for file systems, however.
- Returns:
- the difference, in milliseconds, which two file timestamps must have in order for the two files to be given a creation order.
public URL getFileURL(File file) throws MalformedURLException
Get the URL for a file taking into account # characters.
- Parameters:
file
- the file whose URL representation is required.
- Returns:
- The FileURL value.
public static FileUtils getFileUtils()
Method to retrieve The FileUtils, which is shared by all users of this method.
- Returns:
- an instance of FileUtils.
- Since:
- Ant 1.6.3
public File getParentFile(File f)
This was originally an emulation ofFile.getParentFile
for JDK 1.1, but it is now implemented using that method (Ant 1.6.3 onwards).
- Parameters:
f
- the file whose parent is required.
- Returns:
- the given file's parent, or null if the file does not have a parent.
- Since:
- 1.10
public static boolean isAbsolutePath(String filename)
Verifies that the specified filename represents an absolute path.
- Parameters:
filename
- the filename to be checked.
- Returns:
- true if the filename represents an absolute path.
public boolean isSymbolicLink(File parent, String name) throws IOException
Checks whether a given file is a symbolic link. It doesn't really test for symbolic links but whether the canonical and absolute paths of the file are identical--this may lead to false positives on some platforms.
- Parameters:
parent
- the parent directory of the file to testname
- the name of the file to test.
- Returns:
- true if the file is a symbolic link.
- Since:
- Ant 1.5
public boolean isUpToDate(File source, File dest)
Returns true if the source is older than the dest.
- Parameters:
source
- source file (should be the older).dest
- dest file (should be the newer).
- Returns:
- true if the source is older than the dest, taking the granularity into account.
- Since:
- Ant 1.6.3
public boolean isUpToDate(File source, File dest, long granularity)
Returns true if the source is older than the dest. If the dest file does not exist, then the test returns false; it is implicitly not up do date.
- Parameters:
source
- source file (should be the older).dest
- dest file (should be the newer).granularity
- an offset added to the source time.
- Returns:
- true if the source is older than the dest after accounting for granularity.
- Since:
- Ant 1.6.3
public boolean isUpToDate(long sourceTime, long destTime)
Compare two timestamps for being up to date using the current granularity.
- Parameters:
sourceTime
- timestamp of source file.destTime
- timestamp of dest file.
- Returns:
- true if the dest file is considered up to date.
public boolean isUpToDate(long sourceTime, long destTime, long granularity)
Compare two timestamps for being up to date using the specified granularity.
- Parameters:
sourceTime
- timestamp of source file.destTime
- timestamp of dest file.granularity
- os/filesys granularity.
- Returns:
- true if the dest file is considered up to date.
public static FileUtils newFileUtils()
Factory method.
- Returns:
- a new instance of FileUtils.
public File normalize(String path)
"Normalize" the given absolute path. This includes:Unlike
- Uppercase the drive letter if there is one.
- Remove redundant slashes after the drive spec.
- Resolve all ./, .\, ../ and ..\ sequences.
- DOS style paths that start with a drive letter will have \ as the separator.
File#getCanonicalPath()
this method specifically does not resolve symbolic links.
- Parameters:
path
- the path to be normalized.
- Returns:
- the normalized version of the path.
public static final String readFully(Reader rdr) throws IOException
Read from reader till EOF.
- Parameters:
rdr
- the reader from which to read.
- Returns:
- the contents read out of the given reader.
public static final String readFully(Reader rdr, int bufferSize) throws IOException
Read from reader till EOF.
- Parameters:
rdr
- the reader from which to read.bufferSize
- the buffer size to use when reading.
- Returns:
- the contents read out of the given reader.
public String removeLeadingPath(File leading, File path)
Removes a leading path from a second path.
- Parameters:
leading
- The leading path, must not be null, must be absolute.path
- The path to remove from, must not be null, must be absolute.
- Returns:
- path's normalized absolute if it doesn't start with leading; path's path with leading's path removed otherwise.
- Since:
- Ant 1.5
public void rename(File from, File to) throws IOException
Renames a file, even if that involves crossing file system boundaries. This will removeto
(if it exists), ensure thatto
's parent directory exists and movefrom
, which involves deletingfrom
as well.
- Parameters:
from
- the file to move.to
- the new file name.
- Since:
- Ant 1.6
public File resolveFile(File file, String filename)
Interpret the filename as a file relative to the given file unless the filename already represents an absolute filename.
- Parameters:
file
- the "reference" file for relative paths. This instance must be an absolute file and must not contain "./" or "../" sequences (same for \ instead of /). If it is null, this call is equivalent tonew java.io.File(filename)
.filename
- a file name.
- Returns:
- an absolute file that doesn't contain "./" or "../" sequences and uses the correct separator for the current platform.
public void setFileLastModified(File file, long time)
Calls File.setLastModified(long time). Originally written to to dynamically bind to that call on Java1.2+.
- Parameters:
file
- the file whose modified time is to be settime
- the time to which the last modified time is to be set. if this is -1, the current time is used.
public String toURI(String path)
Constructs afile:
URI that represents the external form of the given pathname. Will be an absolute URI if the given path is absolute. This code doesn't handle non-ASCII characters properly.
- Parameters:
path
- the path in the local file system.
- Returns:
- the URI version of the local path.
- Since:
- Ant 1.6
public String toVMSPath(File f)
Returns a VMS String representation of aFile
object. This is useful since the JVM by default internally converts VMS paths to Unix style. The returned String is always an absolute path.
- Parameters:
f
- TheFile
to get the VMS path for.
- Returns:
- The absolute VMS path to
f
.