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