Class Checksum
java.lang.Object
org.apache.tools.ant.ProjectComponent
org.apache.tools.ant.Task
org.apache.tools.ant.taskdefs.MatchingTask
org.apache.tools.ant.taskdefs.Checksum
- All Implemented Interfaces:
Cloneable, Condition, SelectorContainer
Used to create or verify file checksums.
- Since:
- Ant 1.5
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic classHelper class for the format attribute. -
Field Summary
Fields inherited from class MatchingTask
filesetFields inherited from class ProjectComponent
description, location, project -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidAdd a resource collection.voidaddFileset(FileSet set) Files to generate checksums for.static byte[]decodeHex(char[] data) Converts an array of characters representing hexadecimal values into an array of bytes of those same values.booleaneval()Calculate the checksum(s)voidexecute()Calculate the checksum(s).voidsetAlgorithm(String algorithm) Specifies the algorithm to be used to compute the checksum.voidSets the file for which the checksum is to be calculated.voidsetFileext(String fileext) Sets the file extension that is be to used to create or identify destination file.voidsetForceOverwrite(boolean forceOverwrite) Whether or not to overwrite existing file irrespective of whether it is newer than the source file.voidSelect the in/output pattern via a well know format name.voidsetPattern(String pattern) Specify the pattern to use as a MessageFormat pattern.voidsetProperty(String property) Sets the property to hold the generated checksum.voidsetProvider(String provider) Sets the MessageDigest algorithm provider to be used to calculate the checksum.voidsetReadBufferSize(int size) The size of the read buffer to use.voidSets the root directory where checksum files will be written/readvoidsetTotalproperty(String totalproperty) Sets the property to hold the generated total checksum for all files.voidsetVerifyproperty(String verifyProperty) Sets the verify property.Methods inherited from class MatchingTask
add, addAnd, addContains, addContainsRegexp, addCustom, addDate, addDepend, addDepth, addDifferent, addFilename, addMajority, addModified, addNone, addNot, addOr, addPresent, addSelector, addSize, addType, appendSelector, createExclude, createExcludesFile, createInclude, createIncludesFile, createPatternSet, getDirectoryScanner, getImplicitFileSet, getSelectors, hasSelectors, selectorCount, selectorElements, setCaseSensitive, setDefaultexcludes, setExcludes, setExcludesfile, setFollowSymlinks, setIncludes, setIncludesfile, setProject, XsetIgnore, XsetItemsModifier and TypeMethodDescriptionvoidadd(FileSelector selector) add an arbitrary selectorvoidaddAnd(AndSelector selector) add an "And" selector entry on the selector listvoidaddContains(ContainsSelector selector) add a contains selector entry on the selector listvoidaddContainsRegexp(ContainsRegexpSelector selector) add a regular expression selector entry on the selector listvoidaddCustom(ExtendSelector selector) add an extended selector entry on the selector listvoidaddDate(DateSelector selector) add a selector date entry on the selector listvoidaddDepend(DependSelector selector) add a depends selector entry on the selector listvoidaddDepth(DepthSelector selector) add a depth selector entry on the selector listvoidaddDifferent(DifferentSelector selector) add a type selector entry on the type listvoidaddFilename(FilenameSelector selector) add a selector filename entry on the selector listvoidaddMajority(MajoritySelector selector) add a majority selector entry on the selector listvoidaddModified(ModifiedSelector selector) add the modified selectorvoidaddNone(NoneSelector selector) add a "None" selector entry on the selector listvoidaddNot(NotSelector selector) add a "Not" selector entry on the selector listvoidaddOr(OrSelector selector) add an "Or" selector entry on the selector listvoidaddPresent(PresentSelector selector) add a present selector entry on the selector listvoidaddSelector(SelectSelector selector) add a "Select" selector entry on the selector listvoidaddSize(SizeSelector selector) add a selector size entry on the selector listvoidaddType(TypeSelector selector) add a type selector entry on the type listvoidappendSelector(FileSelector selector) Add a new selector into this container.add a name entry on the exclude listadd a name entry on the include files listadd a name entry on the include listadd a name entry on the include files listadd a set of patternsprotected DirectoryScannergetDirectoryScanner(File baseDir) Returns the directory scanner needed to access the files to process.protected final FileSetAccessor for the implicit fileset.Returns the set of selectors as an array.booleanIndicates whether there are any selectors here.intGives the count of the number of selectors in this containerReturns an enumerator for accessing the set of selectors.voidsetCaseSensitive(boolean isCaseSensitive) Sets case sensitivity of the file systemvoidsetDefaultexcludes(boolean useDefaultExcludes) Sets whether default exclusions should be used or not.voidsetExcludes(String excludes) Sets the set of exclude patterns.voidsetExcludesfile(File excludesfile) Sets the name of the file containing the includes patterns.voidsetFollowSymlinks(boolean followSymlinks) Sets whether or not symbolic links or Windows junctions should be followed.voidsetIncludes(String includes) Sets the set of include patterns.voidsetIncludesfile(File includesfile) Sets the name of the file containing the includes patterns.voidsetProject(Project project) Sets the project object of this component.voidXsetIgnore(String ignoreString) List of filenames and directory names to not include.voidSet this to be the items in the base directory that you want to be included.Methods inherited from class Task
bindToOwner, getOwningTarget, getRuntimeConfigurableWrapper, getTaskName, getTaskType, getWrapper, handleErrorFlush, handleErrorOutput, handleFlush, handleInput, handleOutput, init, isInvalid, log, log, log, log, maybeConfigure, perform, reconfigure, setOwningTarget, setRuntimeConfigurableWrapper, setTaskName, setTaskTypeModifier and TypeMethodDescriptionfinal voidbindToOwner(Task owner) Bind a task to another; use this when configuring a newly created task to do work on behalf of another.Returns the container target of this task.Returns the wrapper used for runtime configuration.Returns the name to use in logging messages.Return the type of task.protected RuntimeConfigurableReturn the runtime configurable structure for this task.protected voidhandleErrorFlush(String output) Handles an error line by logging it with the WARN priority.protected voidhandleErrorOutput(String output) Handles an error output by logging it with the WARN priority.protected voidhandleFlush(String output) Handles output by logging it with the INFO priority.protected inthandleInput(byte[] buffer, int offset, int length) Handle an input request by this task.protected voidhandleOutput(String output) Handles output by logging it with the INFO priority.voidinit()Called by the project to let the task initialize properly.protected final booleanHas this task been marked invalid?voidLogs a message with the default (INFO) priority.voidLogs a message with the given priority.voidLogs a message with the given priority.voidLogs a message with the given priority.voidConfigures this task - if it hasn't been done already.final voidperform()Performs this task if it's still valid, or gets a replacement version and performs that otherwise.voidForce the task to be reconfigured from its RuntimeConfigurable.voidsetOwningTarget(Target target) Sets the target container of this task.voidSets the wrapper to be used for runtime configuration.voidsetTaskName(String name) Sets the name to use in logging messages.voidsetTaskType(String type) Sets the name with which the task has been invoked.Methods inherited from class ProjectComponent
clone, getDescription, getLocation, getProject, setDescription, setLocationModifier and TypeMethodDescriptionclone()Returns the description of the current action.Returns the file/location where this task was defined.Returns the project to which this component belongs.voidsetDescription(String desc) Sets a description of the current action.voidsetLocation(Location location) Sets the file/location where this task was defined.
-
Constructor Details
-
Checksum
public Checksum()
-
-
Method Details
-
setFile
Sets the file for which the checksum is to be calculated.- Parameters:
file- aFilevalue
-
setTodir
Sets the root directory where checksum files will be written/read- Parameters:
todir- the directory to write to- Since:
- Ant 1.6
-
setAlgorithm
Specifies the algorithm to be used to compute the checksum. Defaults to "MD5". Other popular algorithms like "SHA" may be used as well.- Parameters:
algorithm- aStringvalue
-
setProvider
Sets the MessageDigest algorithm provider to be used to calculate the checksum.- Parameters:
provider- aStringvalue
-
setFileext
Sets the file extension that is be to used to create or identify destination file.- Parameters:
fileext- aStringvalue
-
setProperty
Sets the property to hold the generated checksum.- Parameters:
property- aStringvalue
-
setTotalproperty
Sets the property to hold the generated total checksum for all files.- Parameters:
totalproperty- aStringvalue- Since:
- Ant 1.6
-
setVerifyproperty
Sets the verify property. This project property holds the result of a checksum verification - "true" or "false"- Parameters:
verifyProperty- aStringvalue
-
setForceOverwrite
public void setForceOverwrite(boolean forceOverwrite) Whether or not to overwrite existing file irrespective of whether it is newer than the source file. Defaults to false.- Parameters:
forceOverwrite- abooleanvalue
-
setReadBufferSize
public void setReadBufferSize(int size) The size of the read buffer to use.- Parameters:
size- anintvalue
-
setFormat
Select the in/output pattern via a well know format name.- Parameters:
e- anenumeratedvalue- Since:
- 1.7.0
-
setPattern
Specify the pattern to use as a MessageFormat pattern.{0} gets replaced by the checksum, {1} by the filename.
- Parameters:
pattern- aStringvalue- Since:
- 1.7.0
-
addFileset
Files to generate checksums for.- Parameters:
set- a fileset of files to generate checksums for.
-
add
Add a resource collection.- Parameters:
rc- the ResourceCollection to add.
-
execute
Calculate the checksum(s).- Overrides:
executein classTask- Throws:
BuildException- on error
-
eval
Calculate the checksum(s)- Specified by:
evalin interfaceCondition- Returns:
- Returns true if the checksum verification test passed, false otherwise.
- Throws:
BuildException- on error
-
decodeHex
Converts an array of characters representing hexadecimal values into an array of bytes of those same values. The returned array will be half the length of the passed array, as it takes two characters to represent any given byte. An exception is thrown if the passed char array has an odd number of elements. NOTE: This code is copied from jakarta-commons codec.- Parameters:
data- an array of characters representing hexadecimal values- Returns:
- the converted array of bytes
- Throws:
BuildException- on error
-