BriefLogFormatter.smali

.class public Lorg/bitcoinj/utils/BriefLogFormatter;
.super Ljava/util/logging/Formatter;
.source "BriefLogFormatter.java"


# static fields
.field private static logger:Ljava/util/logging/Logger;

.field private static final messageFormat:Ljava/text/MessageFormat;


# direct methods
.method static constructor <clinit>()V
    .registers 2

    .prologue
    .line 30
    new-instance v0, Ljava/text/MessageFormat;

    const-string v1, "{3,date,HH:mm:ss} {0} {1}.{2}: {4}\n{5}"

    invoke-direct {v0, v1}, Ljava/text/MessageFormat;-><init>(Ljava/lang/String;)V

    sput-object v0, Lorg/bitcoinj/utils/BriefLogFormatter;->messageFormat:Ljava/text/MessageFormat;

    return-void
.end method

.method public constructor <init>()V
    .registers 1

    .prologue
    .line 29
    invoke-direct {p0}, Ljava/util/logging/Formatter;-><init>()V

    return-void
.end method

.method public static init()V
    .registers 2

    .prologue
    .line 39
    const-string v0, ""

    invoke-static {v0}, Ljava/util/logging/Logger;->getLogger(Ljava/lang/String;)Ljava/util/logging/Logger;

    move-result-object v0

    .line 40
    sput-object v0, Lorg/bitcoinj/utils/BriefLogFormatter;->logger:Ljava/util/logging/Logger;

    invoke-virtual {v0}, Ljava/util/logging/Logger;->getHandlers()[Ljava/util/logging/Handler;

    move-result-object v0

    .line 42
    array-length v1, v0

    if-lez v1, :cond_1a

    .line 43
    const/4 v1, 0x0

    aget-object v0, v0, v1

    new-instance v1, Lorg/bitcoinj/utils/BriefLogFormatter;

    invoke-direct {v1}, Lorg/bitcoinj/utils/BriefLogFormatter;-><init>()V

    invoke-virtual {v0, v1}, Ljava/util/logging/Handler;->setFormatter(Ljava/util/logging/Formatter;)V

    .line 44
    :cond_1a
    return-void
.end method

.method public static initVerbose()V
    .registers 3

    .prologue
    .line 47
    invoke-static {}, Lorg/bitcoinj/utils/BriefLogFormatter;->init()V

    .line 48
    sget-object v0, Lorg/bitcoinj/utils/BriefLogFormatter;->logger:Ljava/util/logging/Logger;

    sget-object v1, Ljava/util/logging/Level;->ALL:Ljava/util/logging/Level;

    invoke-virtual {v0, v1}, Ljava/util/logging/Logger;->setLevel(Ljava/util/logging/Level;)V

    .line 49
    sget-object v0, Lorg/bitcoinj/utils/BriefLogFormatter;->logger:Ljava/util/logging/Logger;

    sget-object v1, Ljava/util/logging/Level;->FINE:Ljava/util/logging/Level;

    const-string v2, "test"

    invoke-virtual {v0, v1, v2}, Ljava/util/logging/Logger;->log(Ljava/util/logging/Level;Ljava/lang/String;)V

    .line 50
    return-void
.end method

.method public static initWithSilentBitcoinJ()V
    .registers 2

    .prologue
    .line 53
    invoke-static {}, Lorg/bitcoinj/utils/BriefLogFormatter;->init()V

    .line 54
    const-string v0, "org.bitcoinj"

    invoke-static {v0}, Ljava/util/logging/Logger;->getLogger(Ljava/lang/String;)Ljava/util/logging/Logger;

    move-result-object v0

    sget-object v1, Ljava/util/logging/Level;->SEVERE:Ljava/util/logging/Level;

    invoke-virtual {v0, v1}, Ljava/util/logging/Logger;->setLevel(Ljava/util/logging/Level;)V

    .line 55
    return-void
.end method


# virtual methods
.method public format(Ljava/util/logging/LogRecord;)Ljava/lang/String;
    .registers 9

    .prologue
    const/4 v6, 0x5

    .line 59
    const/4 v0, 0x6

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

    .line 60
    const/4 v1, 0x0

    invoke-virtual {p1}, Ljava/util/logging/LogRecord;->getThreadID()I

    move-result v2

    invoke-static {v2}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;

    move-result-object v2

    aput-object v2, v0, v1

    .line 61
    invoke-virtual {p1}, Ljava/util/logging/LogRecord;->getSourceClassName()Ljava/lang/String;

    move-result-object v1

    .line 62
    const/16 v2, 0x2e

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

    move-result v2

    .line 63
    add-int/lit8 v2, v2, 0x1

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

    move-result-object v1

    .line 64
    const/4 v2, 0x1

    aput-object v1, v0, v2

    .line 65
    const/4 v1, 0x2

    invoke-virtual {p1}, Ljava/util/logging/LogRecord;->getSourceMethodName()Ljava/lang/String;

    move-result-object v2

    aput-object v2, v0, v1

    .line 66
    const/4 v1, 0x3

    new-instance v2, Ljava/util/Date;

    invoke-virtual {p1}, Ljava/util/logging/LogRecord;->getMillis()J

    move-result-wide v4

    invoke-direct {v2, v4, v5}, Ljava/util/Date;-><init>(J)V

    aput-object v2, v0, v1

    .line 67
    const/4 v1, 0x4

    invoke-virtual {p1}, Ljava/util/logging/LogRecord;->getMessage()Ljava/lang/String;

    move-result-object v2

    aput-object v2, v0, v1

    .line 68
    invoke-virtual {p1}, Ljava/util/logging/LogRecord;->getThrown()Ljava/lang/Throwable;

    move-result-object v1

    if-eqz v1, :cond_60

    .line 69
    new-instance v1, Ljava/io/StringWriter;

    invoke-direct {v1}, Ljava/io/StringWriter;-><init>()V

    .line 70
    invoke-virtual {p1}, Ljava/util/logging/LogRecord;->getThrown()Ljava/lang/Throwable;

    move-result-object v2

    new-instance v3, Ljava/io/PrintWriter;

    invoke-direct {v3, v1}, Ljava/io/PrintWriter;-><init>(Ljava/io/Writer;)V

    invoke-virtual {v2, v3}, Ljava/lang/Throwable;->printStackTrace(Ljava/io/PrintWriter;)V

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

    move-result-object v1

    aput-object v1, v0, v6

    .line 75
    :goto_59
    sget-object v1, Lorg/bitcoinj/utils/BriefLogFormatter;->messageFormat:Ljava/text/MessageFormat;

    invoke-virtual {v1, v0}, Ljava/text/MessageFormat;->format(Ljava/lang/Object;)Ljava/lang/String;

    move-result-object v0

    return-object v0

    .line 73
    :cond_60
    const-string v1, ""

    aput-object v1, v0, v6

    goto :goto_59
.end method