Class Parallel
java.lang.Object
org.apache.tools.ant.ProjectComponent
org.apache.tools.ant.Task
org.apache.tools.ant.taskdefs.Parallel
- All Implemented Interfaces:
Cloneable, TaskContainer
Executes the contained tasks in separate threads, continuing
once all are completed.
New behavior allows for the ant script to specify a maximum number of
threads that will be executed in parallel. One should be very careful about
using the waitFor task when specifying threadCount
as it can cause deadlocks if the number of threads is too small or if one of
the nested tasks fails to execute completely. The task selection algorithm
will insure that the tasks listed before a task have started before that
task is started, but it will not insure a successful completion of those
tasks or that those tasks will finish first (i.e. it's a classic race
condition).
- Since:
- Ant 1.4
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic classClass which holds a list of tasks to execute -
Field Summary
Fields inherited from class ProjectComponent
description, location, project -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidaddDaemons(Parallel.TaskList daemonTasks) Add a group of daemon threadsvoidAdd a nested task to execute in parallel.voidexecute()Execute the parallel tasksvoidsetFailOnAny(boolean failOnAny) Control whether a failure in a nested task halts execution.voidsetPollInterval(int pollInterval) Interval to poll for completed threads when threadCount or threadsPerProcessor is specified.voidsetThreadCount(int numThreads) Statically determine the maximum number of tasks to execute simultaneously.voidsetThreadsPerProcessor(int numThreadsPerProcessor) Dynamically generates the number of threads to execute based on the number of available processors (viajava.lang.Runtime.availableProcessors()).voidsetTimeout(long timeout) Sets the timeout on this set of tasks.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.
-
Constructor Details
-
Parallel
public Parallel()
-
-
Method Details
-
addDaemons
Add a group of daemon threads- Parameters:
daemonTasks- The tasks to be executed as daemon.
-
setPollInterval
public void setPollInterval(int pollInterval) Interval to poll for completed threads when threadCount or threadsPerProcessor is specified. Integer in milliseconds.; optional- Parameters:
pollInterval- New value of property pollInterval.
-
setFailOnAny
public void setFailOnAny(boolean failOnAny) Control whether a failure in a nested task halts execution. Note that the task will complete but existing threads will continue to run - they are not stopped- Parameters:
failOnAny- if true any nested task failure causes parallel to complete.
-
addTask
Add a nested task to execute in parallel.- Specified by:
addTaskin interfaceTaskContainer- Parameters:
nestedTask- Nested task to be executed in parallel
-
setThreadsPerProcessor
public void setThreadsPerProcessor(int numThreadsPerProcessor) Dynamically generates the number of threads to execute based on the number of available processors (viajava.lang.Runtime.availableProcessors()). Will overwrite the value set in threadCount; optional- Parameters:
numThreadsPerProcessor- Number of threads to create per available processor.
-
setThreadCount
public void setThreadCount(int numThreads) Statically determine the maximum number of tasks to execute simultaneously. If there are less tasks than threads then all will be executed at once, if there are more then onlythreadCounttasks will be executed at one time. IfthreadsPerProcessoris set then this value is ignored.; optional- Parameters:
numThreads- total number of threads.
-
setTimeout
public void setTimeout(long timeout) Sets the timeout on this set of tasks. If the timeout is reached before the other threads complete, the execution of this task completes with an exception. Note that existing threads continue to run.- Parameters:
timeout- timeout in milliseconds.
-
execute
Execute the parallel tasks- Overrides:
executein classTask- Throws:
BuildException- if any of the threads failed.
-