h.smali

.class public final Lcom/imo/android/imoim/techinfocollector/a/h;
.super Lcom/imo/android/imoim/techinfocollector/a/e;
.source "SourceFile"


# annotations
.annotation system Ldalvik/annotation/MemberClasses;
    value = {
        Lcom/imo/android/imoim/techinfocollector/a/h$a;
    }
.end annotation

.annotation system Ldalvik/annotation/Signature;
    value = {
        "Lcom/imo/android/imoim/techinfocollector/a/e<",
        "Ljava/lang/String;",
        ">;"
    }
.end annotation


# static fields
.field public static c:Lcom/imo/android/imoim/network/ConnectData3;

.field public static d:Ljava/util/Map;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/Map<",
            "Ljava/lang/String;",
            "Lcom/imo/android/imoim/techinfocollector/a/h$a;",
            ">;"
        }
    .end annotation
.end field

.field public static e:J

.field public static f:J

.field private static h:Ljava/util/concurrent/atomic/AtomicLong;

.field private static i:Ljava/util/concurrent/atomic/AtomicLong;

.field private static j:Ljava/util/concurrent/atomic/AtomicLong;

.field private static k:Ljava/util/concurrent/atomic/AtomicLong;

.field private static n:I


# instance fields
.field private g:Ljava/text/SimpleDateFormat;

.field private l:J

.field private m:J


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

    .line 33
    new-instance v0, Ljava/util/concurrent/ConcurrentHashMap;

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

    sput-object v0, Lcom/imo/android/imoim/techinfocollector/a/h;->d:Ljava/util/Map;

    .line 35
    new-instance v0, Ljava/util/concurrent/atomic/AtomicLong;

    const-wide/16 v1, 0x0

    invoke-direct {v0, v1, v2}, Ljava/util/concurrent/atomic/AtomicLong;-><init>(J)V

    sput-object v0, Lcom/imo/android/imoim/techinfocollector/a/h;->h:Ljava/util/concurrent/atomic/AtomicLong;

    .line 36
    new-instance v0, Ljava/util/concurrent/atomic/AtomicLong;

    invoke-direct {v0, v1, v2}, Ljava/util/concurrent/atomic/AtomicLong;-><init>(J)V

    sput-object v0, Lcom/imo/android/imoim/techinfocollector/a/h;->i:Ljava/util/concurrent/atomic/AtomicLong;

    .line 37
    new-instance v0, Ljava/util/concurrent/atomic/AtomicLong;

    invoke-direct {v0, v1, v2}, Ljava/util/concurrent/atomic/AtomicLong;-><init>(J)V

    sput-object v0, Lcom/imo/android/imoim/techinfocollector/a/h;->j:Ljava/util/concurrent/atomic/AtomicLong;

    .line 38
    new-instance v0, Ljava/util/concurrent/atomic/AtomicLong;

    invoke-direct {v0, v1, v2}, Ljava/util/concurrent/atomic/AtomicLong;-><init>(J)V

    sput-object v0, Lcom/imo/android/imoim/techinfocollector/a/h;->k:Ljava/util/concurrent/atomic/AtomicLong;

    const-wide/16 v0, -0x1

    .line 43
    sput-wide v0, Lcom/imo/android/imoim/techinfocollector/a/h;->e:J

    .line 44
    sput-wide v0, Lcom/imo/android/imoim/techinfocollector/a/h;->f:J

    return-void
.end method

.method public constructor <init>(Lcom/imo/android/imoim/techinfocollector/a/f;)V
    .registers 4

    const/4 v0, 0x2

    .line 49
    invoke-direct {p0, v0, p1}, Lcom/imo/android/imoim/techinfocollector/a/e;-><init>(ILcom/imo/android/imoim/techinfocollector/a/f;)V

    .line 30
    new-instance p1, Ljava/text/SimpleDateFormat;

    invoke-static {}, Ljava/util/Locale;->getDefault()Ljava/util/Locale;

    move-result-object v0

    const-string v1, "HH:mm:ss.SSS"

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

    iput-object p1, p0, Lcom/imo/android/imoim/techinfocollector/a/h;->g:Ljava/text/SimpleDateFormat;

    const-wide/16 v0, 0x0

    .line 40
    iput-wide v0, p0, Lcom/imo/android/imoim/techinfocollector/a/h;->l:J

    .line 41
    iput-wide v0, p0, Lcom/imo/android/imoim/techinfocollector/a/h;->m:J

    .line 51
    invoke-static {}, Landroid/os/Process;->myUid()I

    move-result p1

    sput p1, Lcom/imo/android/imoim/techinfocollector/a/h;->n:I

    return-void
.end method

.method public static a(Ljava/lang/String;I)V
    .registers 3

    const/4 v0, 0x1

    .line 55
    invoke-static {p0, p1, v0}, Lcom/imo/android/imoim/techinfocollector/a/h;->a(Ljava/lang/String;II)V

    return-void
.end method

.method private static a(Ljava/lang/String;II)V
    .registers 6

    .line 71
    sget-object v0, Lcom/imo/android/imoim/techinfocollector/a/h;->d:Ljava/util/Map;

    new-instance v1, Ljava/lang/StringBuilder;

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

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

    const-string v2, ":"

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

    invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;

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

    move-result-object v1

    new-instance v2, Lcom/imo/android/imoim/techinfocollector/a/h$a;

    invoke-direct {v2, p0, p1, p2}, Lcom/imo/android/imoim/techinfocollector/a/h$a;-><init>(Ljava/lang/String;II)V

    invoke-interface {v0, v1, v2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    return-void
.end method

.method public static b()V
    .registers 1

    .line 173
    sget-object v0, Lcom/imo/android/imoim/techinfocollector/a/h;->h:Ljava/util/concurrent/atomic/AtomicLong;

    invoke-virtual {v0}, Ljava/util/concurrent/atomic/AtomicLong;->incrementAndGet()J

    return-void
.end method

.method public static b(Ljava/lang/String;I)V
    .registers 3

    const/4 v0, 0x3

    .line 59
    invoke-static {p0, p1, v0}, Lcom/imo/android/imoim/techinfocollector/a/h;->a(Ljava/lang/String;II)V

    return-void
.end method

.method public static c()V
    .registers 1

    .line 177
    sget-object v0, Lcom/imo/android/imoim/techinfocollector/a/h;->i:Ljava/util/concurrent/atomic/AtomicLong;

    invoke-virtual {v0}, Ljava/util/concurrent/atomic/AtomicLong;->incrementAndGet()J

    return-void
.end method

.method public static c(Ljava/lang/String;I)V
    .registers 3

    const/4 v0, 0x2

    .line 63
    invoke-static {p0, p1, v0}, Lcom/imo/android/imoim/techinfocollector/a/h;->a(Ljava/lang/String;II)V

    return-void
.end method

.method public static d()V
    .registers 1

    .line 181
    sget-object v0, Lcom/imo/android/imoim/techinfocollector/a/h;->j:Ljava/util/concurrent/atomic/AtomicLong;

    invoke-virtual {v0}, Ljava/util/concurrent/atomic/AtomicLong;->incrementAndGet()J

    return-void
.end method

.method public static e()V
    .registers 1

    .line 185
    sget-object v0, Lcom/imo/android/imoim/techinfocollector/a/h;->k:Ljava/util/concurrent/atomic/AtomicLong;

    invoke-virtual {v0}, Ljava/util/concurrent/atomic/AtomicLong;->incrementAndGet()J

    return-void
.end method


# virtual methods
.method protected final synthetic a()Ljava/lang/Object;
    .registers 10

    .line 1112
    new-instance v0, Ljava/lang/StringBuilder;

    const-string v1, "Network:\n"

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

    .line 1114
    new-instance v1, Ljava/util/ArrayList;

    sget-object v2, Lcom/imo/android/imoim/techinfocollector/a/h;->d:Ljava/util/Map;

    invoke-interface {v2}, Ljava/util/Map;->values()Ljava/util/Collection;

    move-result-object v2

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

    .line 1115
    new-instance v2, Lcom/imo/android/imoim/techinfocollector/a/h$1;

    invoke-direct {v2, p0}, Lcom/imo/android/imoim/techinfocollector/a/h$1;-><init>(Lcom/imo/android/imoim/techinfocollector/a/h;)V

    invoke-static {v1, v2}, Ljava/util/Collections;->sort(Ljava/util/List;Ljava/util/Comparator;)V

    .line 1123
    invoke-interface {v1}, Ljava/util/List;->iterator()Ljava/util/Iterator;

    move-result-object v1

    const/4 v2, 0x0

    :cond_1f
    invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z

    move-result v3

    const-string v4, "\n"

    if-eqz v3, :cond_7c

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

    move-result-object v3

    check-cast v3, Lcom/imo/android/imoim/techinfocollector/a/h$a;

    if-eqz v3, :cond_79

    .line 1125
    iget-object v5, p0, Lcom/imo/android/imoim/techinfocollector/a/h;->g:Ljava/text/SimpleDateFormat;

    iget-wide v6, v3, Lcom/imo/android/imoim/techinfocollector/a/h$a;->c:J

    invoke-static {v6, v7}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;

    move-result-object v6

    invoke-virtual {v5, v6}, Ljava/text/SimpleDateFormat;->format(Ljava/lang/Object;)Ljava/lang/String;

    move-result-object v5

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

    const-string v5, " "

    .line 1126
    invoke-virtual {v0, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget v6, v3, Lcom/imo/android/imoim/techinfocollector/a/h$a;->d:I

    const/4 v7, 0x1

    if-eq v6, v7, :cond_5d

    const/4 v7, 0x2

    if-eq v6, v7, :cond_5a

    const/4 v7, 0x3

    if-eq v6, v7, :cond_57

    const/4 v7, 0x4

    if-eq v6, v7, :cond_54

    const-string v6, "unknown"

    goto :goto_5f

    :cond_54
    const-string v6, "closed"

    goto :goto_5f

    :cond_57
    const-string v6, "failed"

    goto :goto_5f

    :cond_5a
    const-string v6, "success"

    goto :goto_5f

    :cond_5d
    const-string v6, "connecting"

    .line 1127
    :goto_5f
    invoke-virtual {v0, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    .line 1128
    invoke-virtual {v0, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget-object v5, v3, Lcom/imo/android/imoim/techinfocollector/a/h$a;->a:Ljava/lang/String;

    .line 1129
    invoke-virtual {v0, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    const-string v5, ":"

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

    iget v3, v3, Lcom/imo/android/imoim/techinfocollector/a/h$a;->b:I

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

    .line 1130
    invoke-virtual {v0, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    add-int/lit8 v2, v2, 0x1

    :cond_79
    const/4 v3, 0x5

    if-lt v2, v3, :cond_1f

    .line 1139
    :cond_7c
    invoke-virtual {v0, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    const-string v1, "using "

    .line 1141
    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    .line 1142
    sget-object v1, Lcom/imo/android/imoim/techinfocollector/a/h;->c:Lcom/imo/android/imoim/network/ConnectData3;

    if-nez v1, :cond_8e

    const-string v1, "Unknown\n\n"

    .line 1143
    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    goto :goto_9a

    .line 1145
    :cond_8e
    invoke-virtual {v1}, Lcom/imo/android/imoim/network/ConnectData3;->toString()Ljava/lang/String;

    move-result-object v1

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

    const-string v1, "\n\n"

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

    .line 1148
    :goto_9a
    sget v1, Lcom/imo/android/imoim/techinfocollector/a/h;->n:I

    invoke-static {v1}, Landroid/net/TrafficStats;->getUidRxBytes(I)J

    move-result-wide v1

    .line 1149
    sget v3, Lcom/imo/android/imoim/techinfocollector/a/h;->n:I

    invoke-static {v3}, Landroid/net/TrafficStats;->getUidTxBytes(I)J

    move-result-wide v5

    const-string v3, "Sent:"

    .line 1151
    invoke-virtual {v0, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget-wide v7, p0, Lcom/imo/android/imoim/techinfocollector/a/h;->m:J

    sub-long v7, v5, v7

    invoke-static {v7, v8}, Lcom/imo/android/imoim/util/ei;->k(J)Ljava/lang/String;

    move-result-object v3

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

    const-string v3, "/s "

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

    const-string v3, "Received:"

    .line 1152
    invoke-virtual {v0, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    iget-wide v7, p0, Lcom/imo/android/imoim/techinfocollector/a/h;->l:J

    sub-long v7, v1, v7

    invoke-static {v7, v8}, Lcom/imo/android/imoim/util/ei;->k(J)Ljava/lang/String;

    move-result-object v3

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

    const-string v3, "/s\n"

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

    const-string v3, "Total Sent:"

    .line 1154
    invoke-virtual {v0, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    sget-wide v7, Lcom/imo/android/imoim/techinfocollector/a/h;->f:J

    sub-long v7, v5, v7

    invoke-static {v7, v8}, Lcom/imo/android/imoim/util/ei;->k(J)Ljava/lang/String;

    move-result-object v3

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

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

    const-string v3, "Total Received:"

    .line 1155
    invoke-virtual {v0, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    sget-wide v7, Lcom/imo/android/imoim/techinfocollector/a/h;->e:J

    sub-long v7, v1, v7

    invoke-static {v7, v8}, Lcom/imo/android/imoim/util/ei;->k(J)Ljava/lang/String;

    move-result-object v3

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

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

    const-string v3, "proto sent:"

    .line 1157
    invoke-virtual {v0, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    sget-object v3, Lcom/imo/android/imoim/techinfocollector/a/h;->h:Ljava/util/concurrent/atomic/AtomicLong;

    .line 1158
    invoke-virtual {v3}, Ljava/util/concurrent/atomic/AtomicLong;->get()J

    move-result-wide v3

    invoke-virtual {v0, v3, v4}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

    const-string v3, " ack:"

    .line 1159
    invoke-virtual {v0, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    sget-object v3, Lcom/imo/android/imoim/techinfocollector/a/h;->j:Ljava/util/concurrent/atomic/AtomicLong;

    .line 1160
    invoke-virtual {v3}, Ljava/util/concurrent/atomic/AtomicLong;->get()J

    move-result-wide v3

    invoke-virtual {v0, v3, v4}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

    const-string v3, " received:"

    .line 1161
    invoke-virtual {v0, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    sget-object v3, Lcom/imo/android/imoim/techinfocollector/a/h;->k:Ljava/util/concurrent/atomic/AtomicLong;

    .line 1162
    invoke-virtual {v3}, Ljava/util/concurrent/atomic/AtomicLong;->get()J

    move-result-wide v3

    invoke-virtual {v0, v3, v4}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

    const-string v3, " coming:"

    .line 1163
    invoke-virtual {v0, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    sget-object v3, Lcom/imo/android/imoim/techinfocollector/a/h;->i:Ljava/util/concurrent/atomic/AtomicLong;

    .line 1164
    invoke-virtual {v3}, Ljava/util/concurrent/atomic/AtomicLong;->get()J

    move-result-wide v3

    invoke-virtual {v0, v3, v4}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

    .line 1166
    iput-wide v5, p0, Lcom/imo/android/imoim/techinfocollector/a/h;->m:J

    .line 1167
    iput-wide v1, p0, Lcom/imo/android/imoim/techinfocollector/a/h;->l:J

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

    move-result-object v0

    return-object v0
.end method