always log stack of lock held more than 1 minute

(DEBUG only) I'm seeing deadlocks in a non-reproducible way and need to
get at the source. This should log the stacks of long-held locks, and
notify via Toast (when possible) when it occurs.
This commit is contained in:
Eric House 2019-04-25 11:54:11 -07:00
parent c757ba1386
commit 622fa53c64

View file

@ -261,11 +261,17 @@ public class GameLock implements AutoCloseable, Serializable {
private void logIfNull( GameLock result, String fmt, Object... args ) private void logIfNull( GameLock result, String fmt, Object... args )
{ {
if ( DEBUG_LOCKS && null == result ) { if ( BuildConfig.DEBUG && null == result ) {
String func = new Formatter().format( fmt, args ).toString(); String func = new Formatter().format( fmt, args ).toString();
Log.d( TAG, "%s.%s => null", this, func ); Log.d( TAG, "%s.%s => null", this, func );
Owner curOwner = mOwners.peek();
Log.d( TAG, "Unable to lock; cur owner: %s; would-be owner: %s", Log.d( TAG, "Unable to lock; cur owner: %s; would-be owner: %s",
mOwners.peek(), new Owner() ); curOwner, new Owner() );
long heldMS = System.currentTimeMillis() - curOwner.mStamp;
if ( heldMS > (60 * 1000) ) { // 1 minute's a long time
DbgUtils.showf( "GameLock: logged owner held for %d seconds!", heldMS / 1000 );
}
} }
} }
} }