e.smali

.class final Lcom/baidu/crabsdk/a/e;
.super Ljava/lang/Object;

# interfaces
.implements Landroid/view/Choreographer$FrameCallback;


# annotations
.annotation build Landroid/annotation/TargetApi;
    value = 0x10
.end annotation


# static fields
.field static final a:Lcom/baidu/crabsdk/a/e;


# instance fields
.field private b:Z

.field private c:J

.field private d:J

.field private e:J

.field private f:I


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

    new-instance v0, Lcom/baidu/crabsdk/a/e;

    invoke-direct {v0}, Lcom/baidu/crabsdk/a/e;-><init>()V

    sput-object v0, Lcom/baidu/crabsdk/a/e;->a:Lcom/baidu/crabsdk/a/e;

    return-void
.end method

.method private constructor <init>()V
    .registers 4

    const/4 v2, 0x0

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

    iput-boolean v2, p0, Lcom/baidu/crabsdk/a/e;->b:Z

    const-wide/16 v0, 0x0

    iput-wide v0, p0, Lcom/baidu/crabsdk/a/e;->c:J

    const-wide/32 v0, 0x27bc86a

    iput-wide v0, p0, Lcom/baidu/crabsdk/a/e;->d:J

    const-wide/32 v0, 0xfe5029

    iput-wide v0, p0, Lcom/baidu/crabsdk/a/e;->e:J

    iput v2, p0, Lcom/baidu/crabsdk/a/e;->f:I

    return-void
.end method

.method private a()V
    .registers 3

    const-wide/16 v0, 0x0

    iput-wide v0, p0, Lcom/baidu/crabsdk/a/e;->c:J

    const/4 v0, 0x0

    iput v0, p0, Lcom/baidu/crabsdk/a/e;->f:I

    return-void
.end method

.method static synthetic a(Lcom/baidu/crabsdk/a/e;)V
    .registers 8

    const/4 v1, 0x0

    const/4 v4, 0x1

    invoke-static {}, Lcom/baidu/crabsdk/a/a;->e()Lcom/baidu/crabsdk/a/a;

    move-result-object v0

    invoke-virtual {v0}, Lcom/baidu/crabsdk/a/a;->g()Ljava/util/Map;

    move-result-object v0

    if-nez v0, :cond_12

    const-string v0, "no keyStack; blockRecord = null; not a block!!!"

    invoke-static {v0}, Lcom/baidu/crabsdk/c/a;->t(Ljava/lang/String;)I

    :cond_11
    :goto_11
    return-void

    :cond_12
    new-instance v2, Ljava/lang/StringBuilder;

    const-string v3, "^^ -BlockCanaryCore- ^^"

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

    invoke-virtual {v0}, Ljava/lang/Object;->toString()Ljava/lang/String;

    move-result-object v3

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

    move-result-object v2

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

    move-result-object v2

    invoke-static {v2}, Lcom/baidu/crabsdk/c/a;->s(Ljava/lang/String;)I

    invoke-static {}, Lcom/baidu/crabsdk/a/c;->b()Landroid/content/Context;

    move-result-object v2

    invoke-static {v2, v1, v4}, Lcom/baidu/crabsdk/sender/d;->a(Landroid/content/Context;Ljava/lang/Throwable;Z)Ljava/util/Map;

    move-result-object v2

    invoke-interface {v2, v0}, Ljava/util/Map;->putAll(Ljava/util/Map;)V

    invoke-static {v2}, Lcom/baidu/crabsdk/sender/d;->b(Ljava/util/Map;)V

    invoke-static {v2}, Lcom/baidu/crabsdk/sender/f;->d(Ljava/util/Map;)Ljava/lang/String;

    move-result-object v2

    sget-object v0, Lcom/baidu/crabsdk/a;->d:Ljava/lang/String;

    invoke-static {}, Ljava/util/UUID;->randomUUID()Ljava/util/UUID;

    move-result-object v3

    invoke-virtual {v3}, Ljava/util/UUID;->toString()Ljava/lang/String;

    move-result-object v3

    invoke-static {v0, v3}, Lcom/baidu/crabsdk/c/d;->c(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;

    move-result-object v0

    invoke-static {v2, v0}, Lcom/baidu/crabsdk/c/d;->e(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;

    move-result-object v2

    :try_start_4c
    invoke-static {v0}, Lcom/baidu/crabsdk/c/e;->z(Ljava/lang/String;)Ljava/lang/String;
    :try_end_4f
    .catch Ljava/lang/Exception; {:try_start_4c .. :try_end_4f} :catch_75

    move-result-object v0

    :goto_50
    invoke-static {}, Lcom/baidu/crabsdk/sender/e;->af()V

    invoke-static {}, Lcom/baidu/crabsdk/sender/e;->X()Z

    move-result v3

    if-eqz v3, :cond_11

    const-string v3, "-BlockCanaryCore- switch on -  *^o^* doUploadBlock *^o^*"

    invoke-static {v3}, Lcom/baidu/crabsdk/c/a;->q(Ljava/lang/String;)I

    invoke-static {}, Lcom/baidu/crabsdk/sender/e;->ac()Z

    move-result v3

    if-eqz v3, :cond_ae

    if-eqz v2, :cond_6c

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

    move-result v3

    if-nez v3, :cond_7a

    :cond_6c
    :goto_6c
    invoke-static {v1, v0}, Lcom/baidu/crabsdk/sender/h;->a([BLjava/lang/String;)V
    :try_end_6f
    .catch Ljava/io/UnsupportedEncodingException; {:try_start_66 .. :try_end_6f} :catch_70
    .catch Ljava/io/IOException; {:try_start_66 .. :try_end_6f} :catch_a8

    goto :goto_11

    :catch_70
    move-exception v0

    invoke-virtual {v0}, Ljava/io/UnsupportedEncodingException;->printStackTrace()V

    goto :goto_11

    :catch_75
    move-exception v3

    invoke-virtual {v3}, Ljava/lang/Exception;->printStackTrace()V

    goto :goto_50

    :cond_7a
    :try_start_7a
    sget-boolean v1, Lcom/baidu/crabsdk/a;->G:Z

    if-eqz v1, :cond_a1

    new-instance v1, Ljava/io/ByteArrayOutputStream;

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

    new-instance v3, Ljava/util/zip/DeflaterOutputStream;

    new-instance v4, Ljava/util/zip/Deflater;

    const/16 v5, 0x9

    const/4 v6, 0x1

    invoke-direct {v4, v5, v6}, Ljava/util/zip/Deflater;-><init>(IZ)V

    invoke-direct {v3, v1, v4}, Ljava/util/zip/DeflaterOutputStream;-><init>(Ljava/io/OutputStream;Ljava/util/zip/Deflater;)V

    const-string v4, "UTF-8"

    invoke-virtual {v2, v4}, Ljava/lang/String;->getBytes(Ljava/lang/String;)[B

    move-result-object v2

    invoke-virtual {v3, v2}, Ljava/util/zip/DeflaterOutputStream;->write([B)V

    invoke-virtual {v3}, Ljava/util/zip/DeflaterOutputStream;->close()V

    invoke-virtual {v1}, Ljava/io/ByteArrayOutputStream;->toByteArray()[B

    move-result-object v1

    goto :goto_6c

    :cond_a1
    const-string v1, "UTF-8"

    invoke-virtual {v2, v1}, Ljava/lang/String;->getBytes(Ljava/lang/String;)[B
    :try_end_a6
    .catch Ljava/io/UnsupportedEncodingException; {:try_start_7a .. :try_end_a6} :catch_70
    .catch Ljava/io/IOException; {:try_start_7a .. :try_end_a6} :catch_a8

    move-result-object v1

    goto :goto_6c

    :catch_a8
    move-exception v0

    invoke-virtual {v0}, Ljava/io/IOException;->printStackTrace()V

    goto/16 :goto_11

    :cond_ae
    const-string v0, "CrashSwitch.canBlockUploadToday() == false"

    invoke-static {v0}, Lcom/baidu/crabsdk/c/a;->q(Ljava/lang/String;)I

    invoke-static {}, Lcom/baidu/crabsdk/a/b;->i()Lcom/baidu/crabsdk/a/b;

    move-result-object v0

    invoke-virtual {v0}, Lcom/baidu/crabsdk/a/b;->stop()V

    invoke-virtual {p0}, Lcom/baidu/crabsdk/a/e;->stop()V

    goto/16 :goto_11
.end method


# virtual methods
.method public final doFrame(J)V
    .registers 10

    :try_start_0
    iget-wide v0, p0, Lcom/baidu/crabsdk/a/e;->c:J

    const-wide/16 v2, 0x0

    cmp-long v0, v0, v2

    if-eqz v0, :cond_1c

    iget-wide v0, p0, Lcom/baidu/crabsdk/a/e;->c:J

    sub-long v0, p1, v0

    iget-wide v2, p0, Lcom/baidu/crabsdk/a/e;->d:J

    cmp-long v2, v0, v2

    if-lez v2, :cond_28

    iget v2, p0, Lcom/baidu/crabsdk/a/e;->f:I

    int-to-long v2, v2

    iget-wide v4, p0, Lcom/baidu/crabsdk/a/e;->e:J

    div-long/2addr v0, v4

    add-long/2addr v0, v2

    long-to-int v0, v0

    iput v0, p0, Lcom/baidu/crabsdk/a/e;->f:I

    :cond_1c
    :goto_1c
    iput-wide p1, p0, Lcom/baidu/crabsdk/a/e;->c:J
    :try_end_1e
    .catch Ljava/lang/Throwable; {:try_start_0 .. :try_end_1e} :catch_8b

    :goto_1e
    invoke-static {}, Landroid/view/Choreographer;->getInstance()Landroid/view/Choreographer;

    move-result-object v0

    sget-object v1, Lcom/baidu/crabsdk/a/e;->a:Lcom/baidu/crabsdk/a/e;

    invoke-virtual {v0, v1}, Landroid/view/Choreographer;->postFrameCallback(Landroid/view/Choreographer$FrameCallback;)V

    return-void

    :cond_28
    :try_start_28
    iget v0, p0, Lcom/baidu/crabsdk/a/e;->f:I

    if-lez v0, :cond_1c

    iget v0, p0, Lcom/baidu/crabsdk/a/e;->f:I

    const/16 v1, 0x1e

    if-le v0, v1, :cond_84

    new-instance v0, Ljava/lang/StringBuilder;

    const-string v1, "^^ block skip frames = "

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

    iget v1, p0, Lcom/baidu/crabsdk/a/e;->f:I

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

    move-result-object v0

    const-string v1, "\n^^ costs : "

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

    move-result-object v0

    sget-object v1, Ljava/util/concurrent/TimeUnit;->NANOSECONDS:Ljava/util/concurrent/TimeUnit;

    iget v2, p0, Lcom/baidu/crabsdk/a/e;->f:I

    int-to-long v2, v2

    iget-wide v4, p0, Lcom/baidu/crabsdk/a/e;->e:J

    mul-long/2addr v2, v4

    invoke-virtual {v1, v2, v3}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J

    move-result-wide v2

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

    move-result-object v0

    const-string v1, "ms"

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

    move-result-object v0

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

    move-result-object v0

    invoke-static {v0}, Lcom/baidu/crabsdk/c/a;->s(Ljava/lang/String;)I

    sget-object v0, Ljava/util/concurrent/TimeUnit;->NANOSECONDS:Ljava/util/concurrent/TimeUnit;

    iget v1, p0, Lcom/baidu/crabsdk/a/e;->f:I

    int-to-long v2, v1

    iget-wide v4, p0, Lcom/baidu/crabsdk/a/e;->e:J

    mul-long/2addr v2, v4

    invoke-virtual {v0, v2, v3}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J

    move-result-wide v0

    sget v2, Lcom/baidu/crabsdk/a/a;->S:I

    int-to-long v2, v2

    cmp-long v0, v0, v2

    if-ltz v0, :cond_81

    invoke-static {}, Lcom/baidu/crabsdk/a/c;->a()Ljava/util/concurrent/ExecutorService;

    move-result-object v0

    new-instance v1, Lcom/baidu/crabsdk/a/f;

    invoke-direct {v1, p0}, Lcom/baidu/crabsdk/a/f;-><init>(Lcom/baidu/crabsdk/a/e;)V

    invoke-interface {v0, v1}, Ljava/util/concurrent/ExecutorService;->execute(Ljava/lang/Runnable;)V

    :cond_81
    const/4 v0, 0x1

    iput v0, p0, Lcom/baidu/crabsdk/a/e;->f:I

    :cond_84
    iget v0, p0, Lcom/baidu/crabsdk/a/e;->f:I

    add-int/lit8 v0, v0, -0x1

    iput v0, p0, Lcom/baidu/crabsdk/a/e;->f:I
    :try_end_8a
    .catch Ljava/lang/Throwable; {:try_start_28 .. :try_end_8a} :catch_8b

    goto :goto_1c

    :catch_8b
    move-exception v0

    new-instance v1, Ljava/lang/StringBuilder;

    const-string v2, "doFrame:"

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

    invoke-virtual {v0}, Ljava/lang/Throwable;->toString()Ljava/lang/String;

    move-result-object v0

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

    move-result-object v0

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

    move-result-object v0

    invoke-static {v0}, Lcom/baidu/crabsdk/c/a;->t(Ljava/lang/String;)I

    goto/16 :goto_1e
.end method

.method public final start()V
    .registers 3

    iget-boolean v0, p0, Lcom/baidu/crabsdk/a/e;->b:Z

    if-eqz v0, :cond_5

    :goto_4
    return-void

    :cond_5
    const/4 v0, 0x1

    iput-boolean v0, p0, Lcom/baidu/crabsdk/a/e;->b:Z

    invoke-direct {p0}, Lcom/baidu/crabsdk/a/e;->a()V

    :try_start_b
    invoke-static {}, Landroid/os/Looper;->getMainLooper()Landroid/os/Looper;

    move-result-object v0

    invoke-static {}, Landroid/os/Looper;->myLooper()Landroid/os/Looper;

    move-result-object v1

    if-ne v0, v1, :cond_26

    invoke-static {}, Landroid/view/Choreographer;->getInstance()Landroid/view/Choreographer;

    move-result-object v0

    sget-object v1, Lcom/baidu/crabsdk/a/e;->a:Lcom/baidu/crabsdk/a/e;

    invoke-virtual {v0, v1}, Landroid/view/Choreographer;->postFrameCallback(Landroid/view/Choreographer$FrameCallback;)V
    :try_end_1e
    .catch Ljava/lang/Exception; {:try_start_b .. :try_end_1e} :catch_1f

    goto :goto_4

    :catch_1f
    move-exception v0

    const-string v1, "postFrameCallback error!!"

    invoke-static {v1, v0}, Lcom/baidu/crabsdk/c/a;->a(Ljava/lang/String;Ljava/lang/Throwable;)I

    goto :goto_4

    :cond_26
    :try_start_26
    new-instance v0, Landroid/os/Handler;

    invoke-static {}, Landroid/os/Looper;->getMainLooper()Landroid/os/Looper;

    move-result-object v1

    invoke-direct {v0, v1}, Landroid/os/Handler;-><init>(Landroid/os/Looper;)V

    new-instance v1, Lcom/baidu/crabsdk/a/g;

    invoke-direct {v1, p0}, Lcom/baidu/crabsdk/a/g;-><init>(Lcom/baidu/crabsdk/a/e;)V

    invoke-virtual {v0, v1}, Landroid/os/Handler;->post(Ljava/lang/Runnable;)Z
    :try_end_37
    .catch Ljava/lang/Exception; {:try_start_26 .. :try_end_37} :catch_1f

    goto :goto_4
.end method

.method public final stop()V
    .registers 3

    const/4 v0, 0x0

    iput-boolean v0, p0, Lcom/baidu/crabsdk/a/e;->b:Z

    invoke-direct {p0}, Lcom/baidu/crabsdk/a/e;->a()V

    invoke-static {}, Landroid/os/Looper;->getMainLooper()Landroid/os/Looper;

    move-result-object v0

    invoke-static {}, Landroid/os/Looper;->myLooper()Landroid/os/Looper;

    move-result-object v1

    if-ne v0, v1, :cond_1f

    invoke-static {}, Landroid/view/Choreographer;->getInstance()Landroid/view/Choreographer;

    move-result-object v0

    sget-object v1, Lcom/baidu/crabsdk/a/e;->a:Lcom/baidu/crabsdk/a/e;

    invoke-virtual {v0, v1}, Landroid/view/Choreographer;->removeFrameCallback(Landroid/view/Choreographer$FrameCallback;)V

    const-string v0, "stop FrameMonitor !!"

    invoke-static {v0}, Lcom/baidu/crabsdk/c/a;->q(Ljava/lang/String;)I

    :goto_1e
    return-void

    :cond_1f
    new-instance v0, Landroid/os/Handler;

    invoke-static {}, Landroid/os/Looper;->getMainLooper()Landroid/os/Looper;

    move-result-object v1

    invoke-direct {v0, v1}, Landroid/os/Handler;-><init>(Landroid/os/Looper;)V

    new-instance v1, Lcom/baidu/crabsdk/a/h;

    invoke-direct {v1, p0}, Lcom/baidu/crabsdk/a/h;-><init>(Lcom/baidu/crabsdk/a/e;)V

    invoke-virtual {v0, v1}, Landroid/os/Handler;->post(Ljava/lang/Runnable;)Z

    goto :goto_1e
.end method