a.smali
.class public final Lcom/imo/android/imoim/a;
.super Ljava/lang/Object;
.source "SourceFile"
# static fields
.field private static a:Ljava/util/concurrent/ConcurrentHashMap;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/concurrent/ConcurrentHashMap<",
"Ljava/lang/String;",
"Ljava/lang/Long;",
">;"
}
.end annotation
.end field
.field private static b:Ljava/util/concurrent/ConcurrentHashMap;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/concurrent/ConcurrentHashMap<",
"Ljava/lang/String;",
"Ljava/util/ArrayList<",
"Ljava/lang/Long;",
">;>;"
}
.end annotation
.end field
.field private static c:Z
# direct methods
.method static constructor <clinit>()V
.registers 1
.line 31
new-instance v0, Ljava/util/concurrent/ConcurrentHashMap;
invoke-direct {v0}, Ljava/util/concurrent/ConcurrentHashMap;-><init>()V
sput-object v0, Lcom/imo/android/imoim/a;->a:Ljava/util/concurrent/ConcurrentHashMap;
.line 32
new-instance v0, Ljava/util/concurrent/ConcurrentHashMap;
invoke-direct {v0}, Ljava/util/concurrent/ConcurrentHashMap;-><init>()V
sput-object v0, Lcom/imo/android/imoim/a;->b:Ljava/util/concurrent/ConcurrentHashMap;
const/4 v0, 0x0
.line 33
sput-boolean v0, Lcom/imo/android/imoim/a;->c:Z
return-void
.end method
.method public constructor <init>()V
.registers 1
.line 15
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
.method public static a()Ljava/util/Map;
.registers 2
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/util/Map<",
"Ljava/lang/String;",
"Ljava/lang/Long;",
">;"
}
.end annotation
.line 37
new-instance v0, Ljava/util/HashMap;
sget-object v1, Lcom/imo/android/imoim/a;->a:Ljava/util/concurrent/ConcurrentHashMap;
invoke-direct {v0, v1}, Ljava/util/HashMap;-><init>(Ljava/util/Map;)V
return-object v0
.end method
.method public static a(Ljava/lang/String;)V
.registers 4
.line 1046
sget-boolean v0, Lcom/imo/android/imoim/a;->c:Z
if-eqz v0, :cond_5
return-void
.line 55
:cond_5
sget-object v0, Lcom/imo/android/imoim/a;->a:Ljava/util/concurrent/ConcurrentHashMap;
invoke-virtual {v0, p0}, Ljava/util/concurrent/ConcurrentHashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
if-eqz v0, :cond_26
.line 56
new-instance v0, Ljava/lang/StringBuilder;
const-string v1, "traceStart: step "
invoke-direct {v0, v1}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v0, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p0, " is exist"
invoke-virtual {v0, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p0
const-string v0, "AppBootTraceStat"
.line 1075
invoke-static {v0, p0}, Lcom/imo/android/imoim/util/bt;->e(Ljava/lang/String;Ljava/lang/String;)V
return-void
.line 59
:cond_26
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v0
.line 61
new-instance v2, Ljava/util/ArrayList;
invoke-direct {v2}, Ljava/util/ArrayList;-><init>()V
.line 62
invoke-static {v0, v1}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v0
invoke-virtual {v2, v0}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
.line 63
sget-object v0, Lcom/imo/android/imoim/a;->b:Ljava/util/concurrent/ConcurrentHashMap;
invoke-virtual {v0, p0, v2}, Ljava/util/concurrent/ConcurrentHashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
return-void
.end method
.method private static a(Ljava/lang/String;Ljava/lang/Long;Ljava/lang/Long;)V
.registers 6
.line 110
sget-object v0, Lcom/imo/android/imoim/a;->a:Ljava/util/concurrent/ConcurrentHashMap;
invoke-virtual {p2}, Ljava/lang/Long;->longValue()J
move-result-wide v1
invoke-virtual {p1}, Ljava/lang/Long;->longValue()J
move-result-wide p1
sub-long/2addr v1, p1
invoke-static {v1, v2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object p1
invoke-virtual {v0, p0, p1}, Ljava/util/concurrent/ConcurrentHashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
return-void
.end method
.method public static b()V
.registers 1
const/4 v0, 0x1
.line 41
sput-boolean v0, Lcom/imo/android/imoim/a;->c:Z
.line 42
sget-object v0, Lcom/imo/android/imoim/a;->a:Ljava/util/concurrent/ConcurrentHashMap;
invoke-virtual {v0}, Ljava/util/concurrent/ConcurrentHashMap;->clear()V
return-void
.end method
.method public static b(Ljava/lang/String;)V
.registers 4
.line 2046
sget-boolean v0, Lcom/imo/android/imoim/a;->c:Z
if-eqz v0, :cond_5
return-void
.line 73
:cond_5
sget-object v0, Lcom/imo/android/imoim/a;->b:Ljava/util/concurrent/ConcurrentHashMap;
invoke-virtual {v0, p0}, Ljava/util/concurrent/ConcurrentHashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/util/ArrayList;
if-eqz v0, :cond_33
.line 74
invoke-virtual {v0}, Ljava/util/ArrayList;->isEmpty()Z
move-result v1
if-eqz v1, :cond_16
goto :goto_33
.line 79
:cond_16
invoke-virtual {v0}, Ljava/util/ArrayList;->size()I
move-result v1
const/4 v2, 0x1
if-le v1, v2, :cond_20
.line 80
invoke-static {p0}, Lcom/imo/android/imoim/a;->c(Ljava/lang/String;)V
:cond_20
const/4 v1, 0x0
.line 83
invoke-virtual {v0, v1}, Ljava/util/ArrayList;->get(I)Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/lang/Long;
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v1
invoke-static {v1, v2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v1
invoke-static {p0, v0, v1}, Lcom/imo/android/imoim/a;->a(Ljava/lang/String;Ljava/lang/Long;Ljava/lang/Long;)V
return-void
.line 75
:cond_33
:goto_33
new-instance v0, Ljava/lang/StringBuilder;
const-string v1, "traceEnd: has not record step "
invoke-direct {v0, v1}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v0, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p0, " start"
invoke-virtual {v0, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p0
const-string v0, "AppBootTraceStat"
.line 2075
invoke-static {v0, p0}, Lcom/imo/android/imoim/util/bt;->e(Ljava/lang/String;Ljava/lang/String;)V
return-void
.end method
.method public static c(Ljava/lang/String;)V
.registers 7
.line 3046
sget-boolean v0, Lcom/imo/android/imoim/a;->c:Z
if-eqz v0, :cond_5
return-void
.line 94
:cond_5
sget-object v0, Lcom/imo/android/imoim/a;->b:Ljava/util/concurrent/ConcurrentHashMap;
invoke-virtual {v0, p0}, Ljava/util/concurrent/ConcurrentHashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/util/ArrayList;
if-eqz v0, :cond_51
.line 95
invoke-virtual {v0}, Ljava/util/ArrayList;->isEmpty()Z
move-result v1
if-eqz v1, :cond_16
goto :goto_51
.line 100
:cond_16
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v1
.line 101
invoke-virtual {v0}, Ljava/util/ArrayList;->size()I
move-result v3
add-int/lit8 v3, v3, -0x1
.line 102
invoke-virtual {v0, v3}, Ljava/util/ArrayList;->get(I)Ljava/lang/Object;
move-result-object v4
check-cast v4, Ljava/lang/Long;
.line 103
invoke-static {v1, v2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v5
invoke-virtual {v0, v5}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
.line 106
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {v0, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p0, "_"
invoke-virtual {v0, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0, v3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v0, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
add-int/lit8 v3, v3, 0x1
invoke-virtual {v0, v3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p0
invoke-static {v1, v2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v0
invoke-static {p0, v4, v0}, Lcom/imo/android/imoim/a;->a(Ljava/lang/String;Ljava/lang/Long;Ljava/lang/Long;)V
return-void
.line 96
:cond_51
:goto_51
new-instance v0, Ljava/lang/StringBuilder;
const-string v1, "traceStepBlock: has not record step "
invoke-direct {v0, v1}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v0, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p0, " start"
invoke-virtual {v0, p0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p0
const-string v0, "AppBootTraceStat"
.line 3075
invoke-static {v0, p0}, Lcom/imo/android/imoim/util/bt;->e(Ljava/lang/String;Ljava/lang/String;)V
return-void
.end method