d$b.smali

.class final Lcom/imo/android/imoim/mic/a/d$b;
.super Ljava/lang/Object;
.source "SourceFile"

# interfaces
.implements Ljava/lang/Runnable;


# annotations
.annotation system Ldalvik/annotation/EnclosingMethod;
    value = Lcom/imo/android/imoim/mic/a/d;-><init>()V
.end annotation

.annotation system Ldalvik/annotation/InnerClass;
    accessFlags = 0x18
    name = null
.end annotation


# instance fields
.field final synthetic a:Lcom/imo/android/imoim/mic/a/d;


# direct methods
.method constructor <init>(Lcom/imo/android/imoim/mic/a/d;)V
    .registers 2

    iput-object p1, p0, Lcom/imo/android/imoim/mic/a/d$b;->a:Lcom/imo/android/imoim/mic/a/d;

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

    return-void
.end method


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

    .line 261
    :goto_0
    iget-object v0, p0, Lcom/imo/android/imoim/mic/a/d$b;->a:Lcom/imo/android/imoim/mic/a/d;

    invoke-static {v0}, Lcom/imo/android/imoim/mic/a/d;->n(Lcom/imo/android/imoim/mic/a/d;)Ljava/util/concurrent/ConcurrentLinkedQueue;

    move-result-object v0

    invoke-virtual {v0}, Ljava/util/concurrent/ConcurrentLinkedQueue;->isEmpty()Z

    move-result v0

    if-nez v0, :cond_61

    .line 262
    iget-object v0, p0, Lcom/imo/android/imoim/mic/a/d$b;->a:Lcom/imo/android/imoim/mic/a/d;

    invoke-static {v0}, Lcom/imo/android/imoim/mic/a/d;->n(Lcom/imo/android/imoim/mic/a/d;)Ljava/util/concurrent/ConcurrentLinkedQueue;

    move-result-object v0

    invoke-virtual {v0}, Ljava/util/concurrent/ConcurrentLinkedQueue;->poll()Ljava/lang/Object;

    move-result-object v0

    check-cast v0, [B

    .line 263
    invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J

    move-result-wide v1

    .line 264
    iget-object v3, p0, Lcom/imo/android/imoim/mic/a/d$b;->a:Lcom/imo/android/imoim/mic/a/d;

    invoke-static {v3}, Lcom/imo/android/imoim/mic/a/d;->o(Lcom/imo/android/imoim/mic/a/d;)Lcom/imo/android/imoim/mic/a/a;

    move-result-object v3

    iget-object v4, p0, Lcom/imo/android/imoim/mic/a/d$b;->a:Lcom/imo/android/imoim/mic/a/d;

    invoke-static {v4}, Lcom/imo/android/imoim/mic/a/d;->p(Lcom/imo/android/imoim/mic/a/d;)J

    move-result-wide v4

    array-length v6, v0

    invoke-virtual {v3, v4, v5, v0, v6}, Lcom/imo/android/imoim/mic/a/a;->writeDataToOggFile(J[BI)I

    move-result v3

    .line 265
    iget-object v4, p0, Lcom/imo/android/imoim/mic/a/d$b;->a:Lcom/imo/android/imoim/mic/a/d;

    invoke-static {v4}, Lcom/imo/android/imoim/mic/a/d;->q(Lcom/imo/android/imoim/mic/a/d;)J

    move-result-wide v5

    invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J

    move-result-wide v7

    sub-long/2addr v7, v1

    add-long/2addr v5, v7

    invoke-static {v4, v5, v6}, Lcom/imo/android/imoim/mic/a/d;->a(Lcom/imo/android/imoim/mic/a/d;J)V

    .line 266
    iget-object v1, p0, Lcom/imo/android/imoim/mic/a/d$b;->a:Lcom/imo/android/imoim/mic/a/d;

    invoke-static {v1}, Lcom/imo/android/imoim/mic/a/d;->r(Lcom/imo/android/imoim/mic/a/d;)J

    move-result-wide v4

    const-wide/16 v6, 0x1

    add-long/2addr v4, v6

    invoke-static {v1, v4, v5}, Lcom/imo/android/imoim/mic/a/d;->b(Lcom/imo/android/imoim/mic/a/d;J)V

    if-ltz v3, :cond_57

    .line 268
    iget-object v1, p0, Lcom/imo/android/imoim/mic/a/d$b;->a:Lcom/imo/android/imoim/mic/a/d;

    invoke-static {v1}, Lcom/imo/android/imoim/mic/a/d;->s(Lcom/imo/android/imoim/mic/a/d;)J

    move-result-wide v2

    array-length v0, v0

    int-to-long v4, v0

    add-long/2addr v2, v4

    invoke-static {v1, v2, v3}, Lcom/imo/android/imoim/mic/a/d;->c(Lcom/imo/android/imoim/mic/a/d;J)V

    goto :goto_0

    .line 270
    :cond_57
    iget-object v0, p0, Lcom/imo/android/imoim/mic/a/d$b;->a:Lcom/imo/android/imoim/mic/a/d;

    invoke-static {v0}, Lcom/imo/android/imoim/mic/a/d;->n(Lcom/imo/android/imoim/mic/a/d;)Ljava/util/concurrent/ConcurrentLinkedQueue;

    move-result-object v0

    invoke-virtual {v0}, Ljava/util/concurrent/ConcurrentLinkedQueue;->clear()V

    goto :goto_0

    .line 273
    :cond_61
    new-instance v0, Ljava/lang/StringBuilder;

    const-string v1, "mEncodeCompleteRunnable -> stopBuildOggFile. readCount:"

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

    iget-object v1, p0, Lcom/imo/android/imoim/mic/a/d$b;->a:Lcom/imo/android/imoim/mic/a/d;

    invoke-static {v1}, Lcom/imo/android/imoim/mic/a/d;->u(Lcom/imo/android/imoim/mic/a/d;)J

    move-result-wide v1

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

    const-string v1, ", encodeCount:"

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

    iget-object v1, p0, Lcom/imo/android/imoim/mic/a/d$b;->a:Lcom/imo/android/imoim/mic/a/d;

    invoke-static {v1}, Lcom/imo/android/imoim/mic/a/d;->r(Lcom/imo/android/imoim/mic/a/d;)J

    move-result-wide v1

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

    const-string v1, ", encodeCost:"

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

    iget-object v1, p0, Lcom/imo/android/imoim/mic/a/d$b;->a:Lcom/imo/android/imoim/mic/a/d;

    invoke-static {v1}, Lcom/imo/android/imoim/mic/a/d;->q(Lcom/imo/android/imoim/mic/a/d;)J

    move-result-wide v1

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

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

    move-result-object v0

    const-string v1, "IMOBasicAudioRecorder"

    .line 1071
    invoke-static {v1, v0}, Lcom/imo/android/imoim/util/bt;->d(Ljava/lang/String;Ljava/lang/String;)V

    .line 274
    iget-object v0, p0, Lcom/imo/android/imoim/mic/a/d$b;->a:Lcom/imo/android/imoim/mic/a/d;

    invoke-static {v0}, Lcom/imo/android/imoim/mic/a/d;->o(Lcom/imo/android/imoim/mic/a/d;)Lcom/imo/android/imoim/mic/a/a;

    move-result-object v0

    iget-object v2, p0, Lcom/imo/android/imoim/mic/a/d$b;->a:Lcom/imo/android/imoim/mic/a/d;

    invoke-static {v2}, Lcom/imo/android/imoim/mic/a/d;->p(Lcom/imo/android/imoim/mic/a/d;)J

    move-result-wide v2

    invoke-virtual {v0, v2, v3}, Lcom/imo/android/imoim/mic/a/a;->stopBuildOggFile(J)V

    .line 275
    new-instance v0, Ljava/io/File;

    iget-object v2, p0, Lcom/imo/android/imoim/mic/a/d$b;->a:Lcom/imo/android/imoim/mic/a/d;

    invoke-static {v2}, Lcom/imo/android/imoim/mic/a/d;->v(Lcom/imo/android/imoim/mic/a/d;)Ljava/lang/String;

    move-result-object v2

    invoke-direct {v0, v2}, Ljava/io/File;-><init>(Ljava/lang/String;)V

    .line 276
    iget-object v2, p0, Lcom/imo/android/imoim/mic/a/d$b;->a:Lcom/imo/android/imoim/mic/a/d;

    invoke-static {v2}, Lcom/imo/android/imoim/mic/a/d;->r(Lcom/imo/android/imoim/mic/a/d;)J

    move-result-wide v2

    const-wide/16 v4, 0x0

    cmp-long v6, v2, v4

    if-lez v6, :cond_e3

    invoke-virtual {v0}, Ljava/io/File;->exists()Z

    move-result v2

    if-eqz v2, :cond_ca

    invoke-virtual {v0}, Ljava/io/File;->length()J

    move-result-wide v2

    cmp-long v0, v2, v4

    if-nez v0, :cond_e3

    :cond_ca
    const/4 v0, 0x1

    const-string v2, "mEncodeCompleteRunnable -> write no data"

    .line 1079
    invoke-static {v1, v2, v0}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Z)V

    .line 278
    iget-object v0, p0, Lcom/imo/android/imoim/mic/a/d$b;->a:Lcom/imo/android/imoim/mic/a/d;

    invoke-static {v0}, Lcom/imo/android/imoim/mic/a/d;->b(Lcom/imo/android/imoim/mic/a/d;)Lcom/imo/android/imoim/mic/a/f;

    move-result-object v0

    if-eqz v0, :cond_de

    const/4 v1, -0x5

    const-string v2, "encode failed"

    invoke-interface {v0, v1, v2}, Lcom/imo/android/imoim/mic/a/f;->onError(ILjava/lang/String;)V

    .line 279
    :cond_de
    iget-object v0, p0, Lcom/imo/android/imoim/mic/a/d$b;->a:Lcom/imo/android/imoim/mic/a/d;

    invoke-static {v0, v4, v5}, Lcom/imo/android/imoim/mic/a/d;->c(Lcom/imo/android/imoim/mic/a/d;J)V

    .line 281
    :cond_e3
    iget-object v0, p0, Lcom/imo/android/imoim/mic/a/d$b;->a:Lcom/imo/android/imoim/mic/a/d;

    invoke-static {v0}, Lcom/imo/android/imoim/mic/a/d;->w(Lcom/imo/android/imoim/mic/a/d;)Lcom/imo/android/imoim/mic/a/g;

    move-result-object v0

    if-eqz v0, :cond_ee

    invoke-interface {v0}, Lcom/imo/android/imoim/mic/a/g;->a()V

    :cond_ee
    return-void
.end method