c.smali
.class public final Lcom/yysdk/mobile/vpsdk/c/c;
.super Ljava/lang/Thread;
.source "SourceFile"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/yysdk/mobile/vpsdk/c/c$a;,
Lcom/yysdk/mobile/vpsdk/c/c$b;
}
.end annotation
# static fields
.field private static o:I = 0x10
.field private static p:I = 0x2
.field private static q:I = 0x1
.field private static r:I = 0x10
# instance fields
.field private A:Landroid/media/AudioRecord;
.field private B:I
.field private C:Z
.field private D:I
.field private E:I
.field private F:Z
.field private G:Lcom/yysdk/mobile/vpsdk/c/c$b;
.field private H:I
.field volatile a:Z
.field volatile b:Z
.field c:Lcom/yysdk/mobile/vpsdk/j/b;
.field d:Z
.field public e:Ljava/util/concurrent/atomic/AtomicBoolean;
.field f:Z
.field g:I
.field h:J
.field i:Ljava/util/concurrent/atomic/AtomicBoolean;
.field j:Ljava/util/concurrent/Semaphore;
.field k:Lcom/yysdk/mobile/vpsdk/c/c$a;
.field private l:I
.field private m:I
.field private n:I
.field private s:I
.field private volatile t:Z
.field private u:I
.field private v:I
.field private w:Z
.field private x:Ljava/lang/String;
.field private final y:I
.field private z:[B
# direct methods
.method static constructor <clinit>()V
.registers 0
return-void
.end method
.method public constructor <init>(Landroid/content/Context;ZLcom/yysdk/mobile/vpsdk/c/c$b;)V
.registers 9
const-string p1, "AudioRecordThread"
.line 85
invoke-direct {p0, p1}, Ljava/lang/Thread;-><init>(Ljava/lang/String;)V
const/4 p1, 0x0
.line 30
iput p1, p0, Lcom/yysdk/mobile/vpsdk/c/c;->l:I
.line 31
iput p1, p0, Lcom/yysdk/mobile/vpsdk/c/c;->m:I
const v0, 0xac44
.line 32
iput v0, p0, Lcom/yysdk/mobile/vpsdk/c/c;->n:I
.line 38
sget v0, Lcom/yysdk/mobile/vpsdk/c/c;->r:I
div-int/lit8 v0, v0, 0x8
iput v0, p0, Lcom/yysdk/mobile/vpsdk/c/c;->s:I
const/4 v0, 0x1
.line 40
iput-boolean v0, p0, Lcom/yysdk/mobile/vpsdk/c/c;->a:Z
.line 41
iput-boolean p1, p0, Lcom/yysdk/mobile/vpsdk/c/c;->t:Z
.line 42
iput-boolean p1, p0, Lcom/yysdk/mobile/vpsdk/c/c;->b:Z
const/4 v1, -0x1
.line 44
iput v1, p0, Lcom/yysdk/mobile/vpsdk/c/c;->u:I
.line 45
iput v1, p0, Lcom/yysdk/mobile/vpsdk/c/c;->v:I
.line 46
iput-boolean p1, p0, Lcom/yysdk/mobile/vpsdk/c/c;->w:Z
const-string v2, ""
.line 47
iput-object v2, p0, Lcom/yysdk/mobile/vpsdk/c/c;->x:Ljava/lang/String;
.line 49
iget v2, p0, Lcom/yysdk/mobile/vpsdk/c/c;->n:I
mul-int/lit8 v2, v2, 0x14
iget v3, p0, Lcom/yysdk/mobile/vpsdk/c/c;->s:I
mul-int v2, v2, v3
sget v3, Lcom/yysdk/mobile/vpsdk/c/c;->q:I
mul-int v2, v2, v3
div-int/lit16 v2, v2, 0x3e8
iput v2, p0, Lcom/yysdk/mobile/vpsdk/c/c;->y:I
.line 52
new-array v2, v2, [B
iput-object v2, p0, Lcom/yysdk/mobile/vpsdk/c/c;->z:[B
const/4 v2, 0x0
.line 54
iput-object v2, p0, Lcom/yysdk/mobile/vpsdk/c/c;->A:Landroid/media/AudioRecord;
.line 56
iput-object v2, p0, Lcom/yysdk/mobile/vpsdk/c/c;->c:Lcom/yysdk/mobile/vpsdk/j/b;
.line 58
iput p1, p0, Lcom/yysdk/mobile/vpsdk/c/c;->B:I
.line 59
iput-boolean v0, p0, Lcom/yysdk/mobile/vpsdk/c/c;->C:Z
.line 60
iput p1, p0, Lcom/yysdk/mobile/vpsdk/c/c;->D:I
.line 61
iput p1, p0, Lcom/yysdk/mobile/vpsdk/c/c;->E:I
.line 62
iput-boolean p1, p0, Lcom/yysdk/mobile/vpsdk/c/c;->d:Z
.line 65
new-instance v3, Ljava/util/concurrent/atomic/AtomicBoolean;
invoke-direct {v3, v0}, Ljava/util/concurrent/atomic/AtomicBoolean;-><init>(Z)V
iput-object v3, p0, Lcom/yysdk/mobile/vpsdk/c/c;->e:Ljava/util/concurrent/atomic/AtomicBoolean;
.line 67
iput-boolean p1, p0, Lcom/yysdk/mobile/vpsdk/c/c;->f:Z
.line 68
iput p1, p0, Lcom/yysdk/mobile/vpsdk/c/c;->g:I
const-wide/16 v3, 0x0
.line 69
iput-wide v3, p0, Lcom/yysdk/mobile/vpsdk/c/c;->h:J
.line 70
iput v1, p0, Lcom/yysdk/mobile/vpsdk/c/c;->H:I
.line 72
new-instance v1, Ljava/util/concurrent/atomic/AtomicBoolean;
invoke-direct {v1, p1}, Ljava/util/concurrent/atomic/AtomicBoolean;-><init>(Z)V
iput-object v1, p0, Lcom/yysdk/mobile/vpsdk/c/c;->i:Ljava/util/concurrent/atomic/AtomicBoolean;
.line 73
new-instance v1, Ljava/util/concurrent/Semaphore;
invoke-direct {v1, p1}, Ljava/util/concurrent/Semaphore;-><init>(I)V
iput-object v1, p0, Lcom/yysdk/mobile/vpsdk/c/c;->j:Ljava/util/concurrent/Semaphore;
.line 291
iput-object v2, p0, Lcom/yysdk/mobile/vpsdk/c/c;->k:Lcom/yysdk/mobile/vpsdk/c/c$a;
.line 86
iput-boolean v0, p0, Lcom/yysdk/mobile/vpsdk/c/c;->a:Z
.line 88
iput-boolean p2, p0, Lcom/yysdk/mobile/vpsdk/c/c;->F:Z
.line 89
iput-object p3, p0, Lcom/yysdk/mobile/vpsdk/c/c;->G:Lcom/yysdk/mobile/vpsdk/c/c$b;
return-void
.end method
.method private a(I)V
.registers 3
.line 397
iget-object v0, p0, Lcom/yysdk/mobile/vpsdk/c/c;->c:Lcom/yysdk/mobile/vpsdk/j/b;
if-eqz v0, :cond_7
.line 399
invoke-interface {v0, p1}, Lcom/yysdk/mobile/vpsdk/j/b;->a(I)V
:cond_7
return-void
.end method
.method private a([BI)V
.registers 7
const/4 v0, 0x0
const/4 v1, 0x0
:goto_2
const/4 v2, 0x1
if-ge v1, p2, :cond_e
.line 366
aget-byte v3, p1, v1
if-eqz v3, :cond_b
const/4 p1, 0x0
goto :goto_f
:cond_b
add-int/lit8 v1, v1, 0x1
goto :goto_2
:cond_e
const/4 p1, 0x1
.line 372
:goto_f
iget v1, p0, Lcom/yysdk/mobile/vpsdk/c/c;->D:I
const/4 v3, 0x2
if-ge v1, v3, :cond_32
if-eqz p1, :cond_2d
.line 374
iget p1, p0, Lcom/yysdk/mobile/vpsdk/c/c;->E:I
add-int/2addr p1, p2
iput p1, p0, Lcom/yysdk/mobile/vpsdk/c/c;->E:I
.line 375
iget p2, p0, Lcom/yysdk/mobile/vpsdk/c/c;->y:I
mul-int/lit16 p2, p2, 0x96
if-lt p1, p2, :cond_3a
add-int/2addr v1, v2
.line 376
iput v1, p0, Lcom/yysdk/mobile/vpsdk/c/c;->D:I
if-le v1, v2, :cond_2a
const/4 p1, -0x2
.line 379
invoke-direct {p0, p1}, Lcom/yysdk/mobile/vpsdk/c/c;->a(I)V
.line 381
:cond_2a
iput v0, p0, Lcom/yysdk/mobile/vpsdk/c/c;->E:I
return-void
.line 384
:cond_2d
iput v0, p0, Lcom/yysdk/mobile/vpsdk/c/c;->D:I
.line 385
iput v0, p0, Lcom/yysdk/mobile/vpsdk/c/c;->E:I
return-void
:cond_32
if-nez p1, :cond_3a
const/4 p1, -0x3
.line 390
invoke-direct {p0, p1}, Lcom/yysdk/mobile/vpsdk/c/c;->a(I)V
.line 391
iput-boolean v0, p0, Lcom/yysdk/mobile/vpsdk/c/c;->C:Z
:cond_3a
return-void
.end method
.method private a()Z
.registers 12
const-string v0, "AudioRecordThread"
const-string v1, "About to new AudioRecord"
.line 310
invoke-static {v0, v1}, Lcom/yysdk/mobile/vpsdk/p;->a(Ljava/lang/String;Ljava/lang/String;)I
.line 312
iget v1, p0, Lcom/yysdk/mobile/vpsdk/c/c;->n:I
sget v2, Lcom/yysdk/mobile/vpsdk/c/c;->o:I
sget v3, Lcom/yysdk/mobile/vpsdk/c/c;->p:I
invoke-static {v1, v2, v3}, Landroid/media/AudioRecord;->getMinBufferSize(III)I
move-result v1
.line 315
iget v2, p0, Lcom/yysdk/mobile/vpsdk/c/c;->y:I
mul-int/lit8 v2, v2, 0xa
if-le v1, v2, :cond_18
move v2, v1
:cond_18
const/4 v9, 0x0
.line 319
:try_start_19
new-instance v10, Landroid/media/AudioRecord;
iget v4, p0, Lcom/yysdk/mobile/vpsdk/c/c;->m:I
iget v5, p0, Lcom/yysdk/mobile/vpsdk/c/c;->n:I
sget v6, Lcom/yysdk/mobile/vpsdk/c/c;->o:I
sget v7, Lcom/yysdk/mobile/vpsdk/c/c;->p:I
move-object v3, v10
move v8, v2
invoke-direct/range {v3 .. v8}, Landroid/media/AudioRecord;-><init>(IIIII)V
iput-object v10, p0, Lcom/yysdk/mobile/vpsdk/c/c;->A:Landroid/media/AudioRecord;
:try_end_2a
.catch Ljava/lang/IllegalArgumentException; {:try_start_19 .. :try_end_2a} :catch_34
.catch Ljava/lang/Exception; {:try_start_19 .. :try_end_2a} :catch_2b
goto :goto_4c
:catch_2b
move-exception v3
const-string v4, "New AudioRecord catched an unknown exception!"
.line 327
invoke-static {v0, v4, v3}, Lcom/yysdk/mobile/vpsdk/p;->b(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
.line 328
iput-object v9, p0, Lcom/yysdk/mobile/vpsdk/c/c;->A:Landroid/media/AudioRecord;
goto :goto_4c
:catch_34
move-exception v3
.line 323
new-instance v4, Ljava/lang/StringBuilder;
const-string v5, "new audio record failed due to illegal argument: "
invoke-direct {v4, v5}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v3}, Ljava/lang/IllegalArgumentException;->getMessage()Ljava/lang/String;
move-result-object v3
invoke-virtual {v4, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-static {v0, v3}, Lcom/yysdk/mobile/vpsdk/p;->c(Ljava/lang/String;Ljava/lang/String;)I
.line 324
iput-object v9, p0, Lcom/yysdk/mobile/vpsdk/c/c;->A:Landroid/media/AudioRecord;
.line 331
:goto_4c
iget-object v3, p0, Lcom/yysdk/mobile/vpsdk/c/c;->A:Landroid/media/AudioRecord;
const/4 v4, 0x1
if-eqz v3, :cond_7f
.line 332
invoke-virtual {v3}, Landroid/media/AudioRecord;->getState()I
move-result v3
if-eq v3, v4, :cond_7f
.line 333
new-instance v3, Ljava/lang/StringBuilder;
const-string v5, "audio record init failed using source:"
invoke-direct {v3, v5}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget v5, p0, Lcom/yysdk/mobile/vpsdk/c/c;->l:I
invoke-virtual {v3, v5}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v5, ", state="
invoke-virtual {v3, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v5, p0, Lcom/yysdk/mobile/vpsdk/c/c;->A:Landroid/media/AudioRecord;
invoke-virtual {v5}, Landroid/media/AudioRecord;->getState()I
move-result v5
invoke-virtual {v3, v5}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-static {v0, v3}, Lcom/yysdk/mobile/vpsdk/p;->c(Ljava/lang/String;Ljava/lang/String;)I
.line 334
iget-object v3, p0, Lcom/yysdk/mobile/vpsdk/c/c;->A:Landroid/media/AudioRecord;
invoke-virtual {v3}, Landroid/media/AudioRecord;->release()V
.line 335
iput-object v9, p0, Lcom/yysdk/mobile/vpsdk/c/c;->A:Landroid/media/AudioRecord;
.line 338
:cond_7f
new-instance v3, Ljava/lang/StringBuilder;
const-string v5, "AudioRecord created: bufferSize="
invoke-direct {v3, v5}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v3, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v2, ", minBufferSize="
invoke-virtual {v3, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-static {v0, v1}, Lcom/yysdk/mobile/vpsdk/p;->a(Ljava/lang/String;Ljava/lang/String;)I
.line 339
iget-object v0, p0, Lcom/yysdk/mobile/vpsdk/c/c;->A:Landroid/media/AudioRecord;
if-eqz v0, :cond_9d
return v4
:cond_9d
const/4 v0, 0x0
return v0
.end method
.method private b()Z
.registers 6
const-string v0, "AudioRecordThread"
const/4 v1, 0x0
.line 344
:try_start_3
iget-object v2, p0, Lcom/yysdk/mobile/vpsdk/c/c;->A:Landroid/media/AudioRecord;
invoke-virtual {v2}, Landroid/media/AudioRecord;->startRecording()V
:try_end_8
.catch Ljava/lang/IllegalStateException; {:try_start_3 .. :try_end_8} :catch_11
.catch Ljava/lang/Exception; {:try_start_3 .. :try_end_8} :catch_a
const/4 v0, 0x1
return v0
:catch_a
move-exception v2
const-string v3, "start recording encountered an unexpected exception"
.line 357
invoke-static {v0, v3, v2}, Lcom/yysdk/mobile/vpsdk/p;->b(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
return v1
:catch_11
move-exception v2
.line 346
new-instance v3, Ljava/lang/StringBuilder;
const-string v4, "recorder.startRecording(): IllegalStateException: "
invoke-direct {v3, v4}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v2}, Ljava/lang/IllegalStateException;->getMessage()Ljava/lang/String;
move-result-object v2
invoke-virtual {v3, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-static {v0, v2}, Lcom/yysdk/mobile/vpsdk/p;->c(Ljava/lang/String;Ljava/lang/String;)I
const/4 v0, -0x1
.line 347
invoke-direct {p0, v0}, Lcom/yysdk/mobile/vpsdk/c/c;->a(I)V
.line 349
:try_start_2b
iget-object v0, p0, Lcom/yysdk/mobile/vpsdk/c/c;->A:Landroid/media/AudioRecord;
invoke-virtual {v0}, Landroid/media/AudioRecord;->release()V
:try_end_30
.catch Ljava/lang/Exception; {:try_start_2b .. :try_end_30} :catch_30
:catch_30
const/4 v0, 0x0
.line 353
iput-object v0, p0, Lcom/yysdk/mobile/vpsdk/c/c;->A:Landroid/media/AudioRecord;
return v1
.end method
# virtual methods
.method public final run()V
.registers 20
move-object/from16 v1, p0
const/16 v0, -0x10
.line 177
invoke-static {v0}, Landroid/os/Process;->setThreadPriority(I)V
.line 181
invoke-direct/range {p0 .. p0}, Lcom/yysdk/mobile/vpsdk/c/c;->a()Z
move-result v0
const/4 v2, -0x1
if-nez v0, :cond_19
const-string v0, "AudioRecordThread"
const-string v3, "audio recorder create fail"
.line 182
invoke-static {v0, v3}, Lcom/yysdk/mobile/vpsdk/p;->c(Ljava/lang/String;Ljava/lang/String;)I
.line 183
invoke-direct {v1, v2}, Lcom/yysdk/mobile/vpsdk/c/c;->a(I)V
return-void
.line 187
:cond_19
invoke-direct/range {p0 .. p0}, Lcom/yysdk/mobile/vpsdk/c/c;->b()Z
move-result v0
if-nez v0, :cond_20
return-void
.line 192
:cond_20
iget-object v0, v1, Lcom/yysdk/mobile/vpsdk/c/c;->j:Ljava/util/concurrent/Semaphore;
invoke-virtual {v0}, Ljava/util/concurrent/Semaphore;->drainPermits()I
const/4 v0, 0x0
const/4 v3, 0x0
.line 194
:goto_27
iget-boolean v4, v1, Lcom/yysdk/mobile/vpsdk/c/c;->a:Z
const/4 v5, 0x1
if-eqz v4, :cond_191
.line 195
iget-object v4, v1, Lcom/yysdk/mobile/vpsdk/c/c;->A:Landroid/media/AudioRecord;
iget-object v6, v1, Lcom/yysdk/mobile/vpsdk/c/c;->z:[B
iget v7, v1, Lcom/yysdk/mobile/vpsdk/c/c;->y:I
invoke-virtual {v4, v6, v0, v7}, Landroid/media/AudioRecord;->read([BII)I
move-result v15
if-gtz v15, :cond_7b
const/4 v4, -0x2
if-eq v15, v4, :cond_67
const/4 v4, -0x3
if-ne v15, v4, :cond_3f
goto :goto_67
.line 204
:cond_3f
iget v4, v1, Lcom/yysdk/mobile/vpsdk/c/c;->B:I
add-int/2addr v4, v5
iput v4, v1, Lcom/yysdk/mobile/vpsdk/c/c;->B:I
const/16 v6, 0x64
if-lt v4, v6, :cond_16c
.line 206
new-instance v0, Ljava/lang/StringBuilder;
const-string v3, "audio record read error, readTimes="
invoke-direct {v0, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget v3, v1, Lcom/yysdk/mobile/vpsdk/c/c;->B:I
invoke-virtual {v0, v3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v3, ", threshold=100"
invoke-virtual {v0, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
const-string v3, "AudioRecordThread"
invoke-static {v3, v0}, Lcom/yysdk/mobile/vpsdk/p;->c(Ljava/lang/String;Ljava/lang/String;)I
.line 208
invoke-direct {v1, v2}, Lcom/yysdk/mobile/vpsdk/c/c;->a(I)V
goto/16 :goto_191
.line 200
:cond_67
:goto_67
invoke-static {v15}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;
move-result-object v0
const-string v3, "audio record read error:"
invoke-virtual {v3, v0}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
const-string v3, "AudioRecordThread"
invoke-static {v3, v0}, Lcom/yysdk/mobile/vpsdk/p;->c(Ljava/lang/String;Ljava/lang/String;)I
.line 201
invoke-direct {v1, v2}, Lcom/yysdk/mobile/vpsdk/c/c;->a(I)V
goto/16 :goto_191
.line 212
:cond_7b
iput v0, v1, Lcom/yysdk/mobile/vpsdk/c/c;->B:I
.line 213
iget v4, v1, Lcom/yysdk/mobile/vpsdk/c/c;->y:I
if-ge v15, v4, :cond_99
.line 214
new-instance v4, Ljava/lang/StringBuilder;
const-string v6, "recorder: read "
invoke-direct {v4, v6}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-virtual {v4, v15}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v6, " bytes"
invoke-virtual {v4, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
const-string v6, "AudioRecordThread"
invoke-static {v6, v4}, Lcom/yysdk/mobile/vpsdk/p;->a(Ljava/lang/String;Ljava/lang/String;)I
.line 217
:cond_99
iget-boolean v4, v1, Lcom/yysdk/mobile/vpsdk/c/c;->C:Z
if-eqz v4, :cond_a2
.line 218
iget-object v4, v1, Lcom/yysdk/mobile/vpsdk/c/c;->z:[B
invoke-direct {v1, v4, v15}, Lcom/yysdk/mobile/vpsdk/c/c;->a([BI)V
.line 221
:cond_a2
invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J
move-result-wide v6
.line 222
iget-object v4, v1, Lcom/yysdk/mobile/vpsdk/c/c;->G:Lcom/yysdk/mobile/vpsdk/c/c$b;
invoke-interface {v4, v6, v7}, Lcom/yysdk/mobile/vpsdk/c/c$b;->b(J)V
.line 224
iget-boolean v4, v1, Lcom/yysdk/mobile/vpsdk/c/c;->b:Z
if-eqz v4, :cond_15e
.line 225
iget-object v4, v1, Lcom/yysdk/mobile/vpsdk/c/c;->z:[B
add-int/lit8 v3, v3, 0x1
.line 1297
iget v8, v1, Lcom/yysdk/mobile/vpsdk/c/c;->n:I
sget v9, Lcom/yysdk/mobile/vpsdk/c/c;->q:I
invoke-static {v4, v15, v8, v9}, Lcom/yysdk/mobile/vpsdk/VPSDKNativeLibrary;->vpPushEchoNear([BIII)I
.line 1298
iget-boolean v4, v1, Lcom/yysdk/mobile/vpsdk/c/c;->f:Z
if-eqz v4, :cond_ee
rem-int/lit8 v4, v3, 0x32
if-nez v4, :cond_ee
.line 1299
new-instance v4, Ljava/lang/StringBuilder;
const-string v8, "[AEC] get current delay: "
invoke-direct {v4, v8}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
invoke-static {}, Lcom/yysdk/mobile/vpsdk/VPSDKNativeLibrary;->vpGetEchoDelayMs()I
move-result v8
invoke-virtual {v4, v8}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
const-string v8, "AudioRecordThread"
invoke-static {v8, v4}, Lcom/yysdk/mobile/vpsdk/p;->c(Ljava/lang/String;Ljava/lang/String;)I
.line 1300
invoke-static {}, Lcom/yysdk/mobile/vpsdk/VPSDKNativeLibrary;->vpGetEchoDelayMs()I
move-result v4
if-lez v4, :cond_ee
.line 1302
iget-wide v8, v1, Lcom/yysdk/mobile/vpsdk/c/c;->h:J
int-to-long v10, v4
add-long/2addr v8, v10
iput-wide v8, v1, Lcom/yysdk/mobile/vpsdk/c/c;->h:J
.line 1303
iget v4, v1, Lcom/yysdk/mobile/vpsdk/c/c;->g:I
add-int/2addr v4, v5
iput v4, v1, Lcom/yysdk/mobile/vpsdk/c/c;->g:I
long-to-int v9, v8
.line 1304
div-int/2addr v9, v4
iput v9, v1, Lcom/yysdk/mobile/vpsdk/c/c;->H:I
.line 227
:cond_ee
iget-boolean v4, v1, Lcom/yysdk/mobile/vpsdk/c/c;->F:Z
if-eqz v4, :cond_101
const/4 v8, 0x1
const-wide/16 v9, 0x0
.line 228
sget v11, Lcom/yysdk/mobile/vpsdk/c/c;->q:I
sget v12, Lcom/yysdk/mobile/vpsdk/c/c;->r:I
iget v13, v1, Lcom/yysdk/mobile/vpsdk/c/c;->n:I
iget-object v14, v1, Lcom/yysdk/mobile/vpsdk/c/c;->z:[B
invoke-static/range {v8 .. v15}, Lcom/yysdk/mobile/vpsdk/VPSDKNativeLibrary;->imPushAudio(IJIII[BI)I
goto :goto_15a
.line 232
:cond_101
iget-object v4, v1, Lcom/yysdk/mobile/vpsdk/c/c;->G:Lcom/yysdk/mobile/vpsdk/c/c$b;
invoke-interface {v4}, Lcom/yysdk/mobile/vpsdk/c/c$b;->b()Z
move-result v4
if-nez v4, :cond_15a
.line 233
iget-object v4, v1, Lcom/yysdk/mobile/vpsdk/c/c;->G:Lcom/yysdk/mobile/vpsdk/c/c$b;
invoke-interface {v4, v6, v7}, Lcom/yysdk/mobile/vpsdk/c/c$b;->a(J)Lcom/yysdk/mobile/vpsdk/y;
move-result-object v4
.line 234
iget-wide v6, v4, Lcom/yysdk/mobile/vpsdk/y;->a:D
const-wide/16 v8, 0x0
cmpl-double v10, v6, v8
if-lez v10, :cond_142
iget-object v6, v1, Lcom/yysdk/mobile/vpsdk/c/c;->G:Lcom/yysdk/mobile/vpsdk/c/c$b;
iget-wide v7, v4, Lcom/yysdk/mobile/vpsdk/y;->b:J
long-to-int v8, v7
invoke-interface {v6, v8}, Lcom/yysdk/mobile/vpsdk/c/c$b;->a(I)Z
move-result v6
if-nez v6, :cond_142
.line 235
iget-object v6, v1, Lcom/yysdk/mobile/vpsdk/c/c;->k:Lcom/yysdk/mobile/vpsdk/c/c$a;
if-eqz v6, :cond_12b
.line 236
iget-object v7, v1, Lcom/yysdk/mobile/vpsdk/c/c;->z:[B
invoke-interface {v6, v7, v15}, Lcom/yysdk/mobile/vpsdk/c/c$a;->a([BI)V
:cond_12b
const/4 v8, 0x1
.line 238
iget-wide v9, v4, Lcom/yysdk/mobile/vpsdk/y;->b:J
sget v11, Lcom/yysdk/mobile/vpsdk/c/c;->q:I
sget v12, Lcom/yysdk/mobile/vpsdk/c/c;->r:I
iget v13, v1, Lcom/yysdk/mobile/vpsdk/c/c;->n:I
iget-object v14, v1, Lcom/yysdk/mobile/vpsdk/c/c;->z:[B
const-wide/high16 v6, 0x3ff0000000000000L # 1.0
move/from16 v18, v3
iget-wide v2, v4, Lcom/yysdk/mobile/vpsdk/y;->a:D
div-double v16, v6, v2
invoke-static/range {v8 .. v17}, Lcom/yysdk/mobile/vpsdk/VPSDKNativeLibrary;->vpPushAudio(IJIII[BID)I
goto :goto_15c
:cond_142
move/from16 v18, v3
.line 242
new-instance v2, Ljava/lang/StringBuilder;
const-string v3, "audio exceedRecordTs "
invoke-direct {v2, v3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V
iget-wide v3, v4, Lcom/yysdk/mobile/vpsdk/y;->b:J
invoke-virtual {v2, v3, v4}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
const-string v3, "AudioRecordThread"
invoke-static {v3, v2}, Lcom/yysdk/mobile/vpsdk/p;->a(Ljava/lang/String;Ljava/lang/String;)I
goto :goto_15c
:cond_15a
:goto_15a
move/from16 v18, v3
:goto_15c
move/from16 v3, v18
.line 248
:cond_15e
iget-object v2, v1, Lcom/yysdk/mobile/vpsdk/c/c;->e:Ljava/util/concurrent/atomic/AtomicBoolean;
invoke-virtual {v2, v5}, Ljava/util/concurrent/atomic/AtomicBoolean;->set(Z)V
.line 249
iget-object v2, v1, Lcom/yysdk/mobile/vpsdk/c/c;->e:Ljava/util/concurrent/atomic/AtomicBoolean;
monitor-enter v2
.line 250
:try_start_166
iget-object v4, v1, Lcom/yysdk/mobile/vpsdk/c/c;->e:Ljava/util/concurrent/atomic/AtomicBoolean;
invoke-virtual {v4}, Ljava/lang/Object;->notifyAll()V
.line 251
monitor-exit v2
:try_end_16c
.catchall {:try_start_166 .. :try_end_16c} :catchall_18e
.line 254
:cond_16c
iget-object v2, v1, Lcom/yysdk/mobile/vpsdk/c/c;->i:Ljava/util/concurrent/atomic/AtomicBoolean;
invoke-virtual {v2}, Ljava/util/concurrent/atomic/AtomicBoolean;->get()Z
move-result v2
if-eqz v2, :cond_18b
.line 256
:try_start_174
iget-object v2, v1, Lcom/yysdk/mobile/vpsdk/c/c;->A:Landroid/media/AudioRecord;
invoke-virtual {v2}, Landroid/media/AudioRecord;->stop()V
.line 257
iget-object v2, v1, Lcom/yysdk/mobile/vpsdk/c/c;->j:Ljava/util/concurrent/Semaphore;
invoke-virtual {v2}, Ljava/util/concurrent/Semaphore;->acquire()V
.line 258
iget-object v2, v1, Lcom/yysdk/mobile/vpsdk/c/c;->A:Landroid/media/AudioRecord;
invoke-virtual {v2}, Landroid/media/AudioRecord;->startRecording()V
:try_end_183
.catch Ljava/lang/InterruptedException; {:try_start_174 .. :try_end_183} :catch_184
goto :goto_18b
:catch_184
const-string v2, "AudioRecordThread"
const-string v4, "audioRecordTh interrupted while waiting in background"
.line 260
invoke-static {v2, v4}, Lcom/yysdk/mobile/vpsdk/p;->c(Ljava/lang/String;Ljava/lang/String;)I
:cond_18b
:goto_18b
const/4 v2, -0x1
goto/16 :goto_27
:catchall_18e
move-exception v0
.line 251
:try_start_18f
monitor-exit v2
:try_end_190
.catchall {:try_start_18f .. :try_end_190} :catchall_18e
throw v0
.line 265
:cond_191
:goto_191
iget-object v0, v1, Lcom/yysdk/mobile/vpsdk/c/c;->e:Ljava/util/concurrent/atomic/AtomicBoolean;
invoke-virtual {v0, v5}, Ljava/util/concurrent/atomic/AtomicBoolean;->set(Z)V
.line 266
iget-object v2, v1, Lcom/yysdk/mobile/vpsdk/c/c;->e:Ljava/util/concurrent/atomic/AtomicBoolean;
monitor-enter v2
.line 267
:try_start_199
iget-object v0, v1, Lcom/yysdk/mobile/vpsdk/c/c;->e:Ljava/util/concurrent/atomic/AtomicBoolean;
invoke-virtual {v0}, Ljava/lang/Object;->notifyAll()V
.line 268
monitor-exit v2
:try_end_19f
.catchall {:try_start_199 .. :try_end_19f} :catchall_1bf
.line 270
iget-object v0, v1, Lcom/yysdk/mobile/vpsdk/c/c;->A:Landroid/media/AudioRecord;
if-eqz v0, :cond_1b7
.line 272
:try_start_1a3
invoke-virtual {v0}, Landroid/media/AudioRecord;->stop()V
.line 273
iget-object v0, v1, Lcom/yysdk/mobile/vpsdk/c/c;->A:Landroid/media/AudioRecord;
invoke-virtual {v0}, Landroid/media/AudioRecord;->release()V
:try_end_1ab
.catch Ljava/lang/IllegalStateException; {:try_start_1a3 .. :try_end_1ab} :catch_1b4
.catch Ljava/lang/Exception; {:try_start_1a3 .. :try_end_1ab} :catch_1ac
goto :goto_1b4
:catch_1ac
move-exception v0
const-string v2, "AudioRecordThread"
const-string v3, "stop recorder encountered an unexpected exception!"
.line 278
invoke-static {v2, v3, v0}, Lcom/yysdk/mobile/vpsdk/p;->b(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
:catch_1b4
:goto_1b4
const/4 v0, 0x0
.line 280
iput-object v0, v1, Lcom/yysdk/mobile/vpsdk/c/c;->A:Landroid/media/AudioRecord;
:cond_1b7
const-string v0, "AudioRecordThread"
const-string v2, "Record ended"
.line 284
invoke-static {v0, v2}, Lcom/yysdk/mobile/vpsdk/p;->a(Ljava/lang/String;Ljava/lang/String;)I
return-void
:catchall_1bf
move-exception v0
.line 268
:try_start_1c0
monitor-exit v2
:try_end_1c1
.catchall {:try_start_1c0 .. :try_end_1c1} :catchall_1bf
goto :goto_1c3
:goto_1c2
throw v0
:goto_1c3
goto :goto_1c2
.end method
.method public final declared-synchronized start()V
.registers 2
monitor-enter p0
.line 99
:try_start_1
invoke-super {p0}, Ljava/lang/Thread;->start()V
const/4 v0, 0x1
.line 100
iput-boolean v0, p0, Lcom/yysdk/mobile/vpsdk/c/c;->d:Z
:try_end_7
.catchall {:try_start_1 .. :try_end_7} :catchall_9
.line 101
monitor-exit p0
return-void
:catchall_9
move-exception v0
monitor-exit p0
throw v0
.end method