diff --git a/common/source/java/ch/systemsx/cisd/common/concurrent/TerminableCallable.java b/common/source/java/ch/systemsx/cisd/common/concurrent/TerminableCallable.java index 3111f9aa5e85e56dbd0f0d64df175845924f717a..233dcc36361b49313d33f7277f24a6d9accaacf6 100644 --- a/common/source/java/ch/systemsx/cisd/common/concurrent/TerminableCallable.java +++ b/common/source/java/ch/systemsx/cisd/common/concurrent/TerminableCallable.java @@ -493,13 +493,24 @@ public final class TerminableCallable<V> implements Callable<V>, ITerminable * Returns <code>true</code>, if the callable has already started running. */ public boolean hasStarted() + { + return waitForStarted(NO_WAIT_MILLIS); + } + + /** + * Waits for the callable to start running. The method waits at most <var>timeoutMillis</var> + * milli-seconds. + * + * @return <code>true</code>, if the callable has started running when the method returns. + */ + public boolean waitForStarted(long timeoutMillis) throws StopException { try { - return started.await(0L, TimeUnit.MILLISECONDS); + return started.await(timeoutMillis, TimeUnit.MILLISECONDS); } catch (InterruptedException ex) { - return false; // Shouldn't happen. + throw new StopException(ex); } } @@ -507,13 +518,24 @@ public final class TerminableCallable<V> implements Callable<V>, ITerminable * Returns <code>true</code>, if the callable has already finished running. */ public boolean hasFinished() + { + return waitForFinished(NO_WAIT_MILLIS); + } + + /** + * Waits for the callable to finish running. The method waits at most <var>timeoutMillis</var> + * milli-seconds. + * + * @return <code>true</code>, if the callable has finished running when the method returns. + */ + public boolean waitForFinished(long timeoutMillis) throws StopException { try { - return finished.await(0L, TimeUnit.MILLISECONDS); + return finished.await(timeoutMillis, TimeUnit.MILLISECONDS); } catch (InterruptedException ex) { - return false; // Shouldn't happen. + throw new StopException(ex); } } @@ -523,13 +545,24 @@ public final class TerminableCallable<V> implements Callable<V>, ITerminable * method, if any. */ public boolean hasCleanedUp() + { + return waitForCleanedUp(NO_WAIT_MILLIS); + } + + /** + * Waits for the callable to finish cleaning up. The method waits at most <var>timeoutMillis</var> + * milli-seconds. + * + * @return <code>true</code>, if the callable has finished cleaning up when the method returns. + */ + public boolean waitForCleanedUp(long timeoutMillis) throws StopException { try { - return cleanedUp.await(0L, TimeUnit.MILLISECONDS); + return cleanedUp.await(timeoutMillis, TimeUnit.MILLISECONDS); } catch (InterruptedException ex) { - return false; // Shouldn't happen. + throw new StopException(ex); } }