Class URLResource
java.lang.Object
org.apache.tools.ant.ProjectComponent
org.apache.tools.ant.types.DataType
org.apache.tools.ant.types.Resource
org.apache.tools.ant.types.resources.URLResource
- All Implemented Interfaces:
Cloneable, Comparable<Resource>, Iterable<Resource>, ResourceCollection, URLProvider
Exposes a URL as a Resource.
- Since:
- Ant 1.7
-
Field Summary
Fields inherited from class Resource
MAGIC, UNKNOWN_DATETIME, UNKNOWN_SIZEModifier and TypeFieldDescriptionprotected static final intMagic numberstatic final longConstant unknown datetime for getLastModifiedstatic final longConstant unknown sizeFields inherited from class ProjectComponent
description, location, project -
Constructor Summary
ConstructorsConstructorDescriptionDefault constructor.URLResource(File f) Convenience constructor.String constructor for Ant attribute introspection.URLResource(URL u) Convenience constructor.Convenience constructor. -
Method Summary
Modifier and TypeMethodDescriptionprotected voidconnect()Ensure that we have a connection.protected voidconnect(int logLevel) Ensure that we have a connection.booleanTest whether an Object equals this URLResource.Get an InputStream for the Resource.longTells the modification time in milliseconds since 01.01.1970 .getName()Get the name of this URLResource (its file component minus the leading separator).Get an OutputStream for the Resource.protected URLResourcegetRef()Perform the check for circular references and return the referenced Resource.longgetSize()Get the size of this Resource.getURL()Get the URL used by this URLResource.inthashCode()Get the hash code for this Resource.booleanTells if the resource is a directory.booleanisExists()Find out whether the URL exists.voidsetBaseURL(URL base) Base URL which combined with the relativePath attribute defines the URL.voidSet the URL from a File.voidOverrides the super version.voidRelative path which combined with the baseURL attribute defines the URL.voidSet the URL for this URLResource.toString()Return this URLResource formatted as a String.Methods inherited from class Resource
as, asOptional, clone, compareTo, getMagicNumber, isFilesystemOnly, iterator, setDirectory, setExists, setLastModified, setName, setSize, size, toLongStringModifier and TypeMethodDescription<T> TReturns a view of this resource that implements the interface given as the argument or null if there is no such view.<T> Optional<T> asOptional(Class<T> clazz) ReturnResource.as(Class)as anOptional.clone()Clone this Resource.intDelegates to a comparison of names.protected static intgetMagicNumber(byte[] seed) Create a "magic number" for use in hashCode calculations.booleanFulfill the ResourceCollection contract.iterator()Fulfill the ResourceCollection contract.voidsetDirectory(boolean directory) Set the directory attribute.voidsetExists(boolean exists) Set the exists attribute.voidsetLastModified(long lastmodified) Set the last modification attribute.voidSet the name of this Resource.voidsetSize(long size) Set the size of this Resource.intsize()Fulfill the ResourceCollection contract.final StringGet a long String representation of this Resource.Methods inherited from class DataType
checkAttributesAllowed, checkChildrenAllowed, circularReference, dieOnCircularReference, dieOnCircularReference, dieOnCircularReference, getCheckedRef, getCheckedRef, getCheckedRef, getCheckedRef, getCheckedRef, getDataTypeName, getRefid, invokeCircularReferenceCheck, isChecked, isReference, noChildrenAllowed, pushAndInvokeCircularReferenceCheck, setChecked, tooManyAttributesModifier and TypeMethodDescriptionprotected voidcheck that it is ok to set attributes, i.e that no reference is definedprotected voidcheck that it is ok to add children, i.e that no reference is definedprotected BuildExceptionCreates an exception that indicates the user has generated a loop of data types referencing each other.protected voidConvenience method.protected voiddieOnCircularReference(Stack<Object> stack, Project project) Check to see whether any DataType we hold references to is included in the Stack (which holds all DataType instances that directly or indirectly reference this instance, including this instance itself).protected voidConvenience method.protected <T> TDeprecated.use getCheckedRef(Class)protected <T> TgetCheckedRef(Class<T> requiredClass) Performs the check for circular references and returns the referenced object.protected <T> TgetCheckedRef(Class<T> requiredClass, String dataTypeName) Performs the check for circular references and returns the referenced object.protected <T> TgetCheckedRef(Class<T> requiredClass, String dataTypeName, Project project) Performs the check for circular references and returns the referenced object.protected <T> TDeprecated.use getCheckedRef(Class)protected StringGets as descriptive as possible a name used for this datatype instance.getRefid()get the reference set on this objectstatic voidinvokeCircularReferenceCheck(DataType dt, Stack<Object> stk, Project p) Allow DataTypes outside org.apache.tools.ant.types to indirectly call dieOnCircularReference on nested DataTypes.protected booleanThe flag that is used to indicate that circular references have been checked.booleanHas the refid attribute of this element been set?protected BuildExceptionCreates an exception that indicates that this XML element must not have child elements if the refid attribute is set.static voidpushAndInvokeCircularReferenceCheck(DataType dt, Stack<Object> stk, Project p) Allow DataTypes outside org.apache.tools.ant.types to indirectly call dieOnCircularReference on nested DataTypes.protected voidsetChecked(boolean checked) Set the flag that is used to indicate that circular references have been checked.protected BuildExceptionCreates an exception that indicates that refid has to be the only attribute if it is set.Methods inherited from class ProjectComponent
getDescription, getLocation, getProject, log, log, setDescription, setLocation, setProjectModifier and TypeMethodDescriptionReturns the description of the current action.Returns the file/location where this task was defined.Returns the project to which this component belongs.voidLogs a message with the default (INFO) priority.voidLogs a message with the given priority.voidsetDescription(String desc) Sets a description of the current action.voidsetLocation(Location location) Sets the file/location where this task was defined.voidsetProject(Project project) Sets the project object of this component.Methods inherited from interface Iterable
forEach, spliteratorMethods inherited from interface ResourceCollection
isEmpty, streamModifier and TypeMethodDescriptiondefault booleanisEmpty()Learn whether thisResourceCollectionis empty.stream()Return aStreamover thisResourceCollection.
-
Constructor Details
-
URLResource
public URLResource()Default constructor. -
URLResource
-
URLResource
-
URLResource
-
URLResource
String constructor for Ant attribute introspection.- Parameters:
u- String representation of this URL.- See Also:
-
-
Method Details
-
setURL
-
setFile
-
setBaseURL
Base URL which combined with the relativePath attribute defines the URL.- Parameters:
base- URL- Since:
- Ant 1.8.0
-
setRelativePath
Relative path which combined with the baseURL attribute defines the URL.- Parameters:
r- String- Since:
- Ant 1.8.0
-
getURL
Get the URL used by this URLResource.- Specified by:
getURLin interfaceURLProvider- Returns:
- a URL object.
-
setRefid
-
getName
-
toString
-
isExists
-
getLastModified
public long getLastModified()Tells the modification time in milliseconds since 01.01.1970 .- Overrides:
getLastModifiedin classResource- Returns:
- 0 if the resource does not exist to mirror the behavior
of
File.
-
isDirectory
public boolean isDirectory()Tells if the resource is a directory.- Overrides:
isDirectoryin classResource- Returns:
- boolean whether the resource is a directory.
-
getSize
-
equals
-
hashCode
-
getInputStream
Get an InputStream for the Resource.- Overrides:
getInputStreamin classResource- Returns:
- an InputStream containing this Resource's content.
- Throws:
IOException- if unable to provide the content of this Resource as a stream.UnsupportedOperationException- if InputStreams are not supported for this Resource type.
-
getOutputStream
Get an OutputStream for the Resource.- Overrides:
getOutputStreamin classResource- Returns:
- an OutputStream to which content can be written.
- Throws:
IOException- if unable to provide the content of this Resource as a stream.UnsupportedOperationException- if OutputStreams are not supported for this Resource type.IOException- if the URL cannot be opened.
-
connect
Ensure that we have a connection.- Throws:
IOException- if the connection cannot be established.
-
connect
Ensure that we have a connection.- Parameters:
logLevel- severity to use when logging connection errors. Should be one of theMSG_constants inProject.- Throws:
IOException- if the connection cannot be established.- Since:
- Ant 1.8.2
-
getRef
Description copied from class:ResourcePerform the check for circular references and return the referenced Resource.
-