org.apache.tools.ant.taskdefs.optional.unixClass Symlink
- java.lang.Object
- org.apache.tools.ant.ProjectComponent
- org.apache.tools.ant.Task
- org.apache.tools.ant.dispatch.DispatchTask
- org.apache.tools.ant.taskdefs.optional.unix.Symlink
- All Implemented Interfaces:
- java.lang.Cloneable, Dispatchable
public class Symlink extends DispatchTaskCreates, Deletes, Records and Restores Symlinks.This task performs several related operations. In the most trivial and default usage, it creates a link specified in the link attribute to a resource specified in the resource attribute. The second usage of this task is to traverse a directory structure specified by a fileset, and write a properties file in each included directory describing the links found in that directory. The third usage is to traverse a directory structure specified by a fileset, looking for properties files (also specified as included in the fileset) and recreate the links that have been previously recorded for each directory. Finally, it can be used to remove a symlink without deleting the associated resource.
Usage examples:
Make a link named "foo" to a resource named "bar.foo" in subdir:
<symlink link="${dir.top}/foo" resource="${dir.top}/subdir/bar.foo"/>Record all links in subdir and its descendants in files named "dir.links":
<symlink action="record" linkfilename="dir.links"> <fileset dir="${dir.top}" includes="subdir/**" /> </symlink>Recreate the links recorded in the previous example:
<symlink action="recreate"> <fileset dir="${dir.top}" includes="subdir/**/dir.links" /> </symlink>Delete a link named "foo" to a resource named "bar.foo" in subdir:
<symlink action="delete" link="${dir.top}/foo"/>LIMITATIONS: Because Java has no direct support for handling symlinks this task divines them by comparing canonical and absolute paths. On non-unix systems this may cause false positives. Furthermore, any operating system on which the command
ln -s link resource
is not a valid command on the command line will not be able to use action="delete", action="single" or action="recreate", but action="record" should still work. Finally, the lack of support for symlinks in Java means that all links are recorded as links to the canonical resource name. Therefore the link:link --> subdir/dir/../foo.bar
will be recorded aslink=subdir/foo.bar
and restored aslink --> subdir/foo.bar
.
Field Summary
Fields inherited from class org.apache.tools.ant.ProjectComponent
description, location, project
Constructor Summary
Constructors Constructor and Description Symlink()
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method and Description void
addFileset(FileSet set)
Add a fileset to this task.void
delete()
Delete a symlink.static void
deleteSymlink(java.io.File linkfil)
Deprecated.use org.apache.tools.ant.util.SymbolicLinkUtils#deleteSymbolicLink insteadstatic void
deleteSymlink(java.lang.String path)
Deprecated.use org.apache.tools.ant.util.SymbolicLinkUtils#deleteSymbolicLink insteadvoid
execute()
The standard method for executing any task.void
init()
Initialize the task.void
record()
Record symlinks.void
recreate()
Restore symlinks.void
setAction(java.lang.String action)
Set the action to be performed.void
setFailOnError(boolean foe)
Set failonerror mode.void
setLink(java.lang.String lnk)
Set the name of the link.void
setLinkfilename(java.lang.String lf)
Set the name of the file to which links will be written.void
setOverwrite(boolean owrite)
Set overwrite mode.void
setResource(java.lang.String src)
Set the name of the resource to which a link should be created.void
single()
Create a symlink.
Methods inherited from class org.apache.tools.ant.dispatch.DispatchTask
getAction, getActionParameterName
Methods inherited from class org.apache.tools.ant.Task
bindToOwner, getOwningTarget, getRuntimeConfigurableWrapper, getTaskName, getTaskType, getWrapper, handleErrorFlush, handleErrorOutput, handleFlush, handleInput, handleOutput, isInvalid, log, log, log, log, maybeConfigure, perform, reconfigure, setOwningTarget, setRuntimeConfigurableWrapper, setTaskName, setTaskType
Methods inherited from class org.apache.tools.ant.ProjectComponent
clone, getDescription, getLocation, getProject, setDescription, setLocation, setProject
Method Detail
init
public void init() throws BuildExceptionInitialize the task.
- Overrides:
init
in classTask
- Throws:
BuildException
- on error.
execute
public void execute() throws BuildExceptionThe standard method for executing any task.
- Overrides:
execute
in classTask
- Throws:
BuildException
- on error.
single
public void single() throws BuildExceptionCreate a symlink.
- Throws:
BuildException
- on error.- Since:
- Ant 1.7
delete
public void delete() throws BuildExceptionDelete a symlink.
- Throws:
BuildException
- on error.- Since:
- Ant 1.7
recreate
public void recreate() throws BuildExceptionRestore symlinks.
- Throws:
BuildException
- on error.- Since:
- Ant 1.7
record
public void record() throws BuildExceptionRecord symlinks.
- Throws:
BuildException
- on error.- Since:
- Ant 1.7
setOverwrite
public void setOverwrite(boolean owrite)Set overwrite mode. If set to false (default) the task will not overwrite existing links, and may stop the build if a link already exists depending on the setting of failonerror.
- Parameters:
owrite
- If true overwrite existing links.
setFailOnError
public void setFailOnError(boolean foe)Set failonerror mode. If set to true (default) the entire build fails upon error; otherwise the error is logged and the build will continue.
- Parameters:
foe
- If true throw BuildException on error, else log it.
setAction
public void setAction(java.lang.String action)Set the action to be performed. May be "single", "delete", "recreate" or "record".
- Overrides:
setAction
in classDispatchTask
- Parameters:
action
- The action to perform.
setLink
public void setLink(java.lang.String lnk)Set the name of the link. Used when action = "single".
- Parameters:
lnk
- The name for the link.
setResource
public void setResource(java.lang.String src)Set the name of the resource to which a link should be created. Used when action = "single".
- Parameters:
src
- The resource to be linked.
setLinkfilename
public void setLinkfilename(java.lang.String lf)Set the name of the file to which links will be written. Used when action = "record".
- Parameters:
lf
- The name of the file to write links to.
addFileset
public void addFileset(FileSet set)Add a fileset to this task.
- Parameters:
set
- The fileset to add.
deleteSymlink
@Deprecated public static void deleteSymlink(java.lang.String path) throws java.io.IOExceptionDeprecated. use org.apache.tools.ant.util.SymbolicLinkUtils#deleteSymbolicLink insteadDelete a symlink (without deleting the associated resource).This is a convenience method that simply invokes
deleteSymlink(java.io.File)
.
- Parameters:
path
- A string containing the path of the symlink to delete.- Throws:
java.io.IOException
- If calls toFile.rename
orFile.delete
fail.
deleteSymlink
@Deprecated public static void deleteSymlink(java.io.File linkfil) throws java.io.IOExceptionDeprecated. use org.apache.tools.ant.util.SymbolicLinkUtils#deleteSymbolicLink insteadDelete a symlink (without deleting the associated resource).This is a utility method that removes a unix symlink without removing the resource that the symlink points to. If it is accidentally invoked on a real file, the real file will not be harmed.
This method works by getting the canonical path of the link, using the canonical path to rename the resource (breaking the link) and then deleting the link. The resource is then returned to its original name inside a finally block to ensure that the resource is unharmed even in the event of an exception.
Since Ant 1.8.0 this method will try to delete the File object if it reports it wouldn't exist (as symlinks pointing nowhere usually do). Prior version would throw a FileNotFoundException in that case.
- Parameters:
linkfil
- AFile
object of the symlink to delete.- Throws:
java.io.IOException
- If calls toFile.rename
,File.delete
orFile.getCanonicalPath
fail.