diff options
author | Sven Gothel <[email protected]> | 2013-03-18 04:02:46 +0100 |
---|---|---|
committer | Sven Gothel <[email protected]> | 2013-03-18 04:02:46 +0100 |
commit | 192224fc3c38521f38eb3bc51bebb16b628e4cdb (patch) | |
tree | 45eb572fed6672e5eacc9531b48aca226e579c08 /src/java/com/jogamp/common/util/TaskBase.java | |
parent | b1eb7ca6b9d7dec7ff62c1f1e8ef0a0545724d2f (diff) |
Function- RunnableTask: Clear runnableException @ start for re-entry; Fix tExecuted (@ exception); Add debug property 'jogamp.debug.TaskBase.TraceSource', to dump ctor stack trace @ exception.
Diffstat (limited to 'src/java/com/jogamp/common/util/TaskBase.java')
-rw-r--r-- | src/java/com/jogamp/common/util/TaskBase.java | 24 |
1 files changed, 20 insertions, 4 deletions
diff --git a/src/java/com/jogamp/common/util/TaskBase.java b/src/java/com/jogamp/common/util/TaskBase.java index 266a5b7..9fd7c0d 100644 --- a/src/java/com/jogamp/common/util/TaskBase.java +++ b/src/java/com/jogamp/common/util/TaskBase.java @@ -30,14 +30,20 @@ package com.jogamp.common.util; import java.io.PrintStream; +import jogamp.common.Debug; + /** * Helper class to provide a Runnable queue implementation with a Runnable wrapper * which notifies after execution for the <code>invokeAndWait()</code> semantics. */ public abstract class TaskBase implements Runnable { + /** Enable via the property <code>jogamp.debug.TaskBase.TraceSource</code> */ + private static final boolean TRACE_SOURCE = Debug.isPropertyDefined("jogamp.debug.TaskBase.TraceSource", true); + protected final Object syncObject; protected final boolean catchExceptions; - protected final PrintStream exceptionOut; + protected final PrintStream exceptionOut; + protected final Throwable sourceStack; protected Object attachment; protected Throwable runnableException; @@ -49,11 +55,21 @@ public abstract class TaskBase implements Runnable { this.syncObject = syncObject; this.catchExceptions = catchExceptions; this.exceptionOut = exceptionOut; + this.sourceStack = TRACE_SOURCE ? new Throwable("Creation @") : null; tCreated = System.currentTimeMillis(); tStarted = 0; tExecuted = 0; isFlushed = false; } + + protected final String getExceptionOutIntro() { + return catchExceptions ? "A catched" : "An uncatched"; + } + protected final void printSourceTrace() { + if( null != sourceStack && null != exceptionOut ) { + sourceStack.printStackTrace(exceptionOut); + } + } /** * Return the synchronization object if any. @@ -130,12 +146,12 @@ public abstract class TaskBase implements Runnable { public final long getTimestampBeforeExec() { return tStarted; } public final long getTimestampAfterExec() { return tExecuted; } public final long getDurationInQueue() { return tStarted - tCreated; } - public final long getDurationInExec() { return tExecuted - tStarted; } - public final long getDurationTotal() { return tExecuted - tCreated; } + public final long getDurationInExec() { return 0 < tExecuted ? tExecuted - tStarted : 0; } + public final long getDurationTotal() { return 0 < tExecuted ? tExecuted - tCreated : tStarted - tCreated; } @Override public String toString() { - return "RunnableTask[executed "+isExecuted()+", t2-t0 "+getDurationTotal()+", t2-t1 "+getDurationInExec()+", t1-t0 "+getDurationInQueue()+", throwable "+getThrowable()+", Attachment "+attachment+"]"; + return "RunnableTask[executed "+isExecuted()+", tTotal "+getDurationTotal()+" ms, tExec "+getDurationInExec()+" ms, tQueue "+getDurationInQueue()+" ms, attachment "+attachment+", throwable "+getThrowable()+"]"; } } |