ObjectWatcher.smali
.class public final Lleakcanary/ObjectWatcher;
.super Ljava/lang/Object;
.source "SourceFile"
# instance fields
.field private final checkRetainedExecutor:Ljava/util/concurrent/Executor;
.field private final clock:Lleakcanary/Clock;
.field private final isEnabled:Lkotlin/f/a/a;
.annotation system Ldalvik/annotation/Signature;
value = {
"Lkotlin/f/a/a<",
"Ljava/lang/Boolean;",
">;"
}
.end annotation
.end field
.field private final onObjectRetainedListeners:Ljava/util/Set;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Set<",
"Lleakcanary/OnObjectRetainedListener;",
">;"
}
.end annotation
.end field
.field private final queue:Ljava/lang/ref/ReferenceQueue;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/lang/ref/ReferenceQueue<",
"Ljava/lang/Object;",
">;"
}
.end annotation
.end field
.field private final watchedObjects:Ljava/util/Map;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Map<",
"Ljava/lang/String;",
"Lleakcanary/KeyedWeakReference;",
">;"
}
.end annotation
.end field
# direct methods
.method public constructor <init>(Lleakcanary/Clock;Ljava/util/concurrent/Executor;Lkotlin/f/a/a;)V
.registers 5
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lleakcanary/Clock;",
"Ljava/util/concurrent/Executor;",
"Lkotlin/f/a/a<",
"Ljava/lang/Boolean;",
">;)V"
}
.end annotation
const-string v0, "clock"
invoke-static {p1, v0}, Lkotlin/f/b/o;->b(Ljava/lang/Object;Ljava/lang/String;)V
const-string v0, "checkRetainedExecutor"
invoke-static {p2, v0}, Lkotlin/f/b/o;->b(Ljava/lang/Object;Ljava/lang/String;)V
const-string v0, "isEnabled"
invoke-static {p3, v0}, Lkotlin/f/b/o;->b(Ljava/lang/Object;Ljava/lang/String;)V
.line 36
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
iput-object p1, p0, Lleakcanary/ObjectWatcher;->clock:Lleakcanary/Clock;
iput-object p2, p0, Lleakcanary/ObjectWatcher;->checkRetainedExecutor:Ljava/util/concurrent/Executor;
iput-object p3, p0, Lleakcanary/ObjectWatcher;->isEnabled:Lkotlin/f/a/a;
.line 45
new-instance p1, Ljava/util/LinkedHashSet;
invoke-direct {p1}, Ljava/util/LinkedHashSet;-><init>()V
check-cast p1, Ljava/util/Set;
iput-object p1, p0, Lleakcanary/ObjectWatcher;->onObjectRetainedListeners:Ljava/util/Set;
.line 50
new-instance p1, Ljava/util/LinkedHashMap;
invoke-direct {p1}, Ljava/util/LinkedHashMap;-><init>()V
check-cast p1, Ljava/util/Map;
iput-object p1, p0, Lleakcanary/ObjectWatcher;->watchedObjects:Ljava/util/Map;
.line 52
new-instance p1, Ljava/lang/ref/ReferenceQueue;
invoke-direct {p1}, Ljava/lang/ref/ReferenceQueue;-><init>()V
iput-object p1, p0, Lleakcanary/ObjectWatcher;->queue:Ljava/lang/ref/ReferenceQueue;
return-void
.end method
.method public synthetic constructor <init>(Lleakcanary/Clock;Ljava/util/concurrent/Executor;Lkotlin/f/a/a;ILkotlin/f/b/j;)V
.registers 6
and-int/lit8 p4, p4, 0x4
if-eqz p4, :cond_8
.line 42
sget-object p3, Lleakcanary/ObjectWatcher$1;->INSTANCE:Lleakcanary/ObjectWatcher$1;
check-cast p3, Lkotlin/f/a/a;
:cond_8
invoke-direct {p0, p1, p2, p3}, Lleakcanary/ObjectWatcher;-><init>(Lleakcanary/Clock;Ljava/util/concurrent/Executor;Lkotlin/f/a/a;)V
return-void
.end method
.method public static final synthetic access$moveToRetained(Lleakcanary/ObjectWatcher;Ljava/lang/String;)V
.registers 2
.line 36
invoke-direct {p0, p1}, Lleakcanary/ObjectWatcher;->moveToRetained(Ljava/lang/String;)V
return-void
.end method
.method private final declared-synchronized moveToRetained(Ljava/lang/String;)V
.registers 4
monitor-enter p0
.line 176
:try_start_1
invoke-direct {p0}, Lleakcanary/ObjectWatcher;->removeWeaklyReachableObjects()V
.line 177
iget-object v0, p0, Lleakcanary/ObjectWatcher;->watchedObjects:Ljava/util/Map;
invoke-interface {v0, p1}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object p1
check-cast p1, Lleakcanary/KeyedWeakReference;
if-eqz p1, :cond_2f
.line 179
iget-object v0, p0, Lleakcanary/ObjectWatcher;->clock:Lleakcanary/Clock;
invoke-interface {v0}, Lleakcanary/Clock;->uptimeMillis()J
move-result-wide v0
invoke-virtual {p1, v0, v1}, Lleakcanary/KeyedWeakReference;->setRetainedUptimeMillis(J)V
.line 180
iget-object p1, p0, Lleakcanary/ObjectWatcher;->onObjectRetainedListeners:Ljava/util/Set;
check-cast p1, Ljava/lang/Iterable;
.line 218
invoke-interface {p1}, Ljava/lang/Iterable;->iterator()Ljava/util/Iterator;
move-result-object p1
:goto_1f
invoke-interface {p1}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_2f
invoke-interface {p1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lleakcanary/OnObjectRetainedListener;
.line 180
invoke-interface {v0}, Lleakcanary/OnObjectRetainedListener;->onObjectRetained()V
:try_end_2e
.catchall {:try_start_1 .. :try_end_2e} :catchall_31
goto :goto_1f
.line 182
:cond_2f
monitor-exit p0
return-void
:catchall_31
move-exception p1
monitor-exit p0
goto :goto_35
:goto_34
throw p1
:goto_35
goto :goto_34
.end method
.method private final removeWeaklyReachableObjects()V
.registers 4
.line 189
:cond_0
iget-object v0, p0, Lleakcanary/ObjectWatcher;->queue:Ljava/lang/ref/ReferenceQueue;
invoke-virtual {v0}, Ljava/lang/ref/ReferenceQueue;->poll()Ljava/lang/ref/Reference;
move-result-object v0
check-cast v0, Lleakcanary/KeyedWeakReference;
if-eqz v0, :cond_13
.line 191
iget-object v1, p0, Lleakcanary/ObjectWatcher;->watchedObjects:Ljava/util/Map;
invoke-virtual {v0}, Lleakcanary/KeyedWeakReference;->getKey()Ljava/lang/String;
move-result-object v2
invoke-interface {v1, v2}, Ljava/util/Map;->remove(Ljava/lang/Object;)Ljava/lang/Object;
:cond_13
if-nez v0, :cond_0
return-void
.end method
# virtual methods
.method public final declared-synchronized addOnObjectRetainedListener(Lleakcanary/OnObjectRetainedListener;)V
.registers 3
monitor-enter p0
:try_start_1
const-string v0, "listener"
invoke-static {p1, v0}, Lkotlin/f/b/o;->b(Ljava/lang/Object;Ljava/lang/String;)V
.line 105
iget-object v0, p0, Lleakcanary/ObjectWatcher;->onObjectRetainedListeners:Ljava/util/Set;
invoke-interface {v0, p1}, Ljava/util/Set;->add(Ljava/lang/Object;)Z
:try_end_b
.catchall {:try_start_1 .. :try_end_b} :catchall_d
.line 106
monitor-exit p0
return-void
:catchall_d
move-exception p1
monitor-exit p0
throw p1
.end method
.method public final declared-synchronized clearObjectsWatchedBefore(J)V
.registers 9
monitor-enter p0
.line 162
:try_start_1
iget-object v0, p0, Lleakcanary/ObjectWatcher;->watchedObjects:Ljava/util/Map;
.line 207
new-instance v1, Ljava/util/LinkedHashMap;
invoke-direct {v1}, Ljava/util/LinkedHashMap;-><init>()V
check-cast v1, Ljava/util/Map;
.line 208
invoke-interface {v0}, Ljava/util/Map;->entrySet()Ljava/util/Set;
move-result-object v0
invoke-interface {v0}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object v0
:cond_12
:goto_12
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v2
if-eqz v2, :cond_3d
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v2
check-cast v2, Ljava/util/Map$Entry;
.line 162
invoke-interface {v2}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
move-result-object v3
check-cast v3, Lleakcanary/KeyedWeakReference;
invoke-virtual {v3}, Lleakcanary/KeyedWeakReference;->getWatchUptimeMillis()J
move-result-wide v3
cmp-long v5, v3, p1
if-gtz v5, :cond_2e
const/4 v3, 0x1
goto :goto_2f
:cond_2e
const/4 v3, 0x0
:goto_2f
if-eqz v3, :cond_12
.line 210
invoke-interface {v2}, Ljava/util/Map$Entry;->getKey()Ljava/lang/Object;
move-result-object v3
invoke-interface {v2}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
move-result-object v2
invoke-interface {v1, v3, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
goto :goto_12
.line 163
:cond_3d
invoke-interface {v1}, Ljava/util/Map;->values()Ljava/util/Collection;
move-result-object p1
check-cast p1, Ljava/lang/Iterable;
.line 214
invoke-interface {p1}, Ljava/lang/Iterable;->iterator()Ljava/util/Iterator;
move-result-object p1
:goto_47
invoke-interface {p1}, Ljava/util/Iterator;->hasNext()Z
move-result p2
if-eqz p2, :cond_57
invoke-interface {p1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object p2
check-cast p2, Lleakcanary/KeyedWeakReference;
.line 163
invoke-virtual {p2}, Lleakcanary/KeyedWeakReference;->clear()V
goto :goto_47
.line 164
:cond_57
iget-object p1, p0, Lleakcanary/ObjectWatcher;->watchedObjects:Ljava/util/Map;
invoke-interface {p1}, Ljava/util/Map;->keySet()Ljava/util/Set;
move-result-object p1
invoke-interface {v1}, Ljava/util/Map;->keySet()Ljava/util/Set;
move-result-object p2
check-cast p2, Ljava/util/Collection;
invoke-interface {p1, p2}, Ljava/util/Set;->removeAll(Ljava/util/Collection;)Z
:try_end_66
.catchall {:try_start_1 .. :try_end_66} :catchall_68
.line 165
monitor-exit p0
return-void
:catchall_68
move-exception p1
monitor-exit p0
goto :goto_6c
:goto_6b
throw p1
:goto_6c
goto :goto_6b
.end method
.method public final declared-synchronized clearWatchedObjects()V
.registers 3
monitor-enter p0
.line 171
:try_start_1
iget-object v0, p0, Lleakcanary/ObjectWatcher;->watchedObjects:Ljava/util/Map;
invoke-interface {v0}, Ljava/util/Map;->values()Ljava/util/Collection;
move-result-object v0
check-cast v0, Ljava/lang/Iterable;
.line 216
invoke-interface {v0}, Ljava/lang/Iterable;->iterator()Ljava/util/Iterator;
move-result-object v0
:goto_d
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v1
if-eqz v1, :cond_1d
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v1
check-cast v1, Lleakcanary/KeyedWeakReference;
.line 171
invoke-virtual {v1}, Lleakcanary/KeyedWeakReference;->clear()V
goto :goto_d
.line 172
:cond_1d
iget-object v0, p0, Lleakcanary/ObjectWatcher;->watchedObjects:Ljava/util/Map;
invoke-interface {v0}, Ljava/util/Map;->clear()V
:try_end_22
.catchall {:try_start_1 .. :try_end_22} :catchall_24
.line 173
monitor-exit p0
return-void
:catchall_24
move-exception v0
monitor-exit p0
goto :goto_28
:goto_27
throw v0
:goto_28
goto :goto_27
.end method
.method public final declared-synchronized getHasRetainedObjects()Z
.registers 9
monitor-enter p0
.line 60
:try_start_1
invoke-direct {p0}, Lleakcanary/ObjectWatcher;->removeWeaklyReachableObjects()V
.line 61
iget-object v0, p0, Lleakcanary/ObjectWatcher;->watchedObjects:Ljava/util/Map;
.line 197
invoke-interface {v0}, Ljava/util/Map;->isEmpty()Z
move-result v1
const/4 v2, 0x0
if-nez v1, :cond_39
.line 198
invoke-interface {v0}, Ljava/util/Map;->entrySet()Ljava/util/Set;
move-result-object v0
invoke-interface {v0}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object v0
:cond_15
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v1
if-eqz v1, :cond_39
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v1
check-cast v1, Ljava/util/Map$Entry;
.line 61
invoke-interface {v1}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
move-result-object v1
check-cast v1, Lleakcanary/KeyedWeakReference;
invoke-virtual {v1}, Lleakcanary/KeyedWeakReference;->getRetainedUptimeMillis()J
move-result-wide v3
:try_end_2b
.catchall {:try_start_1 .. :try_end_2b} :catchall_3b
const-wide/16 v5, -0x1
const/4 v1, 0x1
cmp-long v7, v3, v5
if-eqz v7, :cond_34
const/4 v3, 0x1
goto :goto_35
:cond_34
const/4 v3, 0x0
:goto_35
if-eqz v3, :cond_15
monitor-exit p0
return v1
.line 199
:cond_39
monitor-exit p0
return v2
:catchall_3b
move-exception v0
monitor-exit p0
goto :goto_3f
:goto_3e
throw v0
:goto_3f
goto :goto_3e
.end method
.method public final declared-synchronized getHasWatchedObjects()Z
.registers 2
monitor-enter p0
.line 80
:try_start_1
invoke-direct {p0}, Lleakcanary/ObjectWatcher;->removeWeaklyReachableObjects()V
.line 81
iget-object v0, p0, Lleakcanary/ObjectWatcher;->watchedObjects:Ljava/util/Map;
invoke-interface {v0}, Ljava/util/Map;->isEmpty()Z
move-result v0
:try_end_a
.catchall {:try_start_1 .. :try_end_a} :catchall_11
if-nez v0, :cond_f
const/4 v0, 0x1
:goto_d
monitor-exit p0
return v0
:cond_f
const/4 v0, 0x0
goto :goto_d
:catchall_11
move-exception v0
monitor-exit p0
goto :goto_15
:goto_14
throw v0
:goto_15
goto :goto_14
.end method
.method public final declared-synchronized getRetainedObjectCount()I
.registers 9
monitor-enter p0
.line 70
:try_start_1
invoke-direct {p0}, Lleakcanary/ObjectWatcher;->removeWeaklyReachableObjects()V
.line 71
iget-object v0, p0, Lleakcanary/ObjectWatcher;->watchedObjects:Ljava/util/Map;
.line 200
invoke-interface {v0}, Ljava/util/Map;->isEmpty()Z
move-result v1
:try_end_a
.catchall {:try_start_1 .. :try_end_a} :catchall_3e
const/4 v2, 0x0
if-eqz v1, :cond_f
monitor-exit p0
return v2
.line 202
:cond_f
:try_start_f
invoke-interface {v0}, Ljava/util/Map;->entrySet()Ljava/util/Set;
move-result-object v0
invoke-interface {v0}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object v0
const/4 v1, 0x0
:cond_18
:goto_18
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v3
if-eqz v3, :cond_3c
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v3
check-cast v3, Ljava/util/Map$Entry;
.line 71
invoke-interface {v3}, Ljava/util/Map$Entry;->getValue()Ljava/lang/Object;
move-result-object v3
check-cast v3, Lleakcanary/KeyedWeakReference;
invoke-virtual {v3}, Lleakcanary/KeyedWeakReference;->getRetainedUptimeMillis()J
move-result-wide v3
:try_end_2e
.catchall {:try_start_f .. :try_end_2e} :catchall_3e
const-wide/16 v5, -0x1
cmp-long v7, v3, v5
if-eqz v7, :cond_36
const/4 v3, 0x1
goto :goto_37
:cond_36
const/4 v3, 0x0
:goto_37
if-eqz v3, :cond_18
add-int/lit8 v1, v1, 0x1
goto :goto_18
.line 203
:cond_3c
monitor-exit p0
return v1
:catchall_3e
move-exception v0
monitor-exit p0
goto :goto_42
:goto_41
throw v0
:goto_42
goto :goto_41
.end method
.method public final declared-synchronized getRetainedObjects()Ljava/util/List;
.registers 9
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/util/List<",
"Ljava/lang/Object;",
">;"
}
.end annotation
monitor-enter p0
.line 91
:try_start_1
invoke-direct {p0}, Lleakcanary/ObjectWatcher;->removeWeaklyReachableObjects()V
.line 92
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
check-cast v0, Ljava/util/List;
.line 93
iget-object v1, p0, Lleakcanary/ObjectWatcher;->watchedObjects:Ljava/util/Map;
invoke-interface {v1}, Ljava/util/Map;->values()Ljava/util/Collection;
move-result-object v1
invoke-interface {v1}, Ljava/util/Collection;->iterator()Ljava/util/Iterator;
move-result-object v1
:cond_15
:goto_15
invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z
move-result v2
if-eqz v2, :cond_35
invoke-interface {v1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v2
check-cast v2, Lleakcanary/KeyedWeakReference;
.line 94
invoke-virtual {v2}, Lleakcanary/KeyedWeakReference;->getRetainedUptimeMillis()J
move-result-wide v3
const-wide/16 v5, -0x1
cmp-long v7, v3, v5
if-eqz v7, :cond_15
.line 95
invoke-virtual {v2}, Lleakcanary/KeyedWeakReference;->get()Ljava/lang/Object;
move-result-object v2
if-eqz v2, :cond_15
.line 97
invoke-interface {v0, v2}, Ljava/util/List;->add(Ljava/lang/Object;)Z
:try_end_34
.catchall {:try_start_1 .. :try_end_34} :catchall_37
goto :goto_15
.line 101
:cond_35
monitor-exit p0
return-object v0
:catchall_37
move-exception v0
monitor-exit p0
goto :goto_3b
:goto_3a
throw v0
:goto_3b
goto :goto_3a
.end method
.method public final declared-synchronized removeOnObjectRetainedListener(Lleakcanary/OnObjectRetainedListener;)V
.registers 3
monitor-enter p0
:try_start_1
const-string v0, "listener"
invoke-static {p1, v0}, Lkotlin/f/b/o;->b(Ljava/lang/Object;Ljava/lang/String;)V
.line 109
iget-object v0, p0, Lleakcanary/ObjectWatcher;->onObjectRetainedListeners:Ljava/util/Set;
invoke-interface {v0, p1}, Ljava/util/Set;->remove(Ljava/lang/Object;)Z
:try_end_b
.catchall {:try_start_1 .. :try_end_b} :catchall_d
.line 110
monitor-exit p0
return-void
:catchall_d
move-exception p1
monitor-exit p0
throw p1
.end method
.method public final declared-synchronized watch(Ljava/lang/Object;)V
.registers 3
monitor-enter p0
:try_start_1
const-string v0, "watchedObject"
invoke-static {p1, v0}, Lkotlin/f/b/o;->b(Ljava/lang/Object;Ljava/lang/String;)V
const-string v0, ""
.line 122
invoke-virtual {p0, p1, v0}, Lleakcanary/ObjectWatcher;->watch(Ljava/lang/Object;Ljava/lang/String;)V
:try_end_b
.catchall {:try_start_1 .. :try_end_b} :catchall_d
.line 123
monitor-exit p0
return-void
:catchall_d
move-exception p1
monitor-exit p0
throw p1
.end method
.method public final declared-synchronized watch(Ljava/lang/Object;Ljava/lang/String;)V
.registers 12
monitor-enter p0
:try_start_1
const-string v0, "watchedObject"
invoke-static {p1, v0}, Lkotlin/f/b/o;->b(Ljava/lang/Object;Ljava/lang/String;)V
const-string v0, "description"
invoke-static {p2, v0}, Lkotlin/f/b/o;->b(Ljava/lang/Object;Ljava/lang/String;)V
.line 134
iget-object v0, p0, Lleakcanary/ObjectWatcher;->isEnabled:Lkotlin/f/a/a;
invoke-interface {v0}, Lkotlin/f/a/a;->invoke()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/lang/Boolean;
invoke-virtual {v0}, Ljava/lang/Boolean;->booleanValue()Z
move-result v0
:try_end_17
.catchall {:try_start_1 .. :try_end_17} :catchall_af
if-nez v0, :cond_1b
.line 135
monitor-exit p0
return-void
.line 137
:cond_1b
:try_start_1b
invoke-direct {p0}, Lleakcanary/ObjectWatcher;->removeWeaklyReachableObjects()V
.line 138
invoke-static {}, Ljava/util/UUID;->randomUUID()Ljava/util/UUID;
move-result-object v0
.line 139
invoke-virtual {v0}, Ljava/util/UUID;->toString()Ljava/lang/String;
move-result-object v0
const-string v1, "UUID.randomUUID()\n .toString()"
invoke-static {v0, v1}, Lkotlin/f/b/o;->a(Ljava/lang/Object;Ljava/lang/String;)V
.line 140
iget-object v1, p0, Lleakcanary/ObjectWatcher;->clock:Lleakcanary/Clock;
invoke-interface {v1}, Lleakcanary/Clock;->uptimeMillis()J
move-result-wide v5
.line 142
new-instance v8, Lleakcanary/KeyedWeakReference;
iget-object v7, p0, Lleakcanary/ObjectWatcher;->queue:Ljava/lang/ref/ReferenceQueue;
move-object v1, v8
move-object v2, p1
move-object v3, v0
move-object v4, p2
invoke-direct/range {v1 .. v7}, Lleakcanary/KeyedWeakReference;-><init>(Ljava/lang/Object;Ljava/lang/String;Ljava/lang/String;JLjava/lang/ref/ReferenceQueue;)V
.line 143
sget-object v1, Lshark/t;->a:Lshark/t;
.line 204
invoke-static {}, Lshark/t;->a()Lshark/t$a;
move-result-object v1
if-eqz v1, :cond_9c
.line 144
new-instance v1, Ljava/lang/StringBuilder;
const-string v2, "Watching "
invoke-direct {v1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
.line 145
instance-of v2, p1, Ljava/lang/Class;
if-eqz v2, :cond_54
invoke-virtual {p1}, Ljava/lang/Object;->toString()Ljava/lang/String;
move-result-object p1
goto :goto_6a
:cond_54
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "instance of "
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {p1}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
move-result-object p1
invoke-virtual {p1}, Ljava/lang/Class;->getName()Ljava/lang/String;
move-result-object p1
invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
:goto_6a
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 146
move-object p1, p2
check-cast p1, Ljava/lang/CharSequence;
invoke-interface {p1}, Ljava/lang/CharSequence;->length()I
move-result p1
if-lez p1, :cond_78
const/4 p1, 0x1
goto :goto_79
:cond_78
const/4 p1, 0x0
:goto_79
if-eqz p1, :cond_8f
new-instance p1, Ljava/lang/StringBuilder;
const-string v2, " ("
invoke-direct {p1, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {p1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const/16 p2, 0x29
invoke-virtual {p1, p2}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
invoke-virtual {p1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
goto :goto_91
:cond_8f
const-string p1, ""
:goto_91
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p1, " with key "
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 147
invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 150
:cond_9c
iget-object p1, p0, Lleakcanary/ObjectWatcher;->watchedObjects:Ljava/util/Map;
invoke-interface {p1, v0, v8}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 151
iget-object p1, p0, Lleakcanary/ObjectWatcher;->checkRetainedExecutor:Ljava/util/concurrent/Executor;
new-instance p2, Lleakcanary/ObjectWatcher$watch$2;
invoke-direct {p2, p0, v0}, Lleakcanary/ObjectWatcher$watch$2;-><init>(Lleakcanary/ObjectWatcher;Ljava/lang/String;)V
check-cast p2, Ljava/lang/Runnable;
invoke-interface {p1, p2}, Ljava/util/concurrent/Executor;->execute(Ljava/lang/Runnable;)V
:try_end_ad
.catchall {:try_start_1b .. :try_end_ad} :catchall_af
.line 154
monitor-exit p0
return-void
:catchall_af
move-exception p1
monitor-exit p0
throw p1
.end method