LogUtils.smali
.class public final Lcom/blankj/utilcode/util/LogUtils;
.super Ljava/lang/Object;
.source "LogUtils.java"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/blankj/utilcode/util/LogUtils$LogFormatter;,
Lcom/blankj/utilcode/util/LogUtils$TagHead;,
Lcom/blankj/utilcode/util/LogUtils$IFileWriter;,
Lcom/blankj/utilcode/util/LogUtils$IFormatter;,
Lcom/blankj/utilcode/util/LogUtils$Config;,
Lcom/blankj/utilcode/util/LogUtils$TYPE;
}
.end annotation
# static fields
.field public static final A:I = 0x7
.field private static final ARGS:Ljava/lang/String; = "args"
.field private static final BOTTOM_BORDER:Ljava/lang/String; = "\u2514\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500"
.field private static final BOTTOM_CORNER:Ljava/lang/String; = "\u2514"
.field private static final CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
.field public static final D:I = 0x3
.field public static final E:I = 0x6
.field private static final EXECUTOR:Ljava/util/concurrent/ExecutorService;
.field private static final FILE:I = 0x10
.field private static final FILE_SEP:Ljava/lang/String;
.field public static final I:I = 0x4
.field private static final I_FORMATTER_MAP:Landroidx/collection/SimpleArrayMap;
.annotation system Ldalvik/annotation/Signature;
value = {
"Landroidx/collection/SimpleArrayMap<",
"Ljava/lang/Class;",
"Lcom/blankj/utilcode/util/LogUtils$IFormatter;",
">;"
}
.end annotation
.end field
.field private static final JSON:I = 0x20
.field private static final LEFT_BORDER:Ljava/lang/String; = "\u2502 "
.field private static final LINE_SEP:Ljava/lang/String;
.field private static final MAX_LEN:I = 0x44c
.field private static final MIDDLE_BORDER:Ljava/lang/String; = "\u251c\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504"
.field private static final MIDDLE_CORNER:Ljava/lang/String; = "\u251c"
.field private static final MIDDLE_DIVIDER:Ljava/lang/String; = "\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504"
.field private static final NOTHING:Ljava/lang/String; = "log nothing"
.field private static final NULL:Ljava/lang/String; = "null"
.field private static final PLACEHOLDER:Ljava/lang/String; = " "
.field private static final SIDE_DIVIDER:Ljava/lang/String; = "\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500"
.field private static final T:[C
.field private static final TOP_BORDER:Ljava/lang/String; = "\u250c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500"
.field private static final TOP_CORNER:Ljava/lang/String; = "\u250c"
.field public static final V:I = 0x2
.field public static final W:I = 0x5
.field private static final XML:I = 0x30
.field private static simpleDateFormat:Ljava/text/SimpleDateFormat;
# direct methods
.method static constructor <clinit>()V
.registers 2
.line 83
const/4 v0, 0x6
new-array v0, v0, [C
fill-array-data v0, :array_2e
sput-object v0, Lcom/blankj/utilcode/util/LogUtils;->T:[C
.line 89
const-string v0, "file.separator"
invoke-static {v0}, Ljava/lang/System;->getProperty(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
sput-object v0, Lcom/blankj/utilcode/util/LogUtils;->FILE_SEP:Ljava/lang/String;
.line 90
const-string v0, "line.separator"
invoke-static {v0}, Ljava/lang/System;->getProperty(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
sput-object v0, Lcom/blankj/utilcode/util/LogUtils;->LINE_SEP:Ljava/lang/String;
.line 107
new-instance v0, Lcom/blankj/utilcode/util/LogUtils$Config;
const/4 v1, 0x0
invoke-direct {v0, v1}, Lcom/blankj/utilcode/util/LogUtils$Config;-><init>(Lcom/blankj/utilcode/util/LogUtils$1;)V
sput-object v0, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
.line 111
invoke-static {}, Ljava/util/concurrent/Executors;->newSingleThreadExecutor()Ljava/util/concurrent/ExecutorService;
move-result-object v0
sput-object v0, Lcom/blankj/utilcode/util/LogUtils;->EXECUTOR:Ljava/util/concurrent/ExecutorService;
.line 113
new-instance v0, Landroidx/collection/SimpleArrayMap;
invoke-direct {v0}, Landroidx/collection/SimpleArrayMap;-><init>()V
sput-object v0, Lcom/blankj/utilcode/util/LogUtils;->I_FORMATTER_MAP:Landroidx/collection/SimpleArrayMap;
return-void
:array_2e
.array-data 2
0x56s
0x44s
0x49s
0x57s
0x45s
0x41s
.end array-data
.end method
.method private constructor <init>()V
.registers 3
.line 115
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 116
new-instance v0, Ljava/lang/UnsupportedOperationException;
const-string/jumbo v1, "u can\'t instantiate me..."
invoke-direct {v0, v1}, Ljava/lang/UnsupportedOperationException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public static varargs a([Ljava/lang/Object;)V
.registers 3
.param p0, "contents" # [Ljava/lang/Object;
.line 164
sget-object v0, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v0}, Lcom/blankj/utilcode/util/LogUtils$Config;->getGlobalTag()Ljava/lang/String;
move-result-object v0
const/4 v1, 0x7
invoke-static {v1, v0, p0}, Lcom/blankj/utilcode/util/LogUtils;->log(ILjava/lang/String;[Ljava/lang/Object;)V
.line 165
return-void
.end method
.method public static varargs aTag(Ljava/lang/String;[Ljava/lang/Object;)V
.registers 3
.param p0, "tag" # Ljava/lang/String;
.param p1, "contents" # [Ljava/lang/Object;
.line 168
const/4 v0, 0x7
invoke-static {v0, p0, p1}, Lcom/blankj/utilcode/util/LogUtils;->log(ILjava/lang/String;[Ljava/lang/Object;)V
.line 169
return-void
.end method
.method static synthetic access$1000()Landroidx/collection/SimpleArrayMap;
.registers 1
.line 69
sget-object v0, Lcom/blankj/utilcode/util/LogUtils;->I_FORMATTER_MAP:Landroidx/collection/SimpleArrayMap;
return-object v0
.end method
.method static synthetic access$1100()[C
.registers 1
.line 69
sget-object v0, Lcom/blankj/utilcode/util/LogUtils;->T:[C
return-object v0
.end method
.method static synthetic access$1200()Ljava/lang/String;
.registers 1
.line 69
sget-object v0, Lcom/blankj/utilcode/util/LogUtils;->LINE_SEP:Ljava/lang/String;
return-object v0
.end method
.method static synthetic access$1300(Ljava/lang/Object;)Ljava/lang/String;
.registers 2
.param p0, "x0" # Ljava/lang/Object;
.line 69
invoke-static {p0}, Lcom/blankj/utilcode/util/LogUtils;->formatObject(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method static synthetic access$300(ILjava/lang/String;Ljava/lang/String;)V
.registers 3
.param p0, "x0" # I
.param p1, "x1" # Ljava/lang/String;
.param p2, "x2" # Ljava/lang/String;
.line 69
invoke-static {p0, p1, p2}, Lcom/blankj/utilcode/util/LogUtils;->print2File(ILjava/lang/String;Ljava/lang/String;)V
return-void
.end method
.method static synthetic access$400(Ljava/lang/String;)Z
.registers 2
.param p0, "x0" # Ljava/lang/String;
.line 69
invoke-static {p0}, Lcom/blankj/utilcode/util/LogUtils;->isMatchLogFileName(Ljava/lang/String;)Z
move-result v0
return v0
.end method
.method static synthetic access$700()Ljava/lang/String;
.registers 1
.line 69
sget-object v0, Lcom/blankj/utilcode/util/LogUtils;->FILE_SEP:Ljava/lang/String;
return-object v0
.end method
.method static synthetic access$800(Ljava/lang/String;)Z
.registers 2
.param p0, "x0" # Ljava/lang/String;
.line 69
invoke-static {p0}, Lcom/blankj/utilcode/util/LogUtils;->isSpace(Ljava/lang/String;)Z
move-result v0
return v0
.end method
.method static synthetic access$900(Lcom/blankj/utilcode/util/LogUtils$IFormatter;)Ljava/lang/Class;
.registers 2
.param p0, "x0" # Lcom/blankj/utilcode/util/LogUtils$IFormatter;
.line 69
invoke-static {p0}, Lcom/blankj/utilcode/util/LogUtils;->getTypeClassFromParadigm(Lcom/blankj/utilcode/util/LogUtils$IFormatter;)Ljava/lang/Class;
move-result-object v0
return-object v0
.end method
.method private static createOrExistsDir(Ljava/io/File;)Z
.registers 2
.param p0, "file" # Ljava/io/File;
.line 617
if-eqz p0, :cond_17
invoke-virtual {p0}, Ljava/io/File;->exists()Z
move-result v0
if-eqz v0, :cond_f
invoke-virtual {p0}, Ljava/io/File;->isDirectory()Z
move-result v0
if-eqz v0, :cond_17
goto :goto_15
:cond_f
invoke-virtual {p0}, Ljava/io/File;->mkdirs()Z
move-result v0
if-eqz v0, :cond_17
:goto_15
const/4 v0, 0x1
goto :goto_18
:cond_17
const/4 v0, 0x0
:goto_18
return v0
.end method
.method private static createOrExistsFile(Ljava/lang/String;Ljava/lang/String;)Z
.registers 5
.param p0, "filePath" # Ljava/lang/String;
.param p1, "date" # Ljava/lang/String;
.line 526
new-instance v0, Ljava/io/File;
invoke-direct {v0, p0}, Ljava/io/File;-><init>(Ljava/lang/String;)V
.line 527
.local v0, "file":Ljava/io/File;
invoke-virtual {v0}, Ljava/io/File;->exists()Z
move-result v1
if-eqz v1, :cond_10
invoke-virtual {v0}, Ljava/io/File;->isFile()Z
move-result v1
return v1
.line 528
:cond_10
invoke-virtual {v0}, Ljava/io/File;->getParentFile()Ljava/io/File;
move-result-object v1
invoke-static {v1}, Lcom/blankj/utilcode/util/LogUtils;->createOrExistsDir(Ljava/io/File;)Z
move-result v1
const/4 v2, 0x0
if-nez v1, :cond_1c
return v2
.line 530
:cond_1c
:try_start_1c
invoke-static {p0, p1}, Lcom/blankj/utilcode/util/LogUtils;->deleteDueLogs(Ljava/lang/String;Ljava/lang/String;)V
.line 531
invoke-virtual {v0}, Ljava/io/File;->createNewFile()Z
move-result v1
.line 532
.local v1, "isCreate":Z
if-eqz v1, :cond_28
.line 533
invoke-static {p0, p1}, Lcom/blankj/utilcode/util/LogUtils;->printDeviceInfo(Ljava/lang/String;Ljava/lang/String;)V
:try_end_28
.catch Ljava/io/IOException; {:try_start_1c .. :try_end_28} :catch_29
.line 535
:cond_28
return v1
.line 536
.end local v1 # "isCreate":Z
:catch_29
move-exception v1
.line 537
.local v1, "e":Ljava/io/IOException;
invoke-virtual {v1}, Ljava/io/IOException;->printStackTrace()V
.line 538
return v2
.end method
.method public static varargs d([Ljava/lang/Object;)V
.registers 3
.param p0, "contents" # [Ljava/lang/Object;
.line 132
sget-object v0, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v0}, Lcom/blankj/utilcode/util/LogUtils$Config;->getGlobalTag()Ljava/lang/String;
move-result-object v0
const/4 v1, 0x3
invoke-static {v1, v0, p0}, Lcom/blankj/utilcode/util/LogUtils;->log(ILjava/lang/String;[Ljava/lang/Object;)V
.line 133
return-void
.end method
.method public static varargs dTag(Ljava/lang/String;[Ljava/lang/Object;)V
.registers 3
.param p0, "tag" # Ljava/lang/String;
.param p1, "contents" # [Ljava/lang/Object;
.line 136
const/4 v0, 0x3
invoke-static {v0, p0, p1}, Lcom/blankj/utilcode/util/LogUtils;->log(ILjava/lang/String;[Ljava/lang/Object;)V
.line 137
return-void
.end method
.method private static deleteDueLogs(Ljava/lang/String;Ljava/lang/String;)V
.registers 19
.param p0, "filePath" # Ljava/lang/String;
.param p1, "date" # Ljava/lang/String;
.line 543
sget-object v0, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v0}, Lcom/blankj/utilcode/util/LogUtils$Config;->getSaveDays()I
move-result v0
if-gtz v0, :cond_9
return-void
.line 544
:cond_9
new-instance v0, Ljava/io/File;
move-object/from16 v1, p0
invoke-direct {v0, v1}, Ljava/io/File;-><init>(Ljava/lang/String;)V
move-object v2, v0
.line 545
.local v2, "file":Ljava/io/File;
invoke-virtual {v2}, Ljava/io/File;->getParentFile()Ljava/io/File;
move-result-object v3
.line 546
.local v3, "parentFile":Ljava/io/File;
new-instance v0, Lcom/blankj/utilcode/util/LogUtils$3;
invoke-direct {v0}, Lcom/blankj/utilcode/util/LogUtils$3;-><init>()V
invoke-virtual {v3, v0}, Ljava/io/File;->listFiles(Ljava/io/FilenameFilter;)[Ljava/io/File;
move-result-object v4
.line 552
.local v4, "files":[Ljava/io/File;
if-eqz v4, :cond_7b
array-length v0, v4
if-gtz v0, :cond_26
move-object/from16 v6, p1
goto :goto_7d
.line 553
:cond_26
new-instance v0, Ljava/text/SimpleDateFormat;
invoke-static {}, Ljava/util/Locale;->getDefault()Ljava/util/Locale;
move-result-object v5
const-string/jumbo v6, "yyyy_MM_dd"
invoke-direct {v0, v6, v5}, Ljava/text/SimpleDateFormat;-><init>(Ljava/lang/String;Ljava/util/Locale;)V
move-object v5, v0
.line 555
.local v5, "sdf":Ljava/text/SimpleDateFormat;
move-object/from16 v6, p1
:try_start_35
invoke-virtual {v5, v6}, Ljava/text/SimpleDateFormat;->parse(Ljava/lang/String;)Ljava/util/Date;
move-result-object v0
invoke-virtual {v0}, Ljava/util/Date;->getTime()J
move-result-wide v7
sget-object v0, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v0}, Lcom/blankj/utilcode/util/LogUtils$Config;->getSaveDays()I
move-result v0
int-to-long v9, v0
const-wide/32 v11, 0x5265c00
mul-long v9, v9, v11
sub-long/2addr v7, v9
.line 556
.local v7, "dueMillis":J
array-length v0, v4
const/4 v9, 0x0
:goto_4c
if-ge v9, v0, :cond_75
aget-object v10, v4, v9
.line 557
.local v10, "aFile":Ljava/io/File;
invoke-virtual {v10}, Ljava/io/File;->getName()Ljava/lang/String;
move-result-object v11
.line 558
.local v11, "name":Ljava/lang/String;
invoke-virtual {v11}, Ljava/lang/String;->length()I
move-result v12
.line 559
.local v12, "l":I
invoke-static {v11}, Lcom/blankj/utilcode/util/LogUtils;->findDate(Ljava/lang/String;)Ljava/lang/String;
move-result-object v13
.line 560
.local v13, "logDay":Ljava/lang/String;
invoke-virtual {v5, v13}, Ljava/text/SimpleDateFormat;->parse(Ljava/lang/String;)Ljava/util/Date;
move-result-object v14
invoke-virtual {v14}, Ljava/util/Date;->getTime()J
move-result-wide v14
cmp-long v16, v14, v7
if-gtz v16, :cond_72
.line 561
sget-object v14, Lcom/blankj/utilcode/util/LogUtils;->EXECUTOR:Ljava/util/concurrent/ExecutorService;
new-instance v15, Lcom/blankj/utilcode/util/LogUtils$4;
invoke-direct {v15, v10}, Lcom/blankj/utilcode/util/LogUtils$4;-><init>(Ljava/io/File;)V
invoke-interface {v14, v15}, Ljava/util/concurrent/ExecutorService;->execute(Ljava/lang/Runnable;)V
:try_end_72
.catch Ljava/text/ParseException; {:try_start_35 .. :try_end_72} :catch_76
.line 556
.end local v10 # "aFile":Ljava/io/File;
.end local v11 # "name":Ljava/lang/String;
.end local v12 # "l":I
.end local v13 # "logDay":Ljava/lang/String;
:cond_72
add-int/lit8 v9, v9, 0x1
goto :goto_4c
.line 574
.end local v7 # "dueMillis":J
:cond_75
goto :goto_7a
.line 572
:catch_76
move-exception v0
.line 573
.local v0, "e":Ljava/text/ParseException;
invoke-virtual {v0}, Ljava/text/ParseException;->printStackTrace()V
.line 575
.end local v0 # "e":Ljava/text/ParseException;
:goto_7a
return-void
.line 552
.end local v5 # "sdf":Ljava/text/SimpleDateFormat;
:cond_7b
move-object/from16 v6, p1
:goto_7d
return-void
.end method
.method public static varargs e([Ljava/lang/Object;)V
.registers 3
.param p0, "contents" # [Ljava/lang/Object;
.line 156
sget-object v0, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v0}, Lcom/blankj/utilcode/util/LogUtils$Config;->getGlobalTag()Ljava/lang/String;
move-result-object v0
const/4 v1, 0x6
invoke-static {v1, v0, p0}, Lcom/blankj/utilcode/util/LogUtils;->log(ILjava/lang/String;[Ljava/lang/Object;)V
.line 157
return-void
.end method
.method public static varargs eTag(Ljava/lang/String;[Ljava/lang/Object;)V
.registers 3
.param p0, "tag" # Ljava/lang/String;
.param p1, "contents" # [Ljava/lang/Object;
.line 160
const/4 v0, 0x6
invoke-static {v0, p0, p1}, Lcom/blankj/utilcode/util/LogUtils;->log(ILjava/lang/String;[Ljava/lang/Object;)V
.line 161
return-void
.end method
.method public static file(ILjava/lang/Object;)V
.registers 6
.param p0, "type" # I
.param p1, "content" # Ljava/lang/Object;
.line 176
or-int/lit8 v0, p0, 0x10
sget-object v1, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v1}, Lcom/blankj/utilcode/util/LogUtils$Config;->getGlobalTag()Ljava/lang/String;
move-result-object v1
const/4 v2, 0x1
new-array v2, v2, [Ljava/lang/Object;
const/4 v3, 0x0
aput-object p1, v2, v3
invoke-static {v0, v1, v2}, Lcom/blankj/utilcode/util/LogUtils;->log(ILjava/lang/String;[Ljava/lang/Object;)V
.line 177
return-void
.end method
.method public static file(ILjava/lang/String;Ljava/lang/Object;)V
.registers 6
.param p0, "type" # I
.param p1, "tag" # Ljava/lang/String;
.param p2, "content" # Ljava/lang/Object;
.line 184
or-int/lit8 v0, p0, 0x10
const/4 v1, 0x1
new-array v1, v1, [Ljava/lang/Object;
const/4 v2, 0x0
aput-object p2, v1, v2
invoke-static {v0, p1, v1}, Lcom/blankj/utilcode/util/LogUtils;->log(ILjava/lang/String;[Ljava/lang/Object;)V
.line 185
return-void
.end method
.method public static file(Ljava/lang/Object;)V
.registers 4
.param p0, "content" # Ljava/lang/Object;
.line 172
sget-object v0, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v0}, Lcom/blankj/utilcode/util/LogUtils$Config;->getGlobalTag()Ljava/lang/String;
move-result-object v0
const/4 v1, 0x1
new-array v1, v1, [Ljava/lang/Object;
const/4 v2, 0x0
aput-object p0, v1, v2
const/16 v2, 0x13
invoke-static {v2, v0, v1}, Lcom/blankj/utilcode/util/LogUtils;->log(ILjava/lang/String;[Ljava/lang/Object;)V
.line 173
return-void
.end method
.method public static file(Ljava/lang/String;Ljava/lang/Object;)V
.registers 4
.param p0, "tag" # Ljava/lang/String;
.param p1, "content" # Ljava/lang/Object;
.line 180
const/4 v0, 0x1
new-array v0, v0, [Ljava/lang/Object;
const/4 v1, 0x0
aput-object p1, v0, v1
const/16 v1, 0x13
invoke-static {v1, p0, v0}, Lcom/blankj/utilcode/util/LogUtils;->log(ILjava/lang/String;[Ljava/lang/Object;)V
.line 181
return-void
.end method
.method private static findDate(Ljava/lang/String;)Ljava/lang/String;
.registers 4
.param p0, "str" # Ljava/lang/String;
.line 582
const-string v0, "[0-9]{4}_[0-9]{2}_[0-9]{2}"
invoke-static {v0}, Ljava/util/regex/Pattern;->compile(Ljava/lang/String;)Ljava/util/regex/Pattern;
move-result-object v0
.line 583
.local v0, "pattern":Ljava/util/regex/Pattern;
invoke-virtual {v0, p0}, Ljava/util/regex/Pattern;->matcher(Ljava/lang/CharSequence;)Ljava/util/regex/Matcher;
move-result-object v1
.line 584
.local v1, "matcher":Ljava/util/regex/Matcher;
invoke-virtual {v1}, Ljava/util/regex/Matcher;->find()Z
move-result v2
if-eqz v2, :cond_15
.line 585
invoke-virtual {v1}, Ljava/util/regex/Matcher;->group()Ljava/lang/String;
move-result-object v2
return-object v2
.line 587
:cond_15
const-string v2, ""
return-object v2
.end method
.method private static formatObject(ILjava/lang/Object;)Ljava/lang/String;
.registers 3
.param p0, "type" # I
.param p1, "object" # Ljava/lang/Object;
.line 357
if-nez p1, :cond_5
const-string v0, "null"
return-object v0
.line 358
:cond_5
const/16 v0, 0x20
if-ne p0, v0, :cond_e
invoke-static {p1, v0}, Lcom/blankj/utilcode/util/LogUtils$LogFormatter;->object2String(Ljava/lang/Object;I)Ljava/lang/String;
move-result-object v0
return-object v0
.line 359
:cond_e
const/16 v0, 0x30
if-ne p0, v0, :cond_17
invoke-static {p1, v0}, Lcom/blankj/utilcode/util/LogUtils$LogFormatter;->object2String(Ljava/lang/Object;I)Ljava/lang/String;
move-result-object v0
return-object v0
.line 360
:cond_17
invoke-static {p1}, Lcom/blankj/utilcode/util/LogUtils;->formatObject(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method private static formatObject(Ljava/lang/Object;)Ljava/lang/String;
.registers 3
.param p0, "object" # Ljava/lang/Object;
.line 364
if-nez p0, :cond_5
const-string v0, "null"
return-object v0
.line 365
:cond_5
sget-object v0, Lcom/blankj/utilcode/util/LogUtils;->I_FORMATTER_MAP:Landroidx/collection/SimpleArrayMap;
invoke-virtual {v0}, Landroidx/collection/SimpleArrayMap;->isEmpty()Z
move-result v0
if-nez v0, :cond_20
.line 366
sget-object v0, Lcom/blankj/utilcode/util/LogUtils;->I_FORMATTER_MAP:Landroidx/collection/SimpleArrayMap;
invoke-static {p0}, Lcom/blankj/utilcode/util/LogUtils;->getClassFromObject(Ljava/lang/Object;)Ljava/lang/Class;
move-result-object v1
invoke-virtual {v0, v1}, Landroidx/collection/SimpleArrayMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/blankj/utilcode/util/LogUtils$IFormatter;
.line 367
.local v0, "iFormatter":Lcom/blankj/utilcode/util/LogUtils$IFormatter;
if-eqz v0, :cond_20
.line 369
invoke-virtual {v0, p0}, Lcom/blankj/utilcode/util/LogUtils$IFormatter;->format(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v1
return-object v1
.line 372
.end local v0 # "iFormatter":Lcom/blankj/utilcode/util/LogUtils$IFormatter;
:cond_20
invoke-static {p0}, Lcom/blankj/utilcode/util/LogUtils$LogFormatter;->object2String(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method private static getClassFromObject(Ljava/lang/Object;)Ljava/lang/Class;
.registers 5
.param p0, "obj" # Ljava/lang/Object;
.line 1199
invoke-virtual {p0}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
move-result-object v0
.line 1200
.local v0, "objClass":Ljava/lang/Class;
invoke-virtual {v0}, Ljava/lang/Class;->isAnonymousClass()Z
move-result v1
if-nez v1, :cond_10
invoke-virtual {v0}, Ljava/lang/Class;->isSynthetic()Z
move-result v1
if-eqz v1, :cond_66
.line 1201
:cond_10
invoke-virtual {v0}, Ljava/lang/Class;->getGenericInterfaces()[Ljava/lang/reflect/Type;
move-result-object v1
.line 1203
.local v1, "genericInterfaces":[Ljava/lang/reflect/Type;
array-length v2, v1
const/4 v3, 0x1
if-ne v2, v3, :cond_2c
.line 1204
const/4 v2, 0x0
aget-object v2, v1, v2
.line 1205
.local v2, "type":Ljava/lang/reflect/Type;
:goto_1b
instance-of v3, v2, Ljava/lang/reflect/ParameterizedType;
if-eqz v3, :cond_27
.line 1206
move-object v3, v2
check-cast v3, Ljava/lang/reflect/ParameterizedType;
invoke-interface {v3}, Ljava/lang/reflect/ParameterizedType;->getRawType()Ljava/lang/reflect/Type;
move-result-object v2
goto :goto_1b
.line 1208
:cond_27
invoke-virtual {v2}, Ljava/lang/Object;->toString()Ljava/lang/String;
move-result-object v2
.line 1209
.local v2, "className":Ljava/lang/String;
goto :goto_41
.line 1210
.end local v2 # "className":Ljava/lang/String;
:cond_2c
invoke-virtual {v0}, Ljava/lang/Class;->getGenericSuperclass()Ljava/lang/reflect/Type;
move-result-object v2
.line 1211
.local v2, "type":Ljava/lang/reflect/Type;
:goto_30
instance-of v3, v2, Ljava/lang/reflect/ParameterizedType;
if-eqz v3, :cond_3c
.line 1212
move-object v3, v2
check-cast v3, Ljava/lang/reflect/ParameterizedType;
invoke-interface {v3}, Ljava/lang/reflect/ParameterizedType;->getRawType()Ljava/lang/reflect/Type;
move-result-object v2
goto :goto_30
.line 1214
:cond_3c
invoke-virtual {v2}, Ljava/lang/Object;->toString()Ljava/lang/String;
move-result-object v3
move-object v2, v3
.line 1217
.local v2, "className":Ljava/lang/String;
:goto_41
const-string v3, "class "
invoke-virtual {v2, v3}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
move-result v3
if-eqz v3, :cond_4f
.line 1218
const/4 v3, 0x6
invoke-virtual {v2, v3}, Ljava/lang/String;->substring(I)Ljava/lang/String;
move-result-object v2
goto :goto_5d
.line 1219
:cond_4f
const-string v3, "interface "
invoke-virtual {v2, v3}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
move-result v3
if-eqz v3, :cond_5d
.line 1220
const/16 v3, 0xa
invoke-virtual {v2, v3}, Ljava/lang/String;->substring(I)Ljava/lang/String;
move-result-object v2
.line 1223
:cond_5d
:goto_5d
:try_start_5d
invoke-static {v2}, Ljava/lang/Class;->forName(Ljava/lang/String;)Ljava/lang/Class;
move-result-object v3
:try_end_61
.catch Ljava/lang/ClassNotFoundException; {:try_start_5d .. :try_end_61} :catch_62
return-object v3
.line 1224
:catch_62
move-exception v3
.line 1225
.local v3, "e":Ljava/lang/ClassNotFoundException;
invoke-virtual {v3}, Ljava/lang/ClassNotFoundException;->printStackTrace()V
.line 1228
.end local v1 # "genericInterfaces":[Ljava/lang/reflect/Type;
.end local v2 # "className":Ljava/lang/String;
.end local v3 # "e":Ljava/lang/ClassNotFoundException;
:cond_66
return-object v0
.end method
.method public static getConfig()Lcom/blankj/utilcode/util/LogUtils$Config;
.registers 1
.line 120
sget-object v0, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
return-object v0
.end method
.method private static getFileName(Ljava/lang/StackTraceElement;)Ljava/lang/String;
.registers 7
.param p0, "targetElement" # Ljava/lang/StackTraceElement;
.line 317
invoke-virtual {p0}, Ljava/lang/StackTraceElement;->getFileName()Ljava/lang/String;
move-result-object v0
.line 318
.local v0, "fileName":Ljava/lang/String;
if-eqz v0, :cond_7
return-object v0
.line 321
:cond_7
invoke-virtual {p0}, Ljava/lang/StackTraceElement;->getClassName()Ljava/lang/String;
move-result-object v1
.line 322
.local v1, "className":Ljava/lang/String;
const-string v2, "\\."
invoke-virtual {v1, v2}, Ljava/lang/String;->split(Ljava/lang/String;)[Ljava/lang/String;
move-result-object v2
.line 323
.local v2, "classNameInfo":[Ljava/lang/String;
array-length v3, v2
if-lez v3, :cond_19
.line 324
array-length v3, v2
add-int/lit8 v3, v3, -0x1
aget-object v1, v2, v3
.line 326
:cond_19
const/16 v3, 0x24
invoke-virtual {v1, v3}, Ljava/lang/String;->indexOf(I)I
move-result v3
.line 327
.local v3, "index":I
const/4 v4, -0x1
if-eq v3, v4, :cond_27
.line 328
const/4 v4, 0x0
invoke-virtual {v1, v4, v3}, Ljava/lang/String;->substring(II)Ljava/lang/String;
move-result-object v1
.line 330
:cond_27
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v4, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v5, ".java"
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
return-object v4
.end method
.method public static getLogFiles()Ljava/util/List;
.registers 4
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/util/List<",
"Ljava/io/File;",
">;"
}
.end annotation
.line 241
sget-object v0, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v0}, Lcom/blankj/utilcode/util/LogUtils$Config;->getDir()Ljava/lang/String;
move-result-object v0
.line 242
.local v0, "dir":Ljava/lang/String;
new-instance v1, Ljava/io/File;
invoke-direct {v1, v0}, Ljava/io/File;-><init>(Ljava/lang/String;)V
.line 243
.local v1, "logDir":Ljava/io/File;
invoke-virtual {v1}, Ljava/io/File;->exists()Z
move-result v2
if-nez v2, :cond_17
new-instance v2, Ljava/util/ArrayList;
invoke-direct {v2}, Ljava/util/ArrayList;-><init>()V
return-object v2
.line 244
:cond_17
new-instance v2, Lcom/blankj/utilcode/util/LogUtils$2;
invoke-direct {v2}, Lcom/blankj/utilcode/util/LogUtils$2;-><init>()V
invoke-virtual {v1, v2}, Ljava/io/File;->listFiles(Ljava/io/FilenameFilter;)[Ljava/io/File;
move-result-object v2
.line 250
.local v2, "files":[Ljava/io/File;
new-instance v3, Ljava/util/ArrayList;
invoke-direct {v3}, Ljava/util/ArrayList;-><init>()V
.line 251
.local v3, "list":Ljava/util/List;, "Ljava/util/List<Ljava/io/File;>;"
invoke-static {v3, v2}, Ljava/util/Collections;->addAll(Ljava/util/Collection;[Ljava/lang/Object;)Z
.line 252
return-object v3
.end method
.method private static getSdf()Ljava/text/SimpleDateFormat;
.registers 3
.line 519
sget-object v0, Lcom/blankj/utilcode/util/LogUtils;->simpleDateFormat:Ljava/text/SimpleDateFormat;
if-nez v0, :cond_12
.line 520
new-instance v0, Ljava/text/SimpleDateFormat;
invoke-static {}, Ljava/util/Locale;->getDefault()Ljava/util/Locale;
move-result-object v1
const-string/jumbo v2, "yyyy_MM_dd HH:mm:ss.SSS "
invoke-direct {v0, v2, v1}, Ljava/text/SimpleDateFormat;-><init>(Ljava/lang/String;Ljava/util/Locale;)V
sput-object v0, Lcom/blankj/utilcode/util/LogUtils;->simpleDateFormat:Ljava/text/SimpleDateFormat;
.line 522
:cond_12
sget-object v0, Lcom/blankj/utilcode/util/LogUtils;->simpleDateFormat:Ljava/text/SimpleDateFormat;
return-object v0
.end method
.method private static getTypeClassFromParadigm(Lcom/blankj/utilcode/util/LogUtils$IFormatter;)Ljava/lang/Class;
.registers 5
.annotation system Ldalvik/annotation/Signature;
value = {
"<T:",
"Ljava/lang/Object;",
">(",
"Lcom/blankj/utilcode/util/LogUtils$IFormatter<",
"TT;>;)",
"Ljava/lang/Class;"
}
.end annotation
.line 1173
.local p0, "formatter":Lcom/blankj/utilcode/util/LogUtils$IFormatter;, "Lcom/blankj/utilcode/util/LogUtils$IFormatter<TT;>;"
invoke-virtual {p0}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/Class;->getGenericInterfaces()[Ljava/lang/reflect/Type;
move-result-object v0
.line 1175
.local v0, "genericInterfaces":[Ljava/lang/reflect/Type;
array-length v1, v0
const/4 v2, 0x0
const/4 v3, 0x1
if-ne v1, v3, :cond_10
.line 1176
aget-object v1, v0, v2
.local v1, "type":Ljava/lang/reflect/Type;
goto :goto_18
.line 1178
.end local v1 # "type":Ljava/lang/reflect/Type;
:cond_10
invoke-virtual {p0}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/Class;->getGenericSuperclass()Ljava/lang/reflect/Type;
move-result-object v1
.line 1180
.restart local v1 # "type":Ljava/lang/reflect/Type;
:goto_18
move-object v3, v1
check-cast v3, Ljava/lang/reflect/ParameterizedType;
invoke-interface {v3}, Ljava/lang/reflect/ParameterizedType;->getActualTypeArguments()[Ljava/lang/reflect/Type;
move-result-object v3
aget-object v1, v3, v2
.line 1181
:goto_21
instance-of v2, v1, Ljava/lang/reflect/ParameterizedType;
if-eqz v2, :cond_2d
.line 1182
move-object v2, v1
check-cast v2, Ljava/lang/reflect/ParameterizedType;
invoke-interface {v2}, Ljava/lang/reflect/ParameterizedType;->getRawType()Ljava/lang/reflect/Type;
move-result-object v1
goto :goto_21
.line 1184
:cond_2d
invoke-virtual {v1}, Ljava/lang/Object;->toString()Ljava/lang/String;
move-result-object v2
.line 1185
.local v2, "className":Ljava/lang/String;
const-string v3, "class "
invoke-virtual {v2, v3}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
move-result v3
if-eqz v3, :cond_3f
.line 1186
const/4 v3, 0x6
invoke-virtual {v2, v3}, Ljava/lang/String;->substring(I)Ljava/lang/String;
move-result-object v2
goto :goto_4d
.line 1187
:cond_3f
const-string v3, "interface "
invoke-virtual {v2, v3}, Ljava/lang/String;->startsWith(Ljava/lang/String;)Z
move-result v3
if-eqz v3, :cond_4d
.line 1188
const/16 v3, 0xa
invoke-virtual {v2, v3}, Ljava/lang/String;->substring(I)Ljava/lang/String;
move-result-object v2
.line 1191
:cond_4d
:goto_4d
:try_start_4d
invoke-static {v2}, Ljava/lang/Class;->forName(Ljava/lang/String;)Ljava/lang/Class;
move-result-object v3
:try_end_51
.catch Ljava/lang/ClassNotFoundException; {:try_start_4d .. :try_end_51} :catch_52
return-object v3
.line 1192
:catch_52
move-exception v3
.line 1193
.local v3, "e":Ljava/lang/ClassNotFoundException;
invoke-virtual {v3}, Ljava/lang/ClassNotFoundException;->printStackTrace()V
.line 1195
.end local v3 # "e":Ljava/lang/ClassNotFoundException;
const/4 v3, 0x0
return-object v3
.end method
.method public static varargs i([Ljava/lang/Object;)V
.registers 3
.param p0, "contents" # [Ljava/lang/Object;
.line 140
sget-object v0, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v0}, Lcom/blankj/utilcode/util/LogUtils$Config;->getGlobalTag()Ljava/lang/String;
move-result-object v0
const/4 v1, 0x4
invoke-static {v1, v0, p0}, Lcom/blankj/utilcode/util/LogUtils;->log(ILjava/lang/String;[Ljava/lang/Object;)V
.line 141
return-void
.end method
.method public static varargs iTag(Ljava/lang/String;[Ljava/lang/Object;)V
.registers 3
.param p0, "tag" # Ljava/lang/String;
.param p1, "contents" # [Ljava/lang/Object;
.line 144
const/4 v0, 0x4
invoke-static {v0, p0, p1}, Lcom/blankj/utilcode/util/LogUtils;->log(ILjava/lang/String;[Ljava/lang/Object;)V
.line 145
return-void
.end method
.method private static input2File(Ljava/lang/String;Ljava/lang/String;)V
.registers 7
.param p0, "input" # Ljava/lang/String;
.param p1, "filePath" # Ljava/lang/String;
.line 631
sget-object v0, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
# getter for: Lcom/blankj/utilcode/util/LogUtils$Config;->mFileWriter:Lcom/blankj/utilcode/util/LogUtils$IFileWriter;
invoke-static {v0}, Lcom/blankj/utilcode/util/LogUtils$Config;->access$600(Lcom/blankj/utilcode/util/LogUtils$Config;)Lcom/blankj/utilcode/util/LogUtils$IFileWriter;
move-result-object v0
if-nez v0, :cond_5e
.line 632
const/4 v0, 0x0
.line 634
.local v0, "bw":Ljava/io/BufferedWriter;
:try_start_9
new-instance v1, Ljava/io/BufferedWriter;
new-instance v2, Ljava/io/OutputStreamWriter;
new-instance v3, Ljava/io/FileOutputStream;
const/4 v4, 0x1
invoke-direct {v3, p1, v4}, Ljava/io/FileOutputStream;-><init>(Ljava/lang/String;Z)V
const-string v4, "UTF-8"
invoke-direct {v2, v3, v4}, Ljava/io/OutputStreamWriter;-><init>(Ljava/io/OutputStream;Ljava/lang/String;)V
invoke-direct {v1, v2}, Ljava/io/BufferedWriter;-><init>(Ljava/io/Writer;)V
move-object v0, v1
.line 635
invoke-virtual {v0, p0}, Ljava/io/BufferedWriter;->write(Ljava/lang/String;)V
:try_end_1f
.catch Ljava/io/IOException; {:try_start_9 .. :try_end_1f} :catch_2b
.catchall {:try_start_9 .. :try_end_1f} :catchall_29
.line 641
nop
.line 642
:try_start_20
invoke-virtual {v0}, Ljava/io/BufferedWriter;->close()V
:try_end_23
.catch Ljava/io/IOException; {:try_start_20 .. :try_end_23} :catch_24
.line 646
:cond_23
:goto_23
goto :goto_50
.line 644
:catch_24
move-exception v1
.line 645
.local v1, "e":Ljava/io/IOException;
invoke-virtual {v1}, Ljava/io/IOException;->printStackTrace()V
.line 647
.end local v1 # "e":Ljava/io/IOException;
goto :goto_50
.line 640
:catchall_29
move-exception v1
goto :goto_51
.line 636
:catch_2b
move-exception v1
.line 637
.restart local v1 # "e":Ljava/io/IOException;
:try_start_2c
invoke-virtual {v1}, Ljava/io/IOException;->printStackTrace()V
.line 638
const-string v2, "LogUtils"
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "log to "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v4, " failed!"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-static {v2, v3}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
:try_end_4a
.catchall {:try_start_2c .. :try_end_4a} :catchall_29
.line 641
.end local v1 # "e":Ljava/io/IOException;
if-eqz v0, :cond_23
.line 642
:try_start_4c
invoke-virtual {v0}, Ljava/io/BufferedWriter;->close()V
:try_end_4f
.catch Ljava/io/IOException; {:try_start_4c .. :try_end_4f} :catch_24
goto :goto_23
.line 648
.end local v0 # "bw":Ljava/io/BufferedWriter;
:goto_50
goto :goto_67
.line 641
.restart local v0 # "bw":Ljava/io/BufferedWriter;
:goto_51
if-eqz v0, :cond_5c
.line 642
:try_start_53
invoke-virtual {v0}, Ljava/io/BufferedWriter;->close()V
:try_end_56
.catch Ljava/io/IOException; {:try_start_53 .. :try_end_56} :catch_57
goto :goto_5c
.line 644
:catch_57
move-exception v2
.line 645
.local v2, "e":Ljava/io/IOException;
invoke-virtual {v2}, Ljava/io/IOException;->printStackTrace()V
goto :goto_5d
.line 646
.end local v2 # "e":Ljava/io/IOException;
:cond_5c
:goto_5c
nop
.line 647
:goto_5d
throw v1
.line 649
.end local v0 # "bw":Ljava/io/BufferedWriter;
:cond_5e
sget-object v0, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
# getter for: Lcom/blankj/utilcode/util/LogUtils$Config;->mFileWriter:Lcom/blankj/utilcode/util/LogUtils$IFileWriter;
invoke-static {v0}, Lcom/blankj/utilcode/util/LogUtils$Config;->access$600(Lcom/blankj/utilcode/util/LogUtils$Config;)Lcom/blankj/utilcode/util/LogUtils$IFileWriter;
move-result-object v0
invoke-interface {v0, p1, p0}, Lcom/blankj/utilcode/util/LogUtils$IFileWriter;->write(Ljava/lang/String;Ljava/lang/String;)V
.line 651
:goto_67
return-void
.end method
.method private static isMatchLogFileName(Ljava/lang/String;)Z
.registers 3
.param p0, "name" # Ljava/lang/String;
.line 578
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "^"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v1, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v1}, Lcom/blankj/utilcode/util/LogUtils$Config;->getFilePrefix()Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v1, "_[0-9]{4}_[0-9]{2}_[0-9]{2}_.*$"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {p0, v0}, Ljava/lang/String;->matches(Ljava/lang/String;)Z
move-result v0
return v0
.end method
.method private static isSpace(Ljava/lang/String;)Z
.registers 5
.param p0, "s" # Ljava/lang/String;
.line 621
const/4 v0, 0x1
if-nez p0, :cond_4
return v0
.line 622
:cond_4
const/4 v1, 0x0
.local v1, "i":I
invoke-virtual {p0}, Ljava/lang/String;->length()I
move-result v2
.local v2, "len":I
:goto_9
if-ge v1, v2, :cond_1a
.line 623
invoke-virtual {p0, v1}, Ljava/lang/String;->charAt(I)C
move-result v3
invoke-static {v3}, Ljava/lang/Character;->isWhitespace(C)Z
move-result v3
if-nez v3, :cond_17
.line 624
const/4 v0, 0x0
return v0
.line 622
:cond_17
add-int/lit8 v1, v1, 0x1
goto :goto_9
.line 627
.end local v1 # "i":I
.end local v2 # "len":I
:cond_1a
return v0
.end method
.method public static json(ILjava/lang/Object;)V
.registers 6
.param p0, "type" # I
.param p1, "content" # Ljava/lang/Object;
.line 192
or-int/lit8 v0, p0, 0x20
sget-object v1, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v1}, Lcom/blankj/utilcode/util/LogUtils$Config;->getGlobalTag()Ljava/lang/String;
move-result-object v1
const/4 v2, 0x1
new-array v2, v2, [Ljava/lang/Object;
const/4 v3, 0x0
aput-object p1, v2, v3
invoke-static {v0, v1, v2}, Lcom/blankj/utilcode/util/LogUtils;->log(ILjava/lang/String;[Ljava/lang/Object;)V
.line 193
return-void
.end method
.method public static json(ILjava/lang/String;Ljava/lang/Object;)V
.registers 6
.param p0, "type" # I
.param p1, "tag" # Ljava/lang/String;
.param p2, "content" # Ljava/lang/Object;
.line 200
or-int/lit8 v0, p0, 0x20
const/4 v1, 0x1
new-array v1, v1, [Ljava/lang/Object;
const/4 v2, 0x0
aput-object p2, v1, v2
invoke-static {v0, p1, v1}, Lcom/blankj/utilcode/util/LogUtils;->log(ILjava/lang/String;[Ljava/lang/Object;)V
.line 201
return-void
.end method
.method public static json(Ljava/lang/Object;)V
.registers 4
.param p0, "content" # Ljava/lang/Object;
.line 188
sget-object v0, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v0}, Lcom/blankj/utilcode/util/LogUtils$Config;->getGlobalTag()Ljava/lang/String;
move-result-object v0
const/4 v1, 0x1
new-array v1, v1, [Ljava/lang/Object;
const/4 v2, 0x0
aput-object p0, v1, v2
const/16 v2, 0x23
invoke-static {v2, v0, v1}, Lcom/blankj/utilcode/util/LogUtils;->log(ILjava/lang/String;[Ljava/lang/Object;)V
.line 189
return-void
.end method
.method public static json(Ljava/lang/String;Ljava/lang/Object;)V
.registers 4
.param p0, "tag" # Ljava/lang/String;
.param p1, "content" # Ljava/lang/Object;
.line 196
const/4 v0, 0x1
new-array v0, v0, [Ljava/lang/Object;
const/4 v1, 0x0
aput-object p1, v0, v1
const/16 v1, 0x23
invoke-static {v1, p0, v0}, Lcom/blankj/utilcode/util/LogUtils;->log(ILjava/lang/String;[Ljava/lang/Object;)V
.line 197
return-void
.end method
.method public static varargs log(ILjava/lang/String;[Ljava/lang/Object;)V
.registers 10
.param p0, "type" # I
.param p1, "tag" # Ljava/lang/String;
.param p2, "contents" # [Ljava/lang/Object;
.line 220
sget-object v0, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v0}, Lcom/blankj/utilcode/util/LogUtils$Config;->isLogSwitch()Z
move-result v0
if-nez v0, :cond_9
return-void
.line 221
:cond_9
and-int/lit8 v0, p0, 0xf
.local v0, "type_low":I
and-int/lit16 v1, p0, 0xf0
.line 222
.local v1, "type_high":I
sget-object v2, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v2}, Lcom/blankj/utilcode/util/LogUtils$Config;->isLog2ConsoleSwitch()Z
move-result v2
const/16 v3, 0x10
if-nez v2, :cond_21
sget-object v2, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v2}, Lcom/blankj/utilcode/util/LogUtils$Config;->isLog2FileSwitch()Z
move-result v2
if-nez v2, :cond_21
if-ne v1, v3, :cond_6f
.line 223
:cond_21
sget-object v2, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
# getter for: Lcom/blankj/utilcode/util/LogUtils$Config;->mConsoleFilter:I
invoke-static {v2}, Lcom/blankj/utilcode/util/LogUtils$Config;->access$100(Lcom/blankj/utilcode/util/LogUtils$Config;)I
move-result v2
if-ge v0, v2, :cond_32
sget-object v2, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
# getter for: Lcom/blankj/utilcode/util/LogUtils$Config;->mFileFilter:I
invoke-static {v2}, Lcom/blankj/utilcode/util/LogUtils$Config;->access$200(Lcom/blankj/utilcode/util/LogUtils$Config;)I
move-result v2
if-ge v0, v2, :cond_32
return-void
.line 224
:cond_32
invoke-static {p1}, Lcom/blankj/utilcode/util/LogUtils;->processTagAndHead(Ljava/lang/String;)Lcom/blankj/utilcode/util/LogUtils$TagHead;
move-result-object v2
.line 225
.local v2, "tagHead":Lcom/blankj/utilcode/util/LogUtils$TagHead;
invoke-static {v1, p2}, Lcom/blankj/utilcode/util/LogUtils;->processBody(I[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v4
.line 226
.local v4, "body":Ljava/lang/String;
sget-object v5, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v5}, Lcom/blankj/utilcode/util/LogUtils$Config;->isLog2ConsoleSwitch()Z
move-result v5
if-eqz v5, :cond_53
if-eq v1, v3, :cond_53
sget-object v5, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
# getter for: Lcom/blankj/utilcode/util/LogUtils$Config;->mConsoleFilter:I
invoke-static {v5}, Lcom/blankj/utilcode/util/LogUtils$Config;->access$100(Lcom/blankj/utilcode/util/LogUtils$Config;)I
move-result v5
if-lt v0, v5, :cond_53
.line 227
iget-object v5, v2, Lcom/blankj/utilcode/util/LogUtils$TagHead;->tag:Ljava/lang/String;
iget-object v6, v2, Lcom/blankj/utilcode/util/LogUtils$TagHead;->consoleHead:[Ljava/lang/String;
invoke-static {v0, v5, v6, v4}, Lcom/blankj/utilcode/util/LogUtils;->print2Console(ILjava/lang/String;[Ljava/lang/String;Ljava/lang/String;)V
.line 229
:cond_53
sget-object v5, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v5}, Lcom/blankj/utilcode/util/LogUtils$Config;->isLog2FileSwitch()Z
move-result v5
if-nez v5, :cond_5d
if-ne v1, v3, :cond_6f
:cond_5d
sget-object v3, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
# getter for: Lcom/blankj/utilcode/util/LogUtils$Config;->mFileFilter:I
invoke-static {v3}, Lcom/blankj/utilcode/util/LogUtils$Config;->access$200(Lcom/blankj/utilcode/util/LogUtils$Config;)I
move-result v3
if-lt v0, v3, :cond_6f
.line 230
sget-object v3, Lcom/blankj/utilcode/util/LogUtils;->EXECUTOR:Ljava/util/concurrent/ExecutorService;
new-instance v5, Lcom/blankj/utilcode/util/LogUtils$1;
invoke-direct {v5, v0, v2, v4}, Lcom/blankj/utilcode/util/LogUtils$1;-><init>(ILcom/blankj/utilcode/util/LogUtils$TagHead;Ljava/lang/String;)V
invoke-interface {v3, v5}, Ljava/util/concurrent/ExecutorService;->execute(Ljava/lang/Runnable;)V
.line 238
.end local v2 # "tagHead":Lcom/blankj/utilcode/util/LogUtils$TagHead;
.end local v4 # "body":Ljava/lang/String;
:cond_6f
return-void
.end method
.method private static print2Console(ILjava/lang/String;[Ljava/lang/String;Ljava/lang/String;)V
.registers 5
.param p0, "type" # I
.param p1, "tag" # Ljava/lang/String;
.param p2, "head" # [Ljava/lang/String;
.param p3, "msg" # Ljava/lang/String;
.line 379
sget-object v0, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v0}, Lcom/blankj/utilcode/util/LogUtils$Config;->isSingleTagSwitch()Z
move-result v0
if-eqz v0, :cond_10
.line 380
invoke-static {p0, p1, p2, p3}, Lcom/blankj/utilcode/util/LogUtils;->processSingleTagMsg(ILjava/lang/String;[Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
invoke-static {p0, p1, v0}, Lcom/blankj/utilcode/util/LogUtils;->printSingleTagMsg(ILjava/lang/String;Ljava/lang/String;)V
goto :goto_1e
.line 382
:cond_10
const/4 v0, 0x1
invoke-static {p0, p1, v0}, Lcom/blankj/utilcode/util/LogUtils;->printBorder(ILjava/lang/String;Z)V
.line 383
invoke-static {p0, p1, p2}, Lcom/blankj/utilcode/util/LogUtils;->printHead(ILjava/lang/String;[Ljava/lang/String;)V
.line 384
invoke-static {p0, p1, p3}, Lcom/blankj/utilcode/util/LogUtils;->printMsg(ILjava/lang/String;Ljava/lang/String;)V
.line 385
const/4 v0, 0x0
invoke-static {p0, p1, v0}, Lcom/blankj/utilcode/util/LogUtils;->printBorder(ILjava/lang/String;Z)V
.line 387
:goto_1e
return-void
.end method
.method private static print2File(ILjava/lang/String;Ljava/lang/String;)V
.registers 10
.param p0, "type" # I
.param p1, "tag" # Ljava/lang/String;
.param p2, "msg" # Ljava/lang/String;
.line 498
invoke-static {}, Lcom/blankj/utilcode/util/LogUtils;->getSdf()Ljava/text/SimpleDateFormat;
move-result-object v0
new-instance v1, Ljava/util/Date;
invoke-direct {v1}, Ljava/util/Date;-><init>()V
invoke-virtual {v0, v1}, Ljava/text/SimpleDateFormat;->format(Ljava/util/Date;)Ljava/lang/String;
move-result-object v0
.line 499
.local v0, "format":Ljava/lang/String;
const/4 v1, 0x0
const/16 v2, 0xa
invoke-virtual {v0, v1, v2}, Ljava/lang/String;->substring(II)Ljava/lang/String;
move-result-object v1
.line 500
.local v1, "date":Ljava/lang/String;
const/16 v2, 0xb
invoke-virtual {v0, v2}, Ljava/lang/String;->substring(I)Ljava/lang/String;
move-result-object v2
.line 501
.local v2, "time":Ljava/lang/String;
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
sget-object v4, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
.line 502
invoke-virtual {v4}, Lcom/blankj/utilcode/util/LogUtils$Config;->getDir()Ljava/lang/String;
move-result-object v4
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v4, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v4}, Lcom/blankj/utilcode/util/LogUtils$Config;->getFilePrefix()Ljava/lang/String;
move-result-object v4
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v4, "_"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v4, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
.line 504
invoke-virtual {v4}, Lcom/blankj/utilcode/util/LogUtils$Config;->getProcessName()Ljava/lang/String;
move-result-object v4
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v4, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v4}, Lcom/blankj/utilcode/util/LogUtils$Config;->getFileExtension()Ljava/lang/String;
move-result-object v4
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
.line 505
.local v3, "fullPath":Ljava/lang/String;
invoke-static {v3, v1}, Lcom/blankj/utilcode/util/LogUtils;->createOrExistsFile(Ljava/lang/String;Ljava/lang/String;)Z
move-result v4
if-nez v4, :cond_74
.line 506
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "create "
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v5, " failed!"
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
const-string v5, "LogUtils"
invoke-static {v5, v4}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
.line 507
return-void
.line 509
:cond_74
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v4, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v5, Lcom/blankj/utilcode/util/LogUtils;->T:[C
add-int/lit8 v6, p0, -0x2
aget-char v5, v5, v6
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
const-string v5, "/"
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v5, Lcom/blankj/utilcode/util/LogUtils;->LINE_SEP:Ljava/lang/String;
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
.line 515
.local v4, "content":Ljava/lang/String;
invoke-static {v4, v3}, Lcom/blankj/utilcode/util/LogUtils;->input2File(Ljava/lang/String;Ljava/lang/String;)V
.line 516
return-void
.end method
.method private static printBorder(ILjava/lang/String;Z)V
.registers 4
.param p0, "type" # I
.param p1, "tag" # Ljava/lang/String;
.param p2, "isTop" # Z
.line 390
sget-object v0, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v0}, Lcom/blankj/utilcode/util/LogUtils$Config;->isLogBorderSwitch()Z
move-result v0
if-eqz v0, :cond_14
.line 391
if-eqz p2, :cond_e
const-string/jumbo v0, "\u250c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500"
goto :goto_11
:cond_e
const-string/jumbo v0, "\u2514\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500"
:goto_11
invoke-static {p0, p1, v0}, Landroid/util/Log;->println(ILjava/lang/String;Ljava/lang/String;)I
.line 393
:cond_14
return-void
.end method
.method private static printDeviceInfo(Ljava/lang/String;Ljava/lang/String;)V
.registers 7
.param p0, "filePath" # Ljava/lang/String;
.param p1, "date" # Ljava/lang/String;
.line 591
const-string v0, ""
.line 592
.local v0, "versionName":Ljava/lang/String;
const/4 v1, 0x0
.line 594
.local v1, "versionCode":I
:try_start_3
invoke-static {}, Lcom/blankj/utilcode/util/Utils;->getApp()Landroid/app/Application;
move-result-object v2
.line 595
invoke-virtual {v2}, Landroid/app/Application;->getPackageManager()Landroid/content/pm/PackageManager;
move-result-object v2
.line 596
invoke-static {}, Lcom/blankj/utilcode/util/Utils;->getApp()Landroid/app/Application;
move-result-object v3
invoke-virtual {v3}, Landroid/app/Application;->getPackageName()Ljava/lang/String;
move-result-object v3
const/4 v4, 0x0
invoke-virtual {v2, v3, v4}, Landroid/content/pm/PackageManager;->getPackageInfo(Ljava/lang/String;I)Landroid/content/pm/PackageInfo;
move-result-object v2
.line 597
.local v2, "pi":Landroid/content/pm/PackageInfo;
if-eqz v2, :cond_20
.line 598
iget-object v3, v2, Landroid/content/pm/PackageInfo;->versionName:Ljava/lang/String;
move-object v0, v3
.line 599
iget v3, v2, Landroid/content/pm/PackageInfo;->versionCode:I
:try_end_1f
.catch Landroid/content/pm/PackageManager$NameNotFoundException; {:try_start_3 .. :try_end_1f} :catch_21
move v1, v3
.line 603
.end local v2 # "pi":Landroid/content/pm/PackageInfo;
:cond_20
goto :goto_25
.line 601
:catch_21
move-exception v2
.line 602
.local v2, "e":Landroid/content/pm/PackageManager$NameNotFoundException;
invoke-virtual {v2}, Landroid/content/pm/PackageManager$NameNotFoundException;->printStackTrace()V
.line 604
.end local v2 # "e":Landroid/content/pm/PackageManager$NameNotFoundException;
:goto_25
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "************* Log Head ****************\nDate of Log : "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v3, "\nDevice Manufacturer: "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v3, Landroid/os/Build;->MANUFACTURER:Ljava/lang/String;
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v3, "\nDevice Model : "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v3, Landroid/os/Build;->MODEL:Ljava/lang/String;
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v3, "\nAndroid Version : "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v3, Landroid/os/Build$VERSION;->RELEASE:Ljava/lang/String;
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v3, "\nAndroid SDK : "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget v3, Landroid/os/Build$VERSION;->SDK_INT:I
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v3, "\nApp VersionName : "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v3, "\nApp VersionCode : "
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v3, "\n************* Log Head ****************\n\n"
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
.line 613
.local v2, "head":Ljava/lang/String;
invoke-static {v2, p0}, Lcom/blankj/utilcode/util/LogUtils;->input2File(Ljava/lang/String;Ljava/lang/String;)V
.line 614
return-void
.end method
.method private static printHead(ILjava/lang/String;[Ljava/lang/String;)V
.registers 8
.param p0, "type" # I
.param p1, "tag" # Ljava/lang/String;
.param p2, "head" # [Ljava/lang/String;
.line 396
if-eqz p2, :cond_38
.line 397
array-length v0, p2
const/4 v1, 0x0
:goto_4
if-ge v1, v0, :cond_2a
aget-object v2, p2, v1
.line 398
.local v2, "aHead":Ljava/lang/String;
sget-object v3, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v3}, Lcom/blankj/utilcode/util/LogUtils$Config;->isLogBorderSwitch()Z
move-result v3
if-eqz v3, :cond_23
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v4, "\u2502 "
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
goto :goto_24
:cond_23
move-object v3, v2
:goto_24
invoke-static {p0, p1, v3}, Landroid/util/Log;->println(ILjava/lang/String;Ljava/lang/String;)I
.line 397
.end local v2 # "aHead":Ljava/lang/String;
add-int/lit8 v1, v1, 0x1
goto :goto_4
.line 400
:cond_2a
sget-object v0, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v0}, Lcom/blankj/utilcode/util/LogUtils$Config;->isLogBorderSwitch()Z
move-result v0
if-eqz v0, :cond_38
const-string/jumbo v0, "\u251c\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504"
invoke-static {p0, p1, v0}, Landroid/util/Log;->println(ILjava/lang/String;Ljava/lang/String;)I
.line 402
:cond_38
return-void
.end method
.method private static printMsg(ILjava/lang/String;Ljava/lang/String;)V
.registers 8
.param p0, "type" # I
.param p1, "tag" # Ljava/lang/String;
.param p2, "msg" # Ljava/lang/String;
.line 405
invoke-virtual {p2}, Ljava/lang/String;->length()I
move-result v0
.line 406
.local v0, "len":I
div-int/lit16 v1, v0, 0x44c
.line 407
.local v1, "countOfSub":I
if-lez v1, :cond_24
.line 408
const/4 v2, 0x0
.line 409
.local v2, "index":I
const/4 v3, 0x0
.local v3, "i":I
:goto_a
if-ge v3, v1, :cond_1a
.line 410
add-int/lit16 v4, v2, 0x44c
invoke-virtual {p2, v2, v4}, Ljava/lang/String;->substring(II)Ljava/lang/String;
move-result-object v4
invoke-static {p0, p1, v4}, Lcom/blankj/utilcode/util/LogUtils;->printSubMsg(ILjava/lang/String;Ljava/lang/String;)V
.line 411
add-int/lit16 v2, v2, 0x44c
.line 409
add-int/lit8 v3, v3, 0x1
goto :goto_a
.line 413
.end local v3 # "i":I
:cond_1a
if-eq v2, v0, :cond_23
.line 414
invoke-virtual {p2, v2, v0}, Ljava/lang/String;->substring(II)Ljava/lang/String;
move-result-object v3
invoke-static {p0, p1, v3}, Lcom/blankj/utilcode/util/LogUtils;->printSubMsg(ILjava/lang/String;Ljava/lang/String;)V
.line 416
.end local v2 # "index":I
:cond_23
goto :goto_27
.line 417
:cond_24
invoke-static {p0, p1, p2}, Lcom/blankj/utilcode/util/LogUtils;->printSubMsg(ILjava/lang/String;Ljava/lang/String;)V
.line 419
:goto_27
return-void
.end method
.method private static printSingleTagMsg(ILjava/lang/String;Ljava/lang/String;)V
.registers 13
.param p0, "type" # I
.param p1, "tag" # Ljava/lang/String;
.param p2, "msg" # Ljava/lang/String;
.line 464
invoke-virtual {p2}, Ljava/lang/String;->length()I
move-result v0
.line 465
.local v0, "len":I
sget-object v1, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v1}, Lcom/blankj/utilcode/util/LogUtils$Config;->isLogBorderSwitch()Z
move-result v1
const-string/jumbo v2, "\u2514\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500"
const/16 v3, 0x44c
if-eqz v1, :cond_19
invoke-virtual {v2}, Ljava/lang/String;->length()I
move-result v1
sub-int v1, v0, v1
div-int/2addr v1, v3
goto :goto_1b
:cond_19
div-int/lit16 v1, v0, 0x44c
.line 466
.local v1, "countOfSub":I
:goto_1b
if-lez v1, :cond_fe
.line 467
sget-object v4, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v4}, Lcom/blankj/utilcode/util/LogUtils$Config;->isLogBorderSwitch()Z
move-result v4
const/4 v5, 0x0
const-string v6, " "
if-eqz v4, :cond_b2
.line 468
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {p2, v5, v3}, Ljava/lang/String;->substring(II)Ljava/lang/String;
move-result-object v3
invoke-virtual {v4, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v3, Lcom/blankj/utilcode/util/LogUtils;->LINE_SEP:Ljava/lang/String;
invoke-virtual {v4, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-static {p0, p1, v3}, Landroid/util/Log;->println(ILjava/lang/String;Ljava/lang/String;)I
.line 469
const/16 v3, 0x44c
.line 470
.local v3, "index":I
const/4 v4, 0x1
.local v4, "i":I
:goto_46
const-string/jumbo v5, "\u2502 "
const-string/jumbo v7, "\u250c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500"
if-ge v4, v1, :cond_83
.line 471
new-instance v8, Ljava/lang/StringBuilder;
invoke-direct {v8}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v8, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v9, Lcom/blankj/utilcode/util/LogUtils;->LINE_SEP:Ljava/lang/String;
invoke-virtual {v8, v9}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v8, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v7, Lcom/blankj/utilcode/util/LogUtils;->LINE_SEP:Ljava/lang/String;
invoke-virtual {v8, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v8, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
add-int/lit16 v5, v3, 0x44c
.line 472
invoke-virtual {p2, v3, v5}, Ljava/lang/String;->substring(II)Ljava/lang/String;
move-result-object v5
invoke-virtual {v8, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v5, Lcom/blankj/utilcode/util/LogUtils;->LINE_SEP:Ljava/lang/String;
invoke-virtual {v8, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v8, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v8}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v5
.line 471
invoke-static {p0, p1, v5}, Landroid/util/Log;->println(ILjava/lang/String;Ljava/lang/String;)I
.line 474
add-int/lit16 v3, v3, 0x44c
.line 470
add-int/lit8 v4, v4, 0x1
goto :goto_46
.line 476
.end local v4 # "i":I
:cond_83
invoke-virtual {v2}, Ljava/lang/String;->length()I
move-result v2
sub-int v2, v0, v2
if-eq v3, v2, :cond_b1
.line 477
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v2, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v4, Lcom/blankj/utilcode/util/LogUtils;->LINE_SEP:Ljava/lang/String;
invoke-virtual {v2, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v4, Lcom/blankj/utilcode/util/LogUtils;->LINE_SEP:Ljava/lang/String;
invoke-virtual {v2, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 478
invoke-virtual {p2, v3, v0}, Ljava/lang/String;->substring(II)Ljava/lang/String;
move-result-object v4
invoke-virtual {v2, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
.line 477
invoke-static {p0, p1, v2}, Landroid/util/Log;->println(ILjava/lang/String;Ljava/lang/String;)I
.line 480
.end local v3 # "index":I
:cond_b1
goto :goto_101
.line 481
:cond_b2
invoke-virtual {p2, v5, v3}, Ljava/lang/String;->substring(II)Ljava/lang/String;
move-result-object v2
invoke-static {p0, p1, v2}, Landroid/util/Log;->println(ILjava/lang/String;Ljava/lang/String;)I
.line 482
const/16 v2, 0x44c
.line 483
.local v2, "index":I
const/4 v3, 0x1
.local v3, "i":I
:goto_bc
if-ge v3, v1, :cond_e0
.line 484
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v4, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v5, Lcom/blankj/utilcode/util/LogUtils;->LINE_SEP:Ljava/lang/String;
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
add-int/lit16 v5, v2, 0x44c
.line 485
invoke-virtual {p2, v2, v5}, Ljava/lang/String;->substring(II)Ljava/lang/String;
move-result-object v5
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
.line 484
invoke-static {p0, p1, v4}, Landroid/util/Log;->println(ILjava/lang/String;Ljava/lang/String;)I
.line 486
add-int/lit16 v2, v2, 0x44c
.line 483
add-int/lit8 v3, v3, 0x1
goto :goto_bc
.line 488
.end local v3 # "i":I
:cond_e0
if-eq v2, v0, :cond_fd
.line 489
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v3, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v4, Lcom/blankj/utilcode/util/LogUtils;->LINE_SEP:Ljava/lang/String;
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p2, v2, v0}, Ljava/lang/String;->substring(II)Ljava/lang/String;
move-result-object v4
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-static {p0, p1, v3}, Landroid/util/Log;->println(ILjava/lang/String;Ljava/lang/String;)I
.line 491
.end local v2 # "index":I
:cond_fd
goto :goto_101
.line 493
:cond_fe
invoke-static {p0, p1, p2}, Landroid/util/Log;->println(ILjava/lang/String;Ljava/lang/String;)I
.line 495
:goto_101
return-void
.end method
.method private static printSubMsg(ILjava/lang/String;Ljava/lang/String;)V
.registers 10
.param p0, "type" # I
.param p1, "tag" # Ljava/lang/String;
.param p2, "msg" # Ljava/lang/String;
.line 422
sget-object v0, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v0}, Lcom/blankj/utilcode/util/LogUtils$Config;->isLogBorderSwitch()Z
move-result v0
if-nez v0, :cond_c
.line 423
invoke-static {p0, p1, p2}, Landroid/util/Log;->println(ILjava/lang/String;Ljava/lang/String;)I
.line 424
return-void
.line 426
:cond_c
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
.line 427
.local v0, "sb":Ljava/lang/StringBuilder;
sget-object v1, Lcom/blankj/utilcode/util/LogUtils;->LINE_SEP:Ljava/lang/String;
invoke-virtual {p2, v1}, Ljava/lang/String;->split(Ljava/lang/String;)[Ljava/lang/String;
move-result-object v1
.line 428
.local v1, "lines":[Ljava/lang/String;
array-length v2, v1
const/4 v3, 0x0
:goto_19
if-ge v3, v2, :cond_35
aget-object v4, v1, v3
.line 429
.local v4, "line":Ljava/lang/String;
new-instance v5, Ljava/lang/StringBuilder;
invoke-direct {v5}, Ljava/lang/StringBuilder;-><init>()V
const-string/jumbo v6, "\u2502 "
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v5, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v5}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v5
invoke-static {p0, p1, v5}, Landroid/util/Log;->println(ILjava/lang/String;Ljava/lang/String;)I
.line 428
.end local v4 # "line":Ljava/lang/String;
add-int/lit8 v3, v3, 0x1
goto :goto_19
.line 431
:cond_35
return-void
.end method
.method private static varargs processBody(I[Ljava/lang/Object;)Ljava/lang/String;
.registers 8
.param p0, "type" # I
.param p1, "contents" # [Ljava/lang/Object;
.line 334
const-string v0, "null"
.line 335
.local v0, "body":Ljava/lang/String;
if-eqz p1, :cond_45
.line 336
array-length v1, p1
const/4 v2, 0x1
if-ne v1, v2, :cond_10
.line 337
const/4 v1, 0x0
aget-object v1, p1, v1
invoke-static {p0, v1}, Lcom/blankj/utilcode/util/LogUtils;->formatObject(ILjava/lang/Object;)Ljava/lang/String;
move-result-object v0
goto :goto_45
.line 339
:cond_10
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
.line 340
.local v1, "sb":Ljava/lang/StringBuilder;
const/4 v2, 0x0
.local v2, "i":I
array-length v3, p1
.local v3, "len":I
:goto_17
if-ge v2, v3, :cond_41
.line 341
aget-object v4, p1, v2
.line 342
.local v4, "content":Ljava/lang/Object;
const-string v5, "args"
invoke-virtual {v1, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 343
const-string v5, "["
invoke-virtual {v1, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 344
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
.line 345
const-string v5, "]"
invoke-virtual {v1, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 346
const-string v5, " = "
invoke-virtual {v1, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 347
invoke-static {v4}, Lcom/blankj/utilcode/util/LogUtils;->formatObject(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v5
invoke-virtual {v1, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v5, Lcom/blankj/utilcode/util/LogUtils;->LINE_SEP:Ljava/lang/String;
.line 348
invoke-virtual {v1, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 340
.end local v4 # "content":Ljava/lang/Object;
add-int/lit8 v2, v2, 0x1
goto :goto_17
.line 350
.end local v2 # "i":I
.end local v3 # "len":I
:cond_41
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
.line 353
.end local v1 # "sb":Ljava/lang/StringBuilder;
:cond_45
:goto_45
invoke-virtual {v0}, Ljava/lang/String;->length()I
move-result v1
if-nez v1, :cond_4e
const-string v1, "log nothing"
goto :goto_4f
:cond_4e
move-object v1, v0
:goto_4f
return-object v1
.end method
.method private static processSingleTagMsg(ILjava/lang/String;[Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
.registers 11
.param p0, "type" # I
.param p1, "tag" # Ljava/lang/String;
.param p2, "head" # [Ljava/lang/String;
.param p3, "msg" # Ljava/lang/String;
.line 437
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
.line 438
.local v0, "sb":Ljava/lang/StringBuilder;
sget-object v1, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v1}, Lcom/blankj/utilcode/util/LogUtils$Config;->isLogBorderSwitch()Z
move-result v1
const-string v2, " "
const/4 v3, 0x0
if-eqz v1, :cond_67
.line 439
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v1, Lcom/blankj/utilcode/util/LogUtils;->LINE_SEP:Ljava/lang/String;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 440
const-string/jumbo v1, "\u250c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v1, Lcom/blankj/utilcode/util/LogUtils;->LINE_SEP:Ljava/lang/String;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 441
const-string/jumbo v1, "\u2502 "
if-eqz p2, :cond_47
.line 442
array-length v2, p2
const/4 v4, 0x0
:goto_2a
if-ge v4, v2, :cond_3c
aget-object v5, p2, v4
.line 443
.local v5, "aHead":Ljava/lang/String;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v6, Lcom/blankj/utilcode/util/LogUtils;->LINE_SEP:Ljava/lang/String;
invoke-virtual {v0, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 442
.end local v5 # "aHead":Ljava/lang/String;
add-int/lit8 v4, v4, 0x1
goto :goto_2a
.line 445
:cond_3c
const-string/jumbo v2, "\u251c\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504\u2504"
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v2, Lcom/blankj/utilcode/util/LogUtils;->LINE_SEP:Ljava/lang/String;
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 447
:cond_47
sget-object v2, Lcom/blankj/utilcode/util/LogUtils;->LINE_SEP:Ljava/lang/String;
invoke-virtual {p3, v2}, Ljava/lang/String;->split(Ljava/lang/String;)[Ljava/lang/String;
move-result-object v2
array-length v4, v2
:goto_4e
if-ge v3, v4, :cond_60
aget-object v5, v2, v3
.line 448
.local v5, "line":Ljava/lang/String;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v6, Lcom/blankj/utilcode/util/LogUtils;->LINE_SEP:Ljava/lang/String;
invoke-virtual {v0, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 447
.end local v5 # "line":Ljava/lang/String;
add-int/lit8 v3, v3, 0x1
goto :goto_4e
.line 450
:cond_60
const-string/jumbo v1, "\u2514\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500"
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
goto :goto_84
.line 452
:cond_67
if-eqz p2, :cond_81
.line 453
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v1, Lcom/blankj/utilcode/util/LogUtils;->LINE_SEP:Ljava/lang/String;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 454
array-length v1, p2
:goto_72
if-ge v3, v1, :cond_81
aget-object v2, p2, v3
.line 455
.local v2, "aHead":Ljava/lang/String;
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
sget-object v4, Lcom/blankj/utilcode/util/LogUtils;->LINE_SEP:Ljava/lang/String;
invoke-virtual {v0, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 454
.end local v2 # "aHead":Ljava/lang/String;
add-int/lit8 v3, v3, 0x1
goto :goto_72
.line 458
:cond_81
invoke-virtual {v0, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 460
:goto_84
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
return-object v1
.end method
.method private static processTagAndHead(Ljava/lang/String;)Lcom/blankj/utilcode/util/LogUtils$TagHead;
.registers 23
.param p0, "tag" # Ljava/lang/String;
.line 256
sget-object v0, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
# getter for: Lcom/blankj/utilcode/util/LogUtils$Config;->mTagIsSpace:Z
invoke-static {v0}, Lcom/blankj/utilcode/util/LogUtils$Config;->access$500(Lcom/blankj/utilcode/util/LogUtils$Config;)Z
move-result v0
const-string v1, ": "
const/4 v2, 0x0
if-nez v0, :cond_1b
sget-object v0, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v0}, Lcom/blankj/utilcode/util/LogUtils$Config;->isLogHeadSwitch()Z
move-result v0
if-nez v0, :cond_1b
.line 257
sget-object v0, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v0}, Lcom/blankj/utilcode/util/LogUtils$Config;->getGlobalTag()Ljava/lang/String;
move-result-object v0
.end local p0 # "tag":Ljava/lang/String;
.local v0, "tag":Ljava/lang/String;
goto/16 :goto_179
.line 259
.end local v0 # "tag":Ljava/lang/String;
.restart local p0 # "tag":Ljava/lang/String;
:cond_1b
new-instance v0, Ljava/lang/Throwable;
invoke-direct {v0}, Ljava/lang/Throwable;-><init>()V
invoke-virtual {v0}, Ljava/lang/Throwable;->getStackTrace()[Ljava/lang/StackTraceElement;
move-result-object v0
.line 260
.local v0, "stackTrace":[Ljava/lang/StackTraceElement;
sget-object v3, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v3}, Lcom/blankj/utilcode/util/LogUtils$Config;->getStackOffset()I
move-result v3
const/4 v4, 0x3
add-int/2addr v3, v4
.line 261
.local v3, "stackIndex":I
array-length v5, v0
const/4 v6, -0x1
const/16 v7, 0x2e
const/4 v8, 0x0
if-lt v3, v5, :cond_5c
.line 262
aget-object v4, v0, v4
.line 263
.local v4, "targetElement":Ljava/lang/StackTraceElement;
invoke-static {v4}, Lcom/blankj/utilcode/util/LogUtils;->getFileName(Ljava/lang/StackTraceElement;)Ljava/lang/String;
move-result-object v5
.line 264
.local v5, "fileName":Ljava/lang/String;
sget-object v9, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
# getter for: Lcom/blankj/utilcode/util/LogUtils$Config;->mTagIsSpace:Z
invoke-static {v9}, Lcom/blankj/utilcode/util/LogUtils$Config;->access$500(Lcom/blankj/utilcode/util/LogUtils$Config;)Z
move-result v9
if-eqz v9, :cond_54
invoke-static/range {p0 .. p0}, Lcom/blankj/utilcode/util/LogUtils;->isSpace(Ljava/lang/String;)Z
move-result v9
if-eqz v9, :cond_54
.line 265
invoke-virtual {v5, v7}, Ljava/lang/String;->indexOf(I)I
move-result v7
.line 266
.local v7, "index":I
if-ne v7, v6, :cond_4f
move-object v6, v5
goto :goto_53
:cond_4f
invoke-virtual {v5, v8, v7}, Ljava/lang/String;->substring(II)Ljava/lang/String;
move-result-object v6
.end local p0 # "tag":Ljava/lang/String;
.local v6, "tag":Ljava/lang/String;
:goto_53
goto :goto_56
.line 268
.end local v6 # "tag":Ljava/lang/String;
.end local v7 # "index":I
.restart local p0 # "tag":Ljava/lang/String;
:cond_54
move-object/from16 v6, p0
.end local p0 # "tag":Ljava/lang/String;
.restart local v6 # "tag":Ljava/lang/String;
:goto_56
new-instance v7, Lcom/blankj/utilcode/util/LogUtils$TagHead;
invoke-direct {v7, v6, v2, v1}, Lcom/blankj/utilcode/util/LogUtils$TagHead;-><init>(Ljava/lang/String;[Ljava/lang/String;Ljava/lang/String;)V
return-object v7
.line 270
.end local v4 # "targetElement":Ljava/lang/StackTraceElement;
.end local v5 # "fileName":Ljava/lang/String;
.end local v6 # "tag":Ljava/lang/String;
.restart local p0 # "tag":Ljava/lang/String;
:cond_5c
aget-object v5, v0, v3
.line 271
.local v5, "targetElement":Ljava/lang/StackTraceElement;
invoke-static {v5}, Lcom/blankj/utilcode/util/LogUtils;->getFileName(Ljava/lang/StackTraceElement;)Ljava/lang/String;
move-result-object v9
.line 272
.local v9, "fileName":Ljava/lang/String;
sget-object v10, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
# getter for: Lcom/blankj/utilcode/util/LogUtils$Config;->mTagIsSpace:Z
invoke-static {v10}, Lcom/blankj/utilcode/util/LogUtils$Config;->access$500(Lcom/blankj/utilcode/util/LogUtils$Config;)Z
move-result v10
if-eqz v10, :cond_7d
invoke-static/range {p0 .. p0}, Lcom/blankj/utilcode/util/LogUtils;->isSpace(Ljava/lang/String;)Z
move-result v10
if-eqz v10, :cond_7d
.line 273
invoke-virtual {v9, v7}, Ljava/lang/String;->indexOf(I)I
move-result v7
.line 274
.restart local v7 # "index":I
if-ne v7, v6, :cond_78
move-object v6, v9
goto :goto_7c
:cond_78
invoke-virtual {v9, v8, v7}, Ljava/lang/String;->substring(II)Ljava/lang/String;
move-result-object v6
.end local p0 # "tag":Ljava/lang/String;
.restart local v6 # "tag":Ljava/lang/String;
:goto_7c
goto :goto_7f
.line 276
.end local v6 # "tag":Ljava/lang/String;
.end local v7 # "index":I
.restart local p0 # "tag":Ljava/lang/String;
:cond_7d
move-object/from16 v6, p0
.end local p0 # "tag":Ljava/lang/String;
.restart local v6 # "tag":Ljava/lang/String;
:goto_7f
sget-object v7, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v7}, Lcom/blankj/utilcode/util/LogUtils$Config;->isLogHeadSwitch()Z
move-result v7
if-eqz v7, :cond_176
.line 277
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/Thread;->getName()Ljava/lang/String;
move-result-object v1
.line 278
.local v1, "tName":Ljava/lang/String;
new-instance v2, Ljava/util/Formatter;
invoke-direct {v2}, Ljava/util/Formatter;-><init>()V
const/4 v7, 0x5
new-array v10, v7, [Ljava/lang/Object;
aput-object v1, v10, v8
.line 281
invoke-virtual {v5}, Ljava/lang/StackTraceElement;->getClassName()Ljava/lang/String;
move-result-object v11
const/4 v12, 0x1
aput-object v11, v10, v12
.line 282
invoke-virtual {v5}, Ljava/lang/StackTraceElement;->getMethodName()Ljava/lang/String;
move-result-object v11
const/4 v13, 0x2
aput-object v11, v10, v13
aput-object v9, v10, v4
.line 284
invoke-virtual {v5}, Ljava/lang/StackTraceElement;->getLineNumber()I
move-result v11
invoke-static {v11}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v11
const/4 v14, 0x4
aput-object v11, v10, v14
.line 279
const-string v11, "%s, %s.%s(%s:%d)"
invoke-virtual {v2, v11, v10}, Ljava/util/Formatter;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/util/Formatter;
move-result-object v2
.line 285
invoke-virtual {v2}, Ljava/util/Formatter;->toString()Ljava/lang/String;
move-result-object v2
.line 286
.local v2, "head":Ljava/lang/String;
new-instance v10, Ljava/lang/StringBuilder;
invoke-direct {v10}, Ljava/lang/StringBuilder;-><init>()V
const-string v11, " ["
invoke-virtual {v10, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v10, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v11, "]: "
invoke-virtual {v10, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v10}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v10
.line 287
.local v10, "fileHead":Ljava/lang/String;
sget-object v11, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v11}, Lcom/blankj/utilcode/util/LogUtils$Config;->getStackDeep()I
move-result v11
if-gt v11, v12, :cond_e6
.line 288
new-instance v4, Lcom/blankj/utilcode/util/LogUtils$TagHead;
new-array v7, v12, [Ljava/lang/String;
aput-object v2, v7, v8
invoke-direct {v4, v6, v7, v10}, Lcom/blankj/utilcode/util/LogUtils$TagHead;-><init>(Ljava/lang/String;[Ljava/lang/String;Ljava/lang/String;)V
return-object v4
.line 290
:cond_e6
sget-object v11, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
.line 292
invoke-virtual {v11}, Lcom/blankj/utilcode/util/LogUtils$Config;->getStackDeep()I
move-result v11
array-length v15, v0
sub-int/2addr v15, v3
.line 291
invoke-static {v11, v15}, Ljava/lang/Math;->min(II)I
move-result v11
new-array v11, v11, [Ljava/lang/String;
.line 295
.local v11, "consoleHead":[Ljava/lang/String;
aput-object v2, v11, v8
.line 296
invoke-virtual {v1}, Ljava/lang/String;->length()I
move-result v15
add-int/2addr v15, v13
.line 297
.local v15, "spaceLen":I
new-instance v14, Ljava/util/Formatter;
invoke-direct {v14}, Ljava/util/Formatter;-><init>()V
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v13, "%"
invoke-virtual {v4, v13}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4, v15}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v13, "s"
invoke-virtual {v4, v13}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
new-array v13, v12, [Ljava/lang/Object;
const-string v18, ""
aput-object v18, v13, v8
invoke-virtual {v14, v4, v13}, Ljava/util/Formatter;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/util/Formatter;
move-result-object v4
invoke-virtual {v4}, Ljava/util/Formatter;->toString()Ljava/lang/String;
move-result-object v4
.line 298
.local v4, "space":Ljava/lang/String;
const/4 v13, 0x1
.local v13, "i":I
array-length v14, v11
.local v14, "len":I
:goto_126
if-ge v13, v14, :cond_16e
.line 299
add-int v18, v13, v3
aget-object v5, v0, v18
.line 300
new-instance v12, Ljava/util/Formatter;
invoke-direct {v12}, Ljava/util/Formatter;-><init>()V
move-object/from16 v19, v0
.end local v0 # "stackTrace":[Ljava/lang/StackTraceElement;
.local v19, "stackTrace":[Ljava/lang/StackTraceElement;
new-array v0, v7, [Ljava/lang/Object;
aput-object v4, v0, v8
.line 303
invoke-virtual {v5}, Ljava/lang/StackTraceElement;->getClassName()Ljava/lang/String;
move-result-object v20
const/16 v18, 0x1
aput-object v20, v0, v18
.line 304
invoke-virtual {v5}, Ljava/lang/StackTraceElement;->getMethodName()Ljava/lang/String;
move-result-object v20
const/16 v17, 0x2
aput-object v20, v0, v17
.line 305
invoke-static {v5}, Lcom/blankj/utilcode/util/LogUtils;->getFileName(Ljava/lang/StackTraceElement;)Ljava/lang/String;
move-result-object v20
const/16 v16, 0x3
aput-object v20, v0, v16
.line 306
invoke-virtual {v5}, Ljava/lang/StackTraceElement;->getLineNumber()I
move-result v20
invoke-static/range {v20 .. v20}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v20
const/16 v21, 0x4
aput-object v20, v0, v21
.line 301
const-string v7, "%s%s.%s(%s:%d)"
invoke-virtual {v12, v7, v0}, Ljava/util/Formatter;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/util/Formatter;
move-result-object v0
.line 307
invoke-virtual {v0}, Ljava/util/Formatter;->toString()Ljava/lang/String;
move-result-object v0
aput-object v0, v11, v13
.line 298
add-int/lit8 v13, v13, 0x1
move-object/from16 v0, v19
const/4 v7, 0x5
const/4 v12, 0x1
goto :goto_126
.end local v19 # "stackTrace":[Ljava/lang/StackTraceElement;
.restart local v0 # "stackTrace":[Ljava/lang/StackTraceElement;
:cond_16e
move-object/from16 v19, v0
.line 309
.end local v0 # "stackTrace":[Ljava/lang/StackTraceElement;
.end local v13 # "i":I
.end local v14 # "len":I
.restart local v19 # "stackTrace":[Ljava/lang/StackTraceElement;
new-instance v0, Lcom/blankj/utilcode/util/LogUtils$TagHead;
invoke-direct {v0, v6, v11, v10}, Lcom/blankj/utilcode/util/LogUtils$TagHead;-><init>(Ljava/lang/String;[Ljava/lang/String;Ljava/lang/String;)V
return-object v0
.line 276
.end local v1 # "tName":Ljava/lang/String;
.end local v2 # "head":Ljava/lang/String;
.end local v4 # "space":Ljava/lang/String;
.end local v10 # "fileHead":Ljava/lang/String;
.end local v11 # "consoleHead":[Ljava/lang/String;
.end local v15 # "spaceLen":I
.end local v19 # "stackTrace":[Ljava/lang/StackTraceElement;
.restart local v0 # "stackTrace":[Ljava/lang/StackTraceElement;
:cond_176
move-object/from16 v19, v0
.end local v0 # "stackTrace":[Ljava/lang/StackTraceElement;
.restart local v19 # "stackTrace":[Ljava/lang/StackTraceElement;
move-object v0, v6
.line 313
.end local v3 # "stackIndex":I
.end local v5 # "targetElement":Ljava/lang/StackTraceElement;
.end local v6 # "tag":Ljava/lang/String;
.end local v9 # "fileName":Ljava/lang/String;
.end local v19 # "stackTrace":[Ljava/lang/StackTraceElement;
.local v0, "tag":Ljava/lang/String;
:goto_179
new-instance v3, Lcom/blankj/utilcode/util/LogUtils$TagHead;
invoke-direct {v3, v0, v2, v1}, Lcom/blankj/utilcode/util/LogUtils$TagHead;-><init>(Ljava/lang/String;[Ljava/lang/String;Ljava/lang/String;)V
return-object v3
.end method
.method public static varargs v([Ljava/lang/Object;)V
.registers 3
.param p0, "contents" # [Ljava/lang/Object;
.line 124
sget-object v0, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v0}, Lcom/blankj/utilcode/util/LogUtils$Config;->getGlobalTag()Ljava/lang/String;
move-result-object v0
const/4 v1, 0x2
invoke-static {v1, v0, p0}, Lcom/blankj/utilcode/util/LogUtils;->log(ILjava/lang/String;[Ljava/lang/Object;)V
.line 125
return-void
.end method
.method public static varargs vTag(Ljava/lang/String;[Ljava/lang/Object;)V
.registers 3
.param p0, "tag" # Ljava/lang/String;
.param p1, "contents" # [Ljava/lang/Object;
.line 128
const/4 v0, 0x2
invoke-static {v0, p0, p1}, Lcom/blankj/utilcode/util/LogUtils;->log(ILjava/lang/String;[Ljava/lang/Object;)V
.line 129
return-void
.end method
.method public static varargs w([Ljava/lang/Object;)V
.registers 3
.param p0, "contents" # [Ljava/lang/Object;
.line 148
sget-object v0, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v0}, Lcom/blankj/utilcode/util/LogUtils$Config;->getGlobalTag()Ljava/lang/String;
move-result-object v0
const/4 v1, 0x5
invoke-static {v1, v0, p0}, Lcom/blankj/utilcode/util/LogUtils;->log(ILjava/lang/String;[Ljava/lang/Object;)V
.line 149
return-void
.end method
.method public static varargs wTag(Ljava/lang/String;[Ljava/lang/Object;)V
.registers 3
.param p0, "tag" # Ljava/lang/String;
.param p1, "contents" # [Ljava/lang/Object;
.line 152
const/4 v0, 0x5
invoke-static {v0, p0, p1}, Lcom/blankj/utilcode/util/LogUtils;->log(ILjava/lang/String;[Ljava/lang/Object;)V
.line 153
return-void
.end method
.method public static xml(ILjava/lang/String;)V
.registers 6
.param p0, "type" # I
.param p1, "content" # Ljava/lang/String;
.line 208
or-int/lit8 v0, p0, 0x30
sget-object v1, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v1}, Lcom/blankj/utilcode/util/LogUtils$Config;->getGlobalTag()Ljava/lang/String;
move-result-object v1
const/4 v2, 0x1
new-array v2, v2, [Ljava/lang/Object;
const/4 v3, 0x0
aput-object p1, v2, v3
invoke-static {v0, v1, v2}, Lcom/blankj/utilcode/util/LogUtils;->log(ILjava/lang/String;[Ljava/lang/Object;)V
.line 209
return-void
.end method
.method public static xml(ILjava/lang/String;Ljava/lang/String;)V
.registers 6
.param p0, "type" # I
.param p1, "tag" # Ljava/lang/String;
.param p2, "content" # Ljava/lang/String;
.line 216
or-int/lit8 v0, p0, 0x30
const/4 v1, 0x1
new-array v1, v1, [Ljava/lang/Object;
const/4 v2, 0x0
aput-object p2, v1, v2
invoke-static {v0, p1, v1}, Lcom/blankj/utilcode/util/LogUtils;->log(ILjava/lang/String;[Ljava/lang/Object;)V
.line 217
return-void
.end method
.method public static xml(Ljava/lang/String;)V
.registers 4
.param p0, "content" # Ljava/lang/String;
.line 204
sget-object v0, Lcom/blankj/utilcode/util/LogUtils;->CONFIG:Lcom/blankj/utilcode/util/LogUtils$Config;
invoke-virtual {v0}, Lcom/blankj/utilcode/util/LogUtils$Config;->getGlobalTag()Ljava/lang/String;
move-result-object v0
const/4 v1, 0x1
new-array v1, v1, [Ljava/lang/Object;
const/4 v2, 0x0
aput-object p0, v1, v2
const/16 v2, 0x33
invoke-static {v2, v0, v1}, Lcom/blankj/utilcode/util/LogUtils;->log(ILjava/lang/String;[Ljava/lang/Object;)V
.line 205
return-void
.end method
.method public static xml(Ljava/lang/String;Ljava/lang/String;)V
.registers 4
.param p0, "tag" # Ljava/lang/String;
.param p1, "content" # Ljava/lang/String;
.line 212
const/4 v0, 0x1
new-array v0, v0, [Ljava/lang/Object;
const/4 v1, 0x0
aput-object p1, v0, v1
const/16 v1, 0x33
invoke-static {v1, p0, v0}, Lcom/blankj/utilcode/util/LogUtils;->log(ILjava/lang/String;[Ljava/lang/Object;)V
.line 213
return-void
.end method