g.smali

.class public final Lcom/orhanobut/logger/g;
.super Ljava/lang/Object;
.source "SourceFile"

# interfaces
.implements Lcom/orhanobut/logger/i;


# instance fields
.field public final a:Ljava/lang/ThreadLocal;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/lang/ThreadLocal<",
            "Ljava/lang/String;",
            ">;"
        }
    .end annotation
.end field

.field public final b:Ljava/util/ArrayList;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/List<",
            "Lcom/orhanobut/logger/d;",
            ">;"
        }
    .end annotation
.end field


# direct methods
.method public constructor <init>()V
    .registers 2

    .line 1
    invoke-direct {p0}, Ljava/lang/Object;-><init>()V

    .line 2
    new-instance v0, Ljava/lang/ThreadLocal;

    invoke-direct {v0}, Ljava/lang/ThreadLocal;-><init>()V

    iput-object v0, p0, Lcom/orhanobut/logger/g;->a:Ljava/lang/ThreadLocal;

    .line 3
    new-instance v0, Ljava/util/ArrayList;

    invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V

    iput-object v0, p0, Lcom/orhanobut/logger/g;->b:Ljava/util/ArrayList;

    return-void
.end method


# virtual methods
.method public final varargs a(Ljava/lang/String;[Ljava/lang/Object;)V
    .registers 5

    const/4 v0, 0x4

    const/4 v1, 0x0

    invoke-virtual {p0, v0, v1, p1, p2}, Lcom/orhanobut/logger/g;->g(ILjava/lang/Throwable;Ljava/lang/String;[Ljava/lang/Object;)V

    return-void
.end method

.method public final b(Ljava/lang/Object;)V
    .registers 5

    if-nez p1, :cond_6

    const-string p1, "null"

    goto/16 :goto_7b

    .line 1
    :cond_6
    invoke-virtual {p1}, Ljava/lang/Object;->getClass()Ljava/lang/Class;

    move-result-object v0

    invoke-virtual {v0}, Ljava/lang/Class;->isArray()Z

    move-result v0

    if-nez v0, :cond_16

    .line 2
    invoke-virtual {p1}, Ljava/lang/Object;->toString()Ljava/lang/String;

    move-result-object p1

    goto/16 :goto_7b

    .line 3
    :cond_16
    instance-of v0, p1, [Z

    if-eqz v0, :cond_21

    .line 4
    check-cast p1, [Z

    invoke-static {p1}, Ljava/util/Arrays;->toString([Z)Ljava/lang/String;

    move-result-object p1

    goto :goto_7b

    .line 5
    :cond_21
    instance-of v0, p1, [B

    if-eqz v0, :cond_2c

    .line 6
    check-cast p1, [B

    invoke-static {p1}, Ljava/util/Arrays;->toString([B)Ljava/lang/String;

    move-result-object p1

    goto :goto_7b

    .line 7
    :cond_2c
    instance-of v0, p1, [C

    if-eqz v0, :cond_37

    .line 8
    check-cast p1, [C

    invoke-static {p1}, Ljava/util/Arrays;->toString([C)Ljava/lang/String;

    move-result-object p1

    goto :goto_7b

    .line 9
    :cond_37
    instance-of v0, p1, [S

    if-eqz v0, :cond_42

    .line 10
    check-cast p1, [S

    invoke-static {p1}, Ljava/util/Arrays;->toString([S)Ljava/lang/String;

    move-result-object p1

    goto :goto_7b

    .line 11
    :cond_42
    instance-of v0, p1, [I

    if-eqz v0, :cond_4d

    .line 12
    check-cast p1, [I

    invoke-static {p1}, Ljava/util/Arrays;->toString([I)Ljava/lang/String;

    move-result-object p1

    goto :goto_7b

    .line 13
    :cond_4d
    instance-of v0, p1, [J

    if-eqz v0, :cond_58

    .line 14
    check-cast p1, [J

    invoke-static {p1}, Ljava/util/Arrays;->toString([J)Ljava/lang/String;

    move-result-object p1

    goto :goto_7b

    .line 15
    :cond_58
    instance-of v0, p1, [F

    if-eqz v0, :cond_63

    .line 16
    check-cast p1, [F

    invoke-static {p1}, Ljava/util/Arrays;->toString([F)Ljava/lang/String;

    move-result-object p1

    goto :goto_7b

    .line 17
    :cond_63
    instance-of v0, p1, [D

    if-eqz v0, :cond_6e

    .line 18
    check-cast p1, [D

    invoke-static {p1}, Ljava/util/Arrays;->toString([D)Ljava/lang/String;

    move-result-object p1

    goto :goto_7b

    .line 19
    :cond_6e
    instance-of v0, p1, [Ljava/lang/Object;

    if-eqz v0, :cond_79

    .line 20
    check-cast p1, [Ljava/lang/Object;

    invoke-static {p1}, Ljava/util/Arrays;->deepToString([Ljava/lang/Object;)Ljava/lang/String;

    move-result-object p1

    goto :goto_7b

    :cond_79
    const-string p1, "Couldn\'t find a correct type for the object"

    :goto_7b
    const/4 v0, 0x0

    new-array v0, v0, [Ljava/lang/Object;

    const/4 v1, 0x3

    const/4 v2, 0x0

    .line 21
    invoke-virtual {p0, v1, v2, p1, v0}, Lcom/orhanobut/logger/g;->g(ILjava/lang/Throwable;Ljava/lang/String;[Ljava/lang/Object;)V

    return-void
.end method

.method public final varargs c(Ljava/lang/String;[Ljava/lang/Object;)V
    .registers 5

    const/4 v0, 0x5

    const/4 v1, 0x0

    invoke-virtual {p0, v0, v1, p1, p2}, Lcom/orhanobut/logger/g;->g(ILjava/lang/Throwable;Ljava/lang/String;[Ljava/lang/Object;)V

    return-void
.end method

.method public final d(Ljava/lang/String;)V
    .registers 6

    const-string v0, "Invalid Json"

    .line 2
    invoke-static {p1}, Lcom/google/android/play/core/splitinstall/k0;->g(Ljava/lang/CharSequence;)Z

    move-result v1

    if-eqz v1, :cond_e

    const-string p1, "Empty/Null json content"

    .line 3
    invoke-virtual {p0, p1}, Lcom/orhanobut/logger/g;->b(Ljava/lang/Object;)V

    return-void

    :cond_e
    const/4 v1, 0x0

    .line 4
    :try_start_f
    invoke-virtual {p1}, Ljava/lang/String;->trim()Ljava/lang/String;

    move-result-object p1

    const-string v2, "{"

    .line 5
    invoke-virtual {p1, v2}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z

    move-result v2

    const/4 v3, 0x2

    if-eqz v2, :cond_29

    .line 6
    new-instance v2, Lorg/json/JSONObject;

    invoke-direct {v2, p1}, Lorg/json/JSONObject;-><init>(Ljava/lang/String;)V

    .line 7
    invoke-virtual {v2, v3}, Lorg/json/JSONObject;->toString(I)Ljava/lang/String;

    move-result-object p1

    .line 8
    invoke-virtual {p0, p1}, Lcom/orhanobut/logger/g;->b(Ljava/lang/Object;)V

    return-void

    :cond_29
    const-string v2, "["

    .line 9
    invoke-virtual {p1, v2}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z

    move-result v2

    if-eqz v2, :cond_3e

    .line 10
    new-instance v2, Lorg/json/JSONArray;

    invoke-direct {v2, p1}, Lorg/json/JSONArray;-><init>(Ljava/lang/String;)V

    .line 11
    invoke-virtual {v2, v3}, Lorg/json/JSONArray;->toString(I)Ljava/lang/String;

    move-result-object p1

    .line 12
    invoke-virtual {p0, p1}, Lcom/orhanobut/logger/g;->b(Ljava/lang/Object;)V

    return-void

    :cond_3e
    new-array p1, v1, [Ljava/lang/Object;

    .line 13
    invoke-virtual {p0, v0, p1}, Lcom/orhanobut/logger/g;->e(Ljava/lang/String;[Ljava/lang/Object;)V
    :try_end_43
    .catch Lorg/json/JSONException; {:try_start_f .. :try_end_43} :catch_44

    goto :goto_49

    :catch_44
    new-array p1, v1, [Ljava/lang/Object;

    .line 14
    invoke-virtual {p0, v0, p1}, Lcom/orhanobut/logger/g;->e(Ljava/lang/String;[Ljava/lang/Object;)V

    :goto_49
    return-void
.end method

.method public final varargs d(Ljava/lang/String;[Ljava/lang/Object;)V
    .registers 5

    const/4 v0, 0x3

    const/4 v1, 0x0

    .line 1
    invoke-virtual {p0, v0, v1, p1, p2}, Lcom/orhanobut/logger/g;->g(ILjava/lang/Throwable;Ljava/lang/String;[Ljava/lang/Object;)V

    return-void
.end method

.method public final varargs e(Ljava/lang/String;[Ljava/lang/Object;)V
    .registers 5

    const/4 v0, 0x6

    const/4 v1, 0x0

    invoke-virtual {p0, v0, v1, p1, p2}, Lcom/orhanobut/logger/g;->g(ILjava/lang/Throwable;Ljava/lang/String;[Ljava/lang/Object;)V

    return-void
.end method

.method public final declared-synchronized f(ILjava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
    .registers 8

    monitor-enter p0

    if-eqz p4, :cond_1d

    if-eqz p3, :cond_1d

    .line 1
    :try_start_5
    new-instance v0, Ljava/lang/StringBuilder;

    invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V

    invoke-virtual {v0, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    const-string p3, " : "

    invoke-virtual {v0, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-static {p4}, Lcom/google/android/play/core/splitinstall/k0;->e(Ljava/lang/Throwable;)Ljava/lang/String;

    move-result-object p3

    invoke-virtual {v0, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object p3

    :cond_1d
    if-eqz p4, :cond_25

    if-nez p3, :cond_25

    .line 2
    invoke-static {p4}, Lcom/google/android/play/core/splitinstall/k0;->e(Ljava/lang/Throwable;)Ljava/lang/String;

    move-result-object p3

    .line 3
    :cond_25
    invoke-static {p3}, Lcom/google/android/play/core/splitinstall/k0;->g(Ljava/lang/CharSequence;)Z

    move-result p4

    if-eqz p4, :cond_2d

    const-string p3, "Empty/NULL log message"

    .line 4
    :cond_2d
    iget-object p4, p0, Lcom/orhanobut/logger/g;->b:Ljava/util/ArrayList;

    invoke-virtual {p4}, Ljava/util/ArrayList;->iterator()Ljava/util/Iterator;

    move-result-object p4

    :cond_33
    :goto_33
    invoke-interface {p4}, Ljava/util/Iterator;->hasNext()Z

    move-result v0

    if-eqz v0, :cond_50

    invoke-interface {p4}, Ljava/util/Iterator;->next()Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Lcom/orhanobut/logger/d;

    .line 5
    invoke-interface {v0, p1}, Lcom/orhanobut/logger/d;->isLoggable(I)Z

    move-result v1

    if-eqz v1, :cond_33

    and-int/lit8 v1, p1, 0x7

    const/4 v2, 0x2

    .line 6
    invoke-static {v1, v2}, Ljava/lang/Math;->max(II)I

    move-result v1

    .line 7
    invoke-interface {v0, v1, p2, p3}, Lcom/orhanobut/logger/d;->log(ILjava/lang/String;Ljava/lang/String;)V
    :try_end_4f
    .catchall {:try_start_5 .. :try_end_4f} :catchall_52

    goto :goto_33

    .line 8
    :cond_50
    monitor-exit p0

    return-void

    :catchall_52
    move-exception p1

    monitor-exit p0

    throw p1
.end method

.method public final varargs declared-synchronized g(ILjava/lang/Throwable;Ljava/lang/String;[Ljava/lang/Object;)V
    .registers 7

    monitor-enter p0

    .line 1
    :try_start_1
    invoke-static {p3}, Ljava/util/Objects;->requireNonNull(Ljava/lang/Object;)Ljava/lang/Object;

    .line 2
    iget-object v0, p0, Lcom/orhanobut/logger/g;->a:Ljava/lang/ThreadLocal;

    invoke-virtual {v0}, Ljava/lang/ThreadLocal;->get()Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Ljava/lang/String;

    if-eqz v0, :cond_14

    .line 3
    iget-object v1, p0, Lcom/orhanobut/logger/g;->a:Ljava/lang/ThreadLocal;

    invoke-virtual {v1}, Ljava/lang/ThreadLocal;->remove()V

    goto :goto_15

    :cond_14
    const/4 v0, 0x0

    :goto_15
    if-eqz p4, :cond_1f

    .line 4
    array-length v1, p4

    if-nez v1, :cond_1b

    goto :goto_1f

    :cond_1b
    invoke-static {p3, p4}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;

    move-result-object p3

    .line 5
    :cond_1f
    :goto_1f
    invoke-virtual {p0, p1, v0, p3, p2}, Lcom/orhanobut/logger/g;->f(ILjava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
    :try_end_22
    .catchall {:try_start_1 .. :try_end_22} :catchall_24

    .line 6
    monitor-exit p0

    return-void

    :catchall_24
    move-exception p1

    monitor-exit p0

    throw p1
.end method