LogcatLogger.smali

.class public Lcom/avast/android/logging/LogcatLogger;
.super Ljava/lang/Object;

# interfaces
.implements Lcom/avast/android/logging/AlfLogger;


# instance fields
.field private a:I

.field private b:Z

.field private c:Landroid/util/LruCache;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Landroid/util/LruCache<",
            "Ljava/lang/String;",
            "Ljava/lang/String;",
            ">;"
        }
    .end annotation
.end field


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

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

    const/4 v0, 0x5

    iput v0, p0, Lcom/avast/android/logging/LogcatLogger;->a:I

    const/4 v0, 0x1

    iput-boolean v0, p0, Lcom/avast/android/logging/LogcatLogger;->b:Z

    new-instance v0, Landroid/util/LruCache;

    const/16 v1, 0x400

    invoke-direct {v0, v1}, Landroid/util/LruCache;-><init>(I)V

    iput-object v0, p0, Lcom/avast/android/logging/LogcatLogger;->c:Landroid/util/LruCache;

    return-void
.end method

.method public constructor <init>(I)V
    .registers 2

    invoke-direct {p0}, Lcom/avast/android/logging/LogcatLogger;-><init>()V

    iput p1, p0, Lcom/avast/android/logging/LogcatLogger;->a:I

    return-void
.end method

.method private m(ILjava/lang/String;Ljava/lang/String;)V
    .registers 8

    invoke-virtual {p3}, Ljava/lang/String;->length()I

    move-result v0

    const/4 v1, 0x0

    :goto_5
    if-ge v1, v0, :cond_26

    const/16 v2, 0xa

    invoke-virtual {p3, v2, v1}, Ljava/lang/String;->indexOf(II)I

    move-result v2

    const/4 v3, -0x1

    if-eq v2, v3, :cond_11

    goto :goto_12

    :cond_11
    move v2, v0

    :goto_12
    add-int/lit16 v3, v1, 0xfa0

    invoke-static {v2, v3}, Ljava/lang/Math;->min(II)I

    move-result v3

    invoke-virtual {p3, v1, v3}, Ljava/lang/String;->substring(II)Ljava/lang/String;

    move-result-object v1

    invoke-static {p1, p2, v1}, Landroid/util/Log;->println(ILjava/lang/String;Ljava/lang/String;)I

    if-lt v3, v2, :cond_24

    add-int/lit8 v1, v3, 0x1

    goto :goto_5

    :cond_24
    move v1, v3

    goto :goto_12

    :cond_26
    return-void
.end method

.method private n(ILjava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
    .registers 6

    iget v0, p0, Lcom/avast/android/logging/LogcatLogger;->a:I

    if-ge p1, v0, :cond_5

    return-void

    :cond_5
    if-eqz p3, :cond_29

    invoke-virtual {p3}, Ljava/lang/String;->length()I

    move-result v0

    if-nez v0, :cond_e

    goto :goto_29

    :cond_e
    if-eqz p4, :cond_2f

    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, "\n"

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

    invoke-static {p4}, Landroid/util/Log;->getStackTraceString(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

    goto :goto_2f

    :cond_29
    :goto_29
    if-eqz p4, :cond_42

    invoke-static {p4}, Landroid/util/Log;->getStackTraceString(Ljava/lang/Throwable;)Ljava/lang/String;

    move-result-object p3

    :cond_2f
    :goto_2f
    invoke-direct {p0, p2}, Lcom/avast/android/logging/LogcatLogger;->o(Ljava/lang/String;)Ljava/lang/String;

    move-result-object p2

    invoke-virtual {p3}, Ljava/lang/String;->length()I

    move-result p4

    const/16 v0, 0xfa0

    if-ge p4, v0, :cond_3f

    invoke-static {p1, p2, p3}, Landroid/util/Log;->println(ILjava/lang/String;Ljava/lang/String;)I

    return-void

    :cond_3f
    invoke-direct {p0, p1, p2, p3}, Lcom/avast/android/logging/LogcatLogger;->m(ILjava/lang/String;Ljava/lang/String;)V

    :cond_42
    return-void
.end method

.method private o(Ljava/lang/String;)Ljava/lang/String;
    .registers 4

    iget-boolean v0, p0, Lcom/avast/android/logging/LogcatLogger;->b:Z

    if-eqz v0, :cond_1e

    iget-object v0, p0, Lcom/avast/android/logging/LogcatLogger;->c:Landroid/util/LruCache;

    invoke-virtual {v0, p1}, Landroid/util/LruCache;->get(Ljava/lang/Object;)Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Ljava/lang/String;

    invoke-static {v0}, Lcom/avast/android/logging/LoggingUtils;->e(Ljava/lang/CharSequence;)Z

    move-result v1

    if-eqz v1, :cond_1d

    const/16 v0, 0x17

    invoke-static {p1, v0}, Lcom/avast/android/logging/LoggingUtils;->f(Ljava/lang/String;I)Ljava/lang/String;

    move-result-object v0

    iget-object v1, p0, Lcom/avast/android/logging/LogcatLogger;->c:Landroid/util/LruCache;

    invoke-virtual {v1, p1, v0}, Landroid/util/LruCache;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    :cond_1d
    return-object v0

    :cond_1e
    return-object p1
.end method


# virtual methods
.method public a(Ljava/lang/String;Ljava/lang/Throwable;Ljava/lang/String;)V
    .registers 5

    const/4 v0, 0x2

    invoke-direct {p0, v0, p1, p3, p2}, Lcom/avast/android/logging/LogcatLogger;->n(ILjava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V

    return-void
.end method

.method public b(Ljava/lang/String;Ljava/lang/Throwable;Ljava/lang/String;)V
    .registers 5

    const/4 v0, 0x6

    invoke-direct {p0, v0, p1, p3, p2}, Lcom/avast/android/logging/LogcatLogger;->n(ILjava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V

    return-void
.end method

.method public c(Ljava/lang/String;Ljava/lang/Throwable;Ljava/lang/String;)V
    .registers 5

    const/4 v0, 0x5

    invoke-direct {p0, v0, p1, p3, p2}, Lcom/avast/android/logging/LogcatLogger;->n(ILjava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V

    return-void
.end method

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

    const/4 v0, 0x5

    const/4 v1, 0x0

    invoke-direct {p0, v0, p1, p2, v1}, Lcom/avast/android/logging/LogcatLogger;->n(ILjava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V

    return-void
.end method

.method public e(Ljava/lang/String;Ljava/lang/String;)V
    .registers 5

    const/4 v0, 0x6

    const/4 v1, 0x0

    invoke-direct {p0, v0, p1, p2, v1}, Lcom/avast/android/logging/LogcatLogger;->n(ILjava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V

    return-void
.end method

.method public f(Ljava/lang/String;Ljava/lang/String;)V
    .registers 5

    const/4 v0, 0x2

    const/4 v1, 0x0

    invoke-direct {p0, v0, p1, p2, v1}, Lcom/avast/android/logging/LogcatLogger;->n(ILjava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V

    return-void
.end method

.method public g(Ljava/lang/String;Ljava/lang/String;)V
    .registers 5

    const/4 v0, 0x7

    const/4 v1, 0x0

    invoke-direct {p0, v0, p1, p2, v1}, Lcom/avast/android/logging/LogcatLogger;->n(ILjava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V

    return-void
.end method

.method public h(Ljava/lang/String;Ljava/lang/String;)V
    .registers 5

    const/4 v0, 0x3

    const/4 v1, 0x0

    invoke-direct {p0, v0, p1, p2, v1}, Lcom/avast/android/logging/LogcatLogger;->n(ILjava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V

    return-void
.end method

.method public i(Ljava/lang/String;Ljava/lang/Throwable;Ljava/lang/String;)V
    .registers 5

    const/4 v0, 0x4

    invoke-direct {p0, v0, p1, p3, p2}, Lcom/avast/android/logging/LogcatLogger;->n(ILjava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V

    return-void
.end method

.method public j(Ljava/lang/String;Ljava/lang/String;)V
    .registers 5

    const/4 v0, 0x4

    const/4 v1, 0x0

    invoke-direct {p0, v0, p1, p2, v1}, Lcom/avast/android/logging/LogcatLogger;->n(ILjava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V

    return-void
.end method

.method public k(Ljava/lang/String;Ljava/lang/Throwable;Ljava/lang/String;)V
    .registers 5

    const/4 v0, 0x7

    invoke-direct {p0, v0, p1, p3, p2}, Lcom/avast/android/logging/LogcatLogger;->n(ILjava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V

    return-void
.end method

.method public l(Ljava/lang/String;Ljava/lang/Throwable;Ljava/lang/String;)V
    .registers 5

    const/4 v0, 0x3

    invoke-direct {p0, v0, p1, p3, p2}, Lcom/avast/android/logging/LogcatLogger;->n(ILjava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V

    return-void
.end method