Class TaskAdapter
java.lang.Object
org.apache.tools.ant.ProjectComponent
org.apache.tools.ant.Task
org.apache.tools.ant.TaskAdapter
- All Implemented Interfaces:
Cloneable, TypeAdapter
Uses introspection to "adapt" an arbitrary Bean which doesn't
itself extend Task, but still contains an execute method and optionally
a setProject method.
-
Field Summary
Fields inherited from class ProjectComponent
description, location, project -
Constructor Summary
ConstructorsConstructorDescriptionNo-arg constructor for reflection.TaskAdapter(Object proxy) Constructor for given proxy. -
Method Summary
Modifier and TypeMethodDescriptionvoidcheckProxyClass(Class<?> proxyClass) Check if the proxy class is a valid class to use with this adapter.static voidcheckTaskClass(Class<?> taskClass, Project project) Checks whether or not a class is suitable to be adapted by TaskAdapter.voidexecute()Executes the proxied task.getProxy()Returns the target object being proxied.voidSets the target object to proxy for.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, setLocation, setProjectModifier 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.voidsetProject(Project project) Sets the project object of this component.Methods inherited from class Object
equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface TypeAdapter
getProject, setProjectModifier and TypeMethodDescriptionGets the projectvoidSets the project
-
Constructor Details
-
TaskAdapter
public TaskAdapter()No-arg constructor for reflection. -
TaskAdapter
Constructor for given proxy. So you could write easier codemyTaskContainer.addTask(new TaskAdapter(myProxy));
- Parameters:
proxy- The object which Ant should use as task.
-
-
Method Details
-
checkTaskClass
Checks whether or not a class is suitable to be adapted by TaskAdapter. If the class is of type Dispatchable, the check is not performed because the method that will be executed will be determined only at runtime of the actual task and not during parse time. This only checks conditions which are additionally required for tasks adapted by TaskAdapter. Thus, this method should be called by Project.checkTaskClass. Throws a BuildException and logs as Project.MSG_ERR for conditions that will cause the task execution to fail. Logs other suspicious conditions with Project.MSG_WARN.- Parameters:
taskClass- Class to test for suitability. Must not benull.project- Project to log warnings/errors to. Must not benull.- See Also:
-
checkProxyClass
Check if the proxy class is a valid class to use with this adapter. The class must have a public no-arg "execute()" method.- Specified by:
checkProxyClassin interfaceTypeAdapter- Parameters:
proxyClass- the class to check.
-
execute
Executes the proxied task.- Overrides:
executein classTask- Throws:
BuildException- if the project could not be set or the method could not be executed.
-
setProxy
Sets the target object to proxy for.- Specified by:
setProxyin interfaceTypeAdapter- Parameters:
o- The target object. Must not benull.
-
getProxy
Returns the target object being proxied.- Specified by:
getProxyin interfaceTypeAdapter- Returns:
- the target proxy object.
-