MacawAudioStreamThread.smali

.class public Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;
.super Ljava/lang/Thread;
.source "SourceFile"


# static fields
.field private static final TAG:Ljava/lang/String; = "MacawAudioStreamThread"

.field private static final kPlayerSampleByteCount:I = 0x2

.field private static final kPlayerSampleConfig:I = 0x2

.field private static final kRecorderReadFailThreshold:I = 0x64

.field private static final kRecorderSampleByteCount:I = 0x2

.field private static final kRecorderSampleConfig:I = 0x2


# instance fields
.field private mAudioDeviceType:I

.field private volatile mMacawContext:J

.field private mMacawHandler:Lcom/imo/android/imoim/av/macaw/MacawHandler;

.field private mPlayer:Landroid/media/AudioTrack;

.field private mPlayerBuffer:[B

.field private mPlayerChannelCount:I

.field private mPlayerChannelCountConfig:I

.field private mPlayerFrameBytesSize:I

.field private mPlayerFrameSize:I

.field private mPlayerSampleRate:I

.field private mPlayerStream:I

.field private mPlayerSystemBufferSize:I

.field mRecorder:Landroid/media/AudioRecord;

.field private mRecorderBuffer:[B

.field private mRecorderChannelConfig:I

.field private mRecorderChannelCount:I

.field private mRecorderFailReadTimes:I

.field private mRecorderFrameBytesSize:I

.field private mRecorderFrameSampleSize:I

.field private mRecorderReadErrorTimes:I

.field private mRecorderSampleRate:I

.field private mRecorderSource:I

.field private mRecorderSystemBufferSize:I

.field private mRecorderTotalLength:I

.field private volatile mRunning:Z


# direct methods
.method public constructor <init>(Lcom/imo/android/imoim/av/macaw/MacawHandler;JI)V
    .registers 12

    .line 48
    invoke-direct {p0}, Ljava/lang/Thread;-><init>()V

    const-wide/16 v0, 0x0

    .line 20
    iput-wide v0, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mMacawContext:J

    const/4 v0, 0x0

    .line 21
    iput-object v0, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mMacawHandler:Lcom/imo/android/imoim/av/macaw/MacawHandler;

    const/4 v1, -0x1

    .line 22
    iput v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mAudioDeviceType:I

    const/4 v1, 0x0

    .line 23
    iput-boolean v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRunning:Z

    .line 25
    iput-object v0, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorder:Landroid/media/AudioRecord;

    .line 26
    iput-object v0, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderBuffer:[B

    const/16 v2, 0x1400

    .line 27
    iput v2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderSystemBufferSize:I

    .line 28
    iput v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderSource:I

    const/16 v3, 0x3e80

    .line 29
    iput v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderSampleRate:I

    const/4 v4, 0x1

    .line 30
    iput v4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderChannelCount:I

    const/16 v5, 0x10

    .line 31
    iput v5, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderChannelConfig:I

    const/16 v5, 0x280

    .line 32
    iput v5, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderFrameBytesSize:I

    const/16 v6, 0x140

    .line 33
    iput v6, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderFrameSampleSize:I

    .line 34
    iput v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderFailReadTimes:I

    .line 35
    iput v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderReadErrorTimes:I

    .line 36
    iput v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderTotalLength:I

    .line 38
    iput-object v0, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;

    .line 39
    iput-object v0, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerBuffer:[B

    .line 40
    iput v2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerSystemBufferSize:I

    .line 41
    iput v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerStream:I

    .line 42
    iput v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerSampleRate:I

    .line 43
    iput v4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerChannelCount:I

    const/4 v0, 0x4

    .line 44
    iput v0, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerChannelCountConfig:I

    .line 45
    iput v6, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerFrameSize:I

    .line 46
    iput v5, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerFrameBytesSize:I

    .line 49
    iput-boolean v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRunning:Z

    .line 50
    iput-wide p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mMacawContext:J

    .line 51
    iput-object p1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mMacawHandler:Lcom/imo/android/imoim/av/macaw/MacawHandler;

    .line 52
    iput p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mAudioDeviceType:I

    return-void
.end method

.method private initPlay(IIIZ)Z
    .registers 13

    .line 57
    iput p1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerSampleRate:I

    .line 58
    iput p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerChannelCount:I

    .line 59
    iput p3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerFrameSize:I

    const/4 p1, 0x2

    mul-int/lit8 p3, p3, 0x2

    mul-int p3, p3, p2

    .line 60
    iput p3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerFrameBytesSize:I

    const/4 p3, 0x1

    if-ne p2, p3, :cond_12

    const/4 p2, 0x4

    goto :goto_14

    :cond_12
    const/16 p2, 0xc

    .line 61
    :goto_14
    iput p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerChannelCountConfig:I

    if-eqz p4, :cond_1b

    const/4 p2, 0x3

    .line 63
    iput p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerStream:I

    .line 65
    :cond_1b
    iget p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerSampleRate:I

    iget p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerChannelCountConfig:I

    invoke-static {p2, p4, p1}, Landroid/media/AudioTrack;->getMinBufferSize(III)I

    move-result p1

    .line 66
    iget p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerFrameSize:I

    div-int p4, p1, p2

    rem-int p2, p1, p2

    const/4 v0, 0x0

    if-nez p2, :cond_2e

    const/4 p2, 0x0

    goto :goto_2f

    :cond_2e
    const/4 p2, 0x1

    :goto_2f
    add-int/2addr p4, p2

    iget p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerFrameSize:I

    mul-int p4, p4, p2

    iput p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerSystemBufferSize:I

    .line 68
    new-instance p2, Ljava/lang/StringBuilder;

    const-string p4, "AudioTrack created: playMinSize="

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

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

    const-string p1, ", mPlayerSystemBufferSize="

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

    iget p1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerSystemBufferSize:I

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

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

    move-result-object p1

    const-string p2, "MacawAudioStreamThread"

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

    .line 69
    new-instance p1, Ljava/lang/StringBuilder;

    const-string p4, "AudioTrack created: Source="

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

    iget p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerStream:I

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

    const-string p4, ", SampleRate="

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

    iget p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerSampleRate:I

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

    const-string p4, ", ChannelCount="

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

    iget p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerChannelCountConfig:I

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

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

    move-result-object p1

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

    const/4 p1, 0x0

    .line 71
    iput-object p1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;

    .line 73
    :try_start_7d
    new-instance p4, Landroid/media/AudioTrack;

    iget v2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerStream:I

    iget v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerSampleRate:I

    iget v4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerChannelCountConfig:I

    const/4 v5, 0x2

    iget v6, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerSystemBufferSize:I

    const/4 v7, 0x1

    move-object v1, p4

    invoke-direct/range {v1 .. v7}, Landroid/media/AudioTrack;-><init>(IIIIII)V

    iput-object p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;
    :try_end_8f
    .catch Ljava/lang/IllegalArgumentException; {:try_start_7d .. :try_end_8f} :catch_a9
    .catch Ljava/lang/Exception; {:try_start_7d .. :try_end_8f} :catch_90

    goto :goto_c1

    :catch_90
    move-exception p4

    .line 80
    new-instance v1, Ljava/lang/StringBuilder;

    const-string v2, "AudioTrack created: encountered an unexpected exception: "

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

    invoke-virtual {p4}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;

    move-result-object p4

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

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

    move-result-object p4

    .line 3079
    invoke-static {p2, p4, p3}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Z)V

    .line 81
    iput-object p1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;

    goto :goto_c1

    :catch_a9
    move-exception p4

    .line 76
    new-instance v1, Ljava/lang/StringBuilder;

    const-string v2, "AudioTrack created: failed due to illegal argument: "

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

    invoke-virtual {p4}, Ljava/lang/IllegalArgumentException;->getMessage()Ljava/lang/String;

    move-result-object p4

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

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

    move-result-object p4

    .line 2079
    invoke-static {p2, p4, p3}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Z)V

    .line 77
    iput-object p1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;

    .line 83
    :goto_c1
    iget-object p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;

    if-eqz p4, :cond_e9

    invoke-virtual {p4}, Landroid/media/AudioTrack;->getState()I

    move-result p4

    if-eq p4, p3, :cond_e9

    .line 84
    new-instance p4, Ljava/lang/StringBuilder;

    const-string v1, "AudioTrack created: Failed to create AudioTrack state="

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

    iget-object v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;

    invoke-virtual {v1}, Landroid/media/AudioTrack;->getState()I

    move-result v1

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

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

    move-result-object p4

    .line 4075
    invoke-static {p2, p4}, Lcom/imo/android/imoim/util/bt;->e(Ljava/lang/String;Ljava/lang/String;)V

    .line 85
    iget-object p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;

    invoke-virtual {p4}, Landroid/media/AudioTrack;->release()V

    .line 86
    iput-object p1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;

    .line 89
    :cond_e9
    iget-object p1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;

    if-nez p1, :cond_f3

    const-string p1, "AudioTrack created: create Failed"

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

    return v0

    .line 93
    :cond_f3
    iget p1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerFrameBytesSize:I

    new-array p1, p1, [B

    iput-object p1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerBuffer:[B

    .line 94
    iput-boolean p3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRunning:Z

    return p3
.end method

.method private initRecord(IIIZ)Z
    .registers 12

    .line 99
    iput p1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderSampleRate:I

    .line 100
    iput p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderChannelCount:I

    const/4 p1, 0x1

    if-ne p2, p1, :cond_a

    const/16 p2, 0x10

    goto :goto_c

    :cond_a
    const/16 p2, 0xc

    .line 101
    :goto_c
    iput p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderChannelConfig:I

    .line 102
    iput p3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderFrameSampleSize:I

    .line 103
    iget p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderChannelCount:I

    mul-int p3, p3, p2

    const/4 p2, 0x2

    mul-int/lit8 p3, p3, 0x2

    iput p3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderFrameBytesSize:I

    if-eqz p4, :cond_1e

    const/4 p3, 0x7

    .line 105
    iput p3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderSource:I

    .line 107
    :cond_1e
    iget p3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderSampleRate:I

    iget p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderChannelConfig:I

    invoke-static {p3, p4, p2}, Landroid/media/AudioRecord;->getMinBufferSize(III)I

    move-result p2

    .line 108
    iget p3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderFrameSampleSize:I

    div-int p4, p2, p3

    rem-int p3, p2, p3

    const/4 v0, 0x0

    if-nez p3, :cond_31

    const/4 p3, 0x0

    goto :goto_32

    :cond_31
    const/4 p3, 0x1

    :goto_32
    add-int/2addr p4, p3

    iget p3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderFrameSampleSize:I

    mul-int p4, p4, p3

    iput p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderSystemBufferSize:I

    .line 110
    new-instance p3, Ljava/lang/StringBuilder;

    const-string p4, "AudioRecord created: recordMinSize="

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

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

    const-string p2, ", mRecorderSystemBufferSize="

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

    iget p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderSystemBufferSize:I

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

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

    move-result-object p2

    const-string p3, "MacawAudioStreamThread"

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

    .line 111
    new-instance p2, Ljava/lang/StringBuilder;

    const-string p4, "AudioRecord created: Source="

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

    iget p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderSource:I

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

    const-string p4, ", SampleRate="

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

    iget p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderSampleRate:I

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

    const-string p4, ", ChannelCount="

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

    iget p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderChannelCount:I

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

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

    move-result-object p2

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

    const/4 p2, 0x0

    .line 113
    iput-object p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorder:Landroid/media/AudioRecord;

    .line 115
    :try_start_80
    new-instance p4, Landroid/media/AudioRecord;

    iget v2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderSource:I

    iget v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderSampleRate:I

    iget v4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderChannelConfig:I

    const/4 v5, 0x2

    iget v6, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderSystemBufferSize:I

    move-object v1, p4

    invoke-direct/range {v1 .. v6}, Landroid/media/AudioRecord;-><init>(IIIII)V

    iput-object p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorder:Landroid/media/AudioRecord;
    :try_end_91
    .catch Ljava/lang/IllegalArgumentException; {:try_start_80 .. :try_end_91} :catch_ab
    .catch Ljava/lang/Exception; {:try_start_80 .. :try_end_91} :catch_92

    goto :goto_c3

    :catch_92
    move-exception p4

    .line 122
    new-instance v1, Ljava/lang/StringBuilder;

    const-string v2, "AudioRecord created: catched an unknown exception: "

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

    invoke-virtual {p4}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;

    move-result-object p4

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

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

    move-result-object p4

    .line 8079
    invoke-static {p3, p4, p1}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Z)V

    .line 123
    iput-object p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorder:Landroid/media/AudioRecord;

    goto :goto_c3

    :catch_ab
    move-exception p4

    .line 118
    new-instance v1, Ljava/lang/StringBuilder;

    const-string v2, "AudioRecord created: failed due to illegal argument: "

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

    invoke-virtual {p4}, Ljava/lang/IllegalArgumentException;->getMessage()Ljava/lang/String;

    move-result-object p4

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

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

    move-result-object p4

    .line 7079
    invoke-static {p3, p4, p1}, Lcom/imo/android/imoim/util/bt;->a(Ljava/lang/String;Ljava/lang/String;Z)V

    .line 119
    iput-object p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorder:Landroid/media/AudioRecord;

    .line 126
    :goto_c3
    iget-object p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorder:Landroid/media/AudioRecord;

    if-eqz p4, :cond_eb

    invoke-virtual {p4}, Landroid/media/AudioRecord;->getState()I

    move-result p4

    if-eq p4, p1, :cond_eb

    .line 127
    new-instance p4, Ljava/lang/StringBuilder;

    const-string v1, "AudioRecord created: failed; state="

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

    iget-object v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorder:Landroid/media/AudioRecord;

    invoke-virtual {v1}, Landroid/media/AudioRecord;->getState()I

    move-result v1

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

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

    move-result-object p4

    .line 9075
    invoke-static {p3, p4}, Lcom/imo/android/imoim/util/bt;->e(Ljava/lang/String;Ljava/lang/String;)V

    .line 128
    iget-object p4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorder:Landroid/media/AudioRecord;

    invoke-virtual {p4}, Landroid/media/AudioRecord;->release()V

    .line 129
    iput-object p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorder:Landroid/media/AudioRecord;

    .line 132
    :cond_eb
    iget-object p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorder:Landroid/media/AudioRecord;

    if-nez p2, :cond_f5

    const-string p1, "AudioRecord created: create Failed"

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

    return v0

    .line 136
    :cond_f5
    iget p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderFrameBytesSize:I

    new-array p2, p2, [B

    iput-object p2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderBuffer:[B

    .line 137
    iput-boolean p1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRunning:Z

    return p1
.end method


# virtual methods
.method public init(IIIZ)Z
    .registers 7

    .line 142
    iget v0, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mAudioDeviceType:I

    if-nez v0, :cond_9

    .line 143
    invoke-direct {p0, p1, p2, p3, p4}, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->initRecord(IIIZ)Z

    move-result p1

    return p1

    :cond_9
    const/4 v1, 0x1

    if-ne v0, v1, :cond_11

    .line 147
    invoke-direct {p0, p1, p2, p3, p4}, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->initPlay(IIIZ)Z

    move-result p1

    return p1

    :cond_11
    const/4 p1, 0x0

    return p1
.end method

.method public playRun()V
    .registers 8

    const-string v0, "MacawAudioStreamThread"

    const-string v1, "playThread run start"

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

    const/16 v1, -0x10

    .line 166
    invoke-static {v1}, Landroid/os/Process;->setThreadPriority(I)V

    .line 168
    iget-object v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;

    if-nez v1, :cond_11

    return-void

    .line 172
    :cond_11
    iget v2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerSystemBufferSize:I

    new-array v3, v2, [B

    const/4 v4, 0x0

    invoke-virtual {v1, v3, v4, v2}, Landroid/media/AudioTrack;->write([BII)I

    .line 174
    :try_start_19
    iget-object v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;

    invoke-virtual {v1}, Landroid/media/AudioTrack;->play()V
    :try_end_1e
    .catch Ljava/lang/IllegalStateException; {:try_start_19 .. :try_end_1e} :catch_94
    .catch Ljava/lang/Exception; {:try_start_19 .. :try_end_1e} :catch_1f

    goto :goto_35

    :catch_1f
    move-exception v1

    .line 181
    new-instance v2, Ljava/lang/StringBuilder;

    const-string v3, "AudioTrack.play() encountered an unexpected exception: "

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

    invoke-virtual {v1}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;

    move-result-object v1

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

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

    move-result-object v1

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

    .line 184
    :goto_35
    iget-boolean v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRunning:Z

    if-eqz v1, :cond_65

    .line 186
    :try_start_39
    iget-object v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mMacawHandler:Lcom/imo/android/imoim/av/macaw/MacawHandler;

    iget-wide v2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mMacawContext:J

    iget-object v5, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerBuffer:[B

    iget v6, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerFrameBytesSize:I

    invoke-virtual {v1, v2, v3, v5, v6}, Lcom/imo/android/imoim/av/macaw/MacawHandler;->readDataFromJavaDeviceStream(J[BI)I

    .line 187
    iget-object v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;

    iget-object v2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerBuffer:[B

    iget v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayerFrameBytesSize:I

    invoke-virtual {v1, v2, v4, v3}, Landroid/media/AudioTrack;->write([BII)I
    :try_end_4d
    .catch Ljava/lang/Exception; {:try_start_39 .. :try_end_4d} :catch_4e

    goto :goto_35

    :catch_4e
    move-exception v1

    .line 189
    new-instance v2, Ljava/lang/StringBuilder;

    const-string v3, "AudioTrack.play() encounter exception: "

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

    invoke-virtual {v1}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;

    move-result-object v1

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

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

    move-result-object v1

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

    goto :goto_35

    .line 194
    :cond_65
    :try_start_65
    iget-object v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;

    invoke-virtual {v1}, Landroid/media/AudioTrack;->flush()V

    .line 195
    iget-object v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;

    invoke-virtual {v1}, Landroid/media/AudioTrack;->stop()V

    .line 196
    iget-object v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;

    invoke-virtual {v1}, Landroid/media/AudioTrack;->release()V
    :try_end_74
    .catch Ljava/lang/Exception; {:try_start_65 .. :try_end_74} :catch_75

    goto :goto_8b

    :catch_75
    move-exception v1

    .line 199
    new-instance v2, Ljava/lang/StringBuilder;

    const-string v3, "AudioTrack.play() flush/stop/release failed: "

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

    invoke-virtual {v1}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;

    move-result-object v1

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

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

    move-result-object v1

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

    :goto_8b
    const/4 v1, 0x0

    .line 201
    iput-object v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mPlayer:Landroid/media/AudioTrack;

    const-string v1, "playThread run end"

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

    return-void

    :catch_94
    move-exception v1

    .line 177
    new-instance v2, Ljava/lang/StringBuilder;

    const-string v3, "AudioTrack.play() failed due to illegal argument: "

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

    invoke-virtual {v1}, Ljava/lang/IllegalStateException;->getMessage()Ljava/lang/String;

    move-result-object v1

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

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

    move-result-object v1

    const/4 v2, 0x1

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

    return-void
.end method

.method public recordRun()V
    .registers 8

    const-string v0, "MacawAudioStreamThread"

    const-string v1, "recordthread run start"

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

    const/16 v1, -0x10

    .line 207
    invoke-static {v1}, Landroid/os/Process;->setThreadPriority(I)V

    .line 209
    iget-object v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorder:Landroid/media/AudioRecord;

    if-nez v1, :cond_11

    return-void

    :cond_11
    const/4 v2, 0x1

    .line 214
    :try_start_12
    invoke-virtual {v1}, Landroid/media/AudioRecord;->startRecording()V
    :try_end_15
    .catch Ljava/lang/IllegalStateException; {:try_start_12 .. :try_end_15} :catch_163
    .catch Ljava/lang/Exception; {:try_start_12 .. :try_end_15} :catch_16

    goto :goto_2c

    :catch_16
    move-exception v1

    .line 221
    new-instance v3, Ljava/lang/StringBuilder;

    const-string v4, "Recorder.startRecording(): encountered an unexpected exception: "

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

    invoke-virtual {v1}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;

    move-result-object v1

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

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

    move-result-object v1

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

    .line 224
    :cond_2c
    :goto_2c
    iget-boolean v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRunning:Z

    if-eqz v1, :cond_112

    const/4 v1, -0x1

    const/4 v3, 0x0

    .line 227
    :try_start_32
    iget-object v4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorder:Landroid/media/AudioRecord;

    iget-object v5, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderBuffer:[B

    iget v6, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderFrameBytesSize:I

    invoke-virtual {v4, v5, v3, v6}, Landroid/media/AudioRecord;->read([BII)I

    move-result v1
    :try_end_3c
    .catch Ljava/lang/Exception; {:try_start_32 .. :try_end_3c} :catch_3d

    goto :goto_53

    :catch_3d
    move-exception v4

    .line 229
    new-instance v5, Ljava/lang/StringBuilder;

    const-string v6, "record read Exception: "

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

    invoke-virtual {v4}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;

    move-result-object v4

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

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

    move-result-object v4

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

    :goto_53
    if-gtz v1, :cond_cd

    const/4 v3, -0x2

    if-eq v1, v3, :cond_5b

    const/4 v3, -0x3

    if-ne v1, v3, :cond_86

    .line 234
    :cond_5b
    iget v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderTotalLength:I

    const/16 v4, 0x1900

    if-le v3, v4, :cond_bf

    iget v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderReadErrorTimes:I

    const/16 v4, 0x14

    if-ge v3, v4, :cond_bf

    add-int/lit8 v3, v3, 0x1

    .line 235
    iput v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderReadErrorTimes:I

    .line 236
    new-instance v3, Ljava/lang/StringBuilder;

    const-string v4, "Mic may be rapped by another app, restart mRecorder to get it back, retrying "

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

    iget v4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderReadErrorTimes:I

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

    const-string v4, "errorcode="

    invoke-virtual {v3, v4}, 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 v3

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

    .line 242
    :cond_86
    iget v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderFailReadTimes:I

    add-int/2addr v3, v2

    iput v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderFailReadTimes:I

    const-wide/16 v3, 0x14

    .line 245
    :try_start_8d
    invoke-static {v3, v4}, Ljava/lang/Thread;->sleep(J)V
    :try_end_90
    .catch Ljava/lang/InterruptedException; {:try_start_8d .. :try_end_90} :catch_91

    goto :goto_9d

    :catch_91
    const-string v3, "audio record thread interrupted"

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

    .line 248
    invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;

    move-result-object v3

    invoke-virtual {v3}, Ljava/lang/Thread;->interrupt()V

    .line 251
    :goto_9d
    iget v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderFailReadTimes:I

    const/16 v4, 0x64

    if-lt v3, v4, :cond_2c

    .line 252
    new-instance v2, Ljava/lang/StringBuilder;

    const-string v3, "audio record read error, readTimes="

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

    iget v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderFailReadTimes:I

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

    const-string v3, ", threshold=100errorcode="

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

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

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

    move-result-object v1

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

    goto :goto_112

    .line 238
    :cond_bf
    invoke-static {v1}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;

    move-result-object v1

    const-string v2, "audio record read error:"

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

    move-result-object v1

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

    goto :goto_112

    .line 256
    :cond_cd
    iput v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderFailReadTimes:I

    .line 257
    iget v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderFrameBytesSize:I

    if-ge v1, v3, :cond_e9

    .line 258
    new-instance v3, Ljava/lang/StringBuilder;

    const-string v4, "mRecorder: read "

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

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

    const-string v4, " bytes"

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

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

    move-result-object v3

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

    .line 261
    :cond_e9
    :try_start_e9
    iget-object v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mMacawHandler:Lcom/imo/android/imoim/av/macaw/MacawHandler;

    iget-wide v4, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mMacawContext:J

    iget-object v6, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderBuffer:[B

    invoke-virtual {v3, v4, v5, v6, v1}, Lcom/imo/android/imoim/av/macaw/MacawHandler;->writeDataToJavaDeviceStream(J[BI)I

    move-result v1

    .line 262
    iget v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderTotalLength:I

    add-int/2addr v3, v1

    iput v3, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderTotalLength:I
    :try_end_f8
    .catch Ljava/lang/Exception; {:try_start_e9 .. :try_end_f8} :catch_fa

    goto/16 :goto_2c

    :catch_fa
    move-exception v1

    .line 264
    new-instance v3, Ljava/lang/StringBuilder;

    const-string v4, "audio record thread writeDataToJavaDeviceStream exception: "

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

    invoke-virtual {v1}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;

    move-result-object v1

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

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

    move-result-object v1

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

    goto/16 :goto_2c

    .line 269
    :cond_112
    :goto_112
    iget-object v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorder:Landroid/media/AudioRecord;

    if-eqz v1, :cond_14f

    .line 271
    :try_start_116
    invoke-virtual {v1}, Landroid/media/AudioRecord;->stop()V

    .line 272
    iget-object v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorder:Landroid/media/AudioRecord;

    invoke-virtual {v1}, Landroid/media/AudioRecord;->release()V
    :try_end_11e
    .catch Ljava/lang/IllegalStateException; {:try_start_116 .. :try_end_11e} :catch_136
    .catch Ljava/lang/Exception; {:try_start_116 .. :try_end_11e} :catch_11f

    goto :goto_14c

    :catch_11f
    move-exception v1

    .line 277
    new-instance v2, Ljava/lang/StringBuilder;

    const-string v3, "stop mRecorder encountered an unexpected exception: "

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

    invoke-virtual {v1}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;

    move-result-object v1

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

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

    move-result-object v1

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

    goto :goto_14c

    :catch_136
    move-exception v1

    .line 274
    new-instance v2, Ljava/lang/StringBuilder;

    const-string v3, "stop mRecorder IllegalStateException: "

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

    invoke-virtual {v1}, Ljava/lang/IllegalStateException;->getMessage()Ljava/lang/String;

    move-result-object v1

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

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

    move-result-object v1

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

    :goto_14c
    const/4 v1, 0x0

    .line 279
    iput-object v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorder:Landroid/media/AudioRecord;

    .line 281
    :cond_14f
    new-instance v1, Ljava/lang/StringBuilder;

    const-string v2, "recordThread run end, totalReadLength="

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

    iget v2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRecorderTotalLength:I

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

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

    move-result-object v1

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

    return-void

    :catch_163
    move-exception v1

    .line 217
    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 {v1}, Ljava/lang/IllegalStateException;->getMessage()Ljava/lang/String;

    move-result-object v1

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

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

    move-result-object v1

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

    return-void
.end method

.method public run()V
    .registers 3

    .line 155
    iget v0, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mAudioDeviceType:I

    if-nez v0, :cond_7

    .line 156
    invoke-virtual {p0}, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->recordRun()V

    .line 159
    :cond_7
    iget v0, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mAudioDeviceType:I

    const/4 v1, 0x1

    if-ne v0, v1, :cond_f

    .line 160
    invoke-virtual {p0}, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->playRun()V

    :cond_f
    return-void
.end method

.method public stopThread(I)V
    .registers 6

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

    const-string v1, "Stop Audio Strem thread in devive type: "

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

    iget v1, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mAudioDeviceType:I

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

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

    move-result-object v0

    const-string v1, "MacawAudioStreamThread"

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

    const/4 v0, 0x0

    .line 286
    iput-boolean v0, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mRunning:Z

    const-wide/16 v2, 0x0

    .line 287
    iput-wide v2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mMacawContext:J

    .line 288
    invoke-virtual {p0}, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->interrupt()V

    int-to-long v2, p1

    const/4 p1, 0x1

    .line 290
    :try_start_21
    invoke-virtual {p0, v2, v3}, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->join(J)V
    :try_end_24
    .catch Ljava/lang/InterruptedException; {:try_start_21 .. :try_end_24} :catch_39
    .catch Ljava/lang/Exception; {:try_start_21 .. :try_end_24} :catch_25

    goto :goto_53

    .line 296
    :catch_25
    new-instance v0, Ljava/lang/StringBuilder;

    const-string v2, "Join Audio Strem thread encountered an unexpected exception: "

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

    iget v2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mAudioDeviceType:I

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

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

    move-result-object v0

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

    goto :goto_53

    .line 292
    :catch_39
    new-instance v0, Ljava/lang/StringBuilder;

    const-string v2, "Stop Audio Strem thread was interrupted devive type: "

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

    iget v2, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mAudioDeviceType:I

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

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

    move-result-object v0

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

    .line 293
    invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;

    move-result-object p1

    invoke-virtual {p1}, Ljava/lang/Thread;->interrupt()V

    .line 298
    :goto_53
    new-instance p1, Ljava/lang/StringBuilder;

    const-string v0, "Stop Audio Strem thread out devive type: "

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

    iget v0, p0, Lcom/imo/android/imoim/av/macaw/MacawAudioStreamThread;->mAudioDeviceType:I

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

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

    move-result-object p1

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

    return-void
.end method