Class WhileClosure
- java.lang.Object
-
- org.apache.commons.collections.functors.WhileClosure
-
- All Implemented Interfaces:
java.io.Serializable,Closure
public class WhileClosure extends java.lang.Object implements Closure, java.io.Serializable
Closure implementation that executes a closure repeatedly until a condition is met, like a do-while or while loop.WARNING: from v3.2.2 onwards this class will throw an
UnsupportedOperationExceptionwhen trying to serialize or de-serialize an instance to prevent potential remote code execution exploits.In order to re-enable serialization support for
WhileClosurethe following system property can be used (via -Dproperty=true):org.apache.commons.collections.enableUnsafeSerialization
- Since:
- Commons Collections 3.0
- See Also:
- Serialized Form
-
-
Constructor Summary
Constructors Constructor Description WhileClosure(Predicate predicate, Closure closure, boolean doLoop)Constructor that performs no validation.
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description voidexecute(java.lang.Object input)Executes the closure until the predicate is false.ClosuregetClosure()Gets the closure.static ClosuregetInstance(Predicate predicate, Closure closure, boolean doLoop)Factory method that performs validation.PredicategetPredicate()Gets the predicate in use.booleanisDoLoop()Is the loop a do-while loop.
-
-
-
Constructor Detail
-
WhileClosure
public WhileClosure(Predicate predicate, Closure closure, boolean doLoop)
Constructor that performs no validation. UsegetInstanceif you want that.- Parameters:
predicate- the predicate used to evaluate when the loop terminates, not nullclosure- the closure the execute, not nulldoLoop- true to act as a do-while loop, always executing the closure once
-
-
Method Detail
-
getInstance
public static Closure getInstance(Predicate predicate, Closure closure, boolean doLoop)
Factory method that performs validation.- Parameters:
predicate- the predicate used to evaluate when the loop terminates, not nullclosure- the closure the execute, not nulldoLoop- true to act as a do-while loop, always executing the closure once- Returns:
- the
whileclosure - Throws:
java.lang.IllegalArgumentException- if the predicate or closure is null
-
execute
public void execute(java.lang.Object input)
Executes the closure until the predicate is false.
-
getPredicate
public Predicate getPredicate()
Gets the predicate in use.- Returns:
- the predicate
- Since:
- Commons Collections 3.1
-
getClosure
public Closure getClosure()
Gets the closure.- Returns:
- the closure
- Since:
- Commons Collections 3.1
-
isDoLoop
public boolean isDoLoop()
Is the loop a do-while loop.- Returns:
- true is do-while, false if while
- Since:
- Commons Collections 3.1
-
-