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