IstSession.smali

.class public Lcom/iflytek/cloud/msc/ist/IstSession;
.super Lcom/iflytek/thirdparty/t;
.source "SourceFile"


# static fields
.field private static final IST_AUDIO_SAMPLE_CONTINUE:I = 0x2

.field private static final IST_AUDIO_SAMPLE_LAST:I = 0x4


# instance fields
.field private mResult:[B

.field private mSessionOut:Lcom/iflytek/msc/MSCSessionInfo;

.field private mWriteout:Lcom/iflytek/msc/MSCSessionInfo;


# direct methods
.method public constructor <init>()V
    .registers 2

    .prologue
    .line 20
    invoke-direct {p0}, Lcom/iflytek/thirdparty/t;-><init>()V

    .line 26
    new-instance v0, Lcom/iflytek/msc/MSCSessionInfo;

    invoke-direct {v0}, Lcom/iflytek/msc/MSCSessionInfo;-><init>()V

    iput-object v0, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mSessionOut:Lcom/iflytek/msc/MSCSessionInfo;

    .line 27
    new-instance v0, Lcom/iflytek/msc/MSCSessionInfo;

    invoke-direct {v0}, Lcom/iflytek/msc/MSCSessionInfo;-><init>()V

    iput-object v0, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mWriteout:Lcom/iflytek/msc/MSCSessionInfo;

    .line 29
    const/4 v0, 0x0

    iput-object v0, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mResult:[B

    return-void
.end method

.method public static getIntByTag(Ljava/lang/String;)I
    .registers 4

    .prologue
    const/4 v0, 0x0

    .line 243
    :try_start_1
    invoke-static {p0}, Lcom/iflytek/cloud/msc/ist/IstSession;->getStringByTag(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v1

    .line 244
    invoke-static {v1}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z

    move-result v2

    if-eqz v2, :cond_c

    .line 250
    :goto_b
    return v0

    .line 247
    :cond_c
    invoke-static {v1}, Ljava/lang/Integer;->parseInt(Ljava/lang/String;)I
    :try_end_f
    .catch Ljava/lang/Exception; {:try_start_1 .. :try_end_f} :catch_11

    move-result v0

    goto :goto_b

    .line 248
    :catch_11
    move-exception v1

    goto :goto_b
.end method

.method public static getStringByTag(Ljava/lang/String;)Ljava/lang/String;
    .registers 5

    .prologue
    const/4 v0, 0x0

    .line 260
    .line 262
    :try_start_1
    new-instance v1, Lcom/iflytek/msc/MSCSessionInfo;

    invoke-direct {v1}, Lcom/iflytek/msc/MSCSessionInfo;-><init>()V

    .line 263
    const/4 v2, 0x0

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

    move-result-object v3

    invoke-static {v2, v3, v1}, Lcom/iflytek/msc/MSC;->QISRGetParam([C[BLcom/iflytek/msc/MSCSessionInfo;)I

    move-result v2

    .line 264
    if-nez v2, :cond_1c

    .line 265
    new-instance v2, Ljava/lang/String;

    iget-object v1, v1, Lcom/iflytek/msc/MSCSessionInfo;->buffer:[B

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

    invoke-virtual {v2}, Ljava/lang/String;->trim()Ljava/lang/String;
    :try_end_1b
    .catch Ljava/lang/Exception; {:try_start_1 .. :try_end_1b} :catch_1d

    move-result-object v0

    .line 270
    :cond_1c
    :goto_1c
    return-object v0

    .line 268
    :catch_1d
    move-exception v1

    goto :goto_1c
.end method

.method private declared-synchronized writeData([BII)V
    .registers 7
    .annotation system Ldalvik/annotation/Throws;
        value = {
            Lcom/iflytek/cloud/SpeechError;
        }
    .end annotation

    .prologue
    .line 105
    monitor-enter p0

    :try_start_1
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mClientID:[C

    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mWriteout:Lcom/iflytek/msc/MSCSessionInfo;

    invoke-static {v0, p1, p2, p3, v1}, Lcom/iflytek/msc/MSC;->QISRAudioWrite([C[BIILcom/iflytek/msc/MSCSessionInfo;)I

    move-result v0

    .line 108
    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mSessionOut:Lcom/iflytek/msc/MSCSessionInfo;

    iget-object v2, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mWriteout:Lcom/iflytek/msc/MSCSessionInfo;

    iget v2, v2, Lcom/iflytek/msc/MSCSessionInfo;->sesstatus:I

    iput v2, v1, Lcom/iflytek/msc/MSCSessionInfo;->sesstatus:I

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

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

    const-string v2, "QISRAudioWrite length:"

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

    move-result-object v1

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

    move-result-object v1

    const-string v2, ", aus="

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

    move-result-object v1

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

    move-result-object v1

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

    move-result-object v1

    invoke-static {v1}, Lcom/iflytek/cloud/msc/util/log/DebugLog;->LogI(Ljava/lang/String;)V

    .line 110
    if-eqz v0, :cond_40

    .line 111
    new-instance v0, Lcom/iflytek/cloud/SpeechError;

    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mWriteout:Lcom/iflytek/msc/MSCSessionInfo;

    iget v1, v1, Lcom/iflytek/msc/MSCSessionInfo;->errorcode:I

    invoke-direct {v0, v1}, Lcom/iflytek/cloud/SpeechError;-><init>(I)V

    throw v0
    :try_end_3d
    .catchall {:try_start_1 .. :try_end_3d} :catchall_3d

    .line 105
    :catchall_3d
    move-exception v0

    monitor-exit p0

    throw v0

    .line 113
    :cond_40
    monitor-exit p0

    return-void
.end method


# virtual methods
.method protected getAudioUrl()Ljava/lang/String;
    .registers 2

    .prologue
    .line 327
    const-string v0, "audio_url"

    invoke-virtual {p0, v0}, Lcom/iflytek/cloud/msc/ist/IstSession;->getStringValue(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v0

    return-object v0
.end method

.method public declared-synchronized getAudioVolume()I
    .registers 5

    .prologue
    const/4 v0, 0x0

    .line 130
    monitor-enter p0

    .line 133
    :try_start_2
    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mClientID:[C

    const-string v2, "volume"

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

    move-result-object v2

    iget-object v3, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mWriteout:Lcom/iflytek/msc/MSCSessionInfo;

    invoke-static {v1, v2, v3}, Lcom/iflytek/msc/MSC;->QISRGetParam([C[BLcom/iflytek/msc/MSCSessionInfo;)I
    :try_end_f
    .catch Ljava/lang/Exception; {:try_start_2 .. :try_end_f} :catch_47
    .catchall {:try_start_2 .. :try_end_f} :catchall_44

    move-result v1

    .line 135
    if-nez v1, :cond_26

    .line 136
    :try_start_12
    new-instance v2, Ljava/lang/String;

    iget-object v3, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mWriteout:Lcom/iflytek/msc/MSCSessionInfo;

    iget-object v3, v3, Lcom/iflytek/msc/MSCSessionInfo;->buffer:[B

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

    .line 140
    new-instance v3, Ljava/lang/String;

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

    invoke-static {v3}, Ljava/lang/Integer;->parseInt(Ljava/lang/String;)I
    :try_end_23
    .catch Ljava/lang/Exception; {:try_start_12 .. :try_end_23} :catch_2c
    .catchall {:try_start_12 .. :try_end_23} :catchall_44

    move-result v0

    .line 147
    :goto_24
    monitor-exit p0

    return v0

    .line 142
    :cond_26
    :try_start_26
    const-string v2, "VAD CHECK FALSE"

    invoke-static {v2}, Lcom/iflytek/cloud/msc/util/log/DebugLog;->LogI(Ljava/lang/String;)V
    :try_end_2b
    .catch Ljava/lang/Exception; {:try_start_26 .. :try_end_2b} :catch_2c
    .catchall {:try_start_26 .. :try_end_2b} :catchall_44

    goto :goto_24

    .line 144
    :catch_2c
    move-exception v2

    .line 145
    :goto_2d
    :try_start_2d
    new-instance v2, Ljava/lang/StringBuilder;

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

    const-string v3, "getAudioVolume Exception vadret = "

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

    move-result-object v2

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

    move-result-object v1

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

    move-result-object v1

    invoke-static {v1}, Lcom/iflytek/cloud/msc/util/log/DebugLog;->LogD(Ljava/lang/String;)V
    :try_end_43
    .catchall {:try_start_2d .. :try_end_43} :catchall_44

    goto :goto_24

    .line 130
    :catchall_44
    move-exception v0

    monitor-exit p0

    throw v0

    .line 144
    :catch_47
    move-exception v1

    move v1, v0

    goto :goto_2d
.end method

.method public declared-synchronized getEpStatus()I
    .registers 2

    .prologue
    .line 120
    monitor-enter p0

    :try_start_1
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mWriteout:Lcom/iflytek/msc/MSCSessionInfo;

    iget v0, v0, Lcom/iflytek/msc/MSCSessionInfo;->epstatues:I
    :try_end_5
    .catchall {:try_start_1 .. :try_end_5} :catchall_7

    .line 121
    monitor-exit p0

    return v0

    .line 120
    :catchall_7
    move-exception v0

    monitor-exit p0

    throw v0
.end method

.method public declared-synchronized getIntValue(Ljava/lang/String;)I
    .registers 5

    .prologue
    const/4 v0, 0x0

    .line 156
    monitor-enter p0

    :try_start_2
    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mClientID:[C
    :try_end_4
    .catchall {:try_start_2 .. :try_end_4} :catchall_21

    if-nez v1, :cond_8

    .line 169
    :cond_6
    :goto_6
    monitor-exit p0

    return v0

    .line 161
    :cond_8
    :try_start_8
    invoke-virtual {p0, p1}, Lcom/iflytek/cloud/msc/ist/IstSession;->getStringValue(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v1

    .line 162
    invoke-static {v1}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z

    move-result v2

    if-nez v2, :cond_6

    .line 163
    new-instance v2, Ljava/lang/String;

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

    invoke-static {v2}, Ljava/lang/Integer;->parseInt(Ljava/lang/String;)I
    :try_end_1a
    .catch Ljava/lang/Exception; {:try_start_8 .. :try_end_1a} :catch_1c
    .catchall {:try_start_8 .. :try_end_1a} :catchall_21

    move-result v0

    goto :goto_6

    .line 166
    :catch_1c
    move-exception v1

    .line 167
    :try_start_1d
    invoke-static {v1}, Lcom/iflytek/cloud/msc/util/log/DebugLog;->LogE(Ljava/lang/Throwable;)V
    :try_end_20
    .catchall {:try_start_1d .. :try_end_20} :catchall_21

    goto :goto_6

    .line 156
    :catchall_21
    move-exception v0

    monitor-exit p0

    throw v0
.end method

.method public declared-synchronized getIntValue(Ljava/lang/String;I)I
    .registers 5

    .prologue
    .line 178
    monitor-enter p0

    :try_start_1
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mClientID:[C
    :try_end_3
    .catchall {:try_start_1 .. :try_end_3} :catchall_20

    if-nez v0, :cond_7

    .line 191
    :cond_5
    :goto_5
    monitor-exit p0

    return p2

    .line 183
    :cond_7
    :try_start_7
    invoke-virtual {p0, p1}, Lcom/iflytek/cloud/msc/ist/IstSession;->getStringValue(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v0

    .line 184
    invoke-static {v0}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z

    move-result v1

    if-nez v1, :cond_5

    .line 185
    new-instance v1, Ljava/lang/String;

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

    invoke-static {v1}, Ljava/lang/Integer;->parseInt(Ljava/lang/String;)I
    :try_end_19
    .catch Ljava/lang/Exception; {:try_start_7 .. :try_end_19} :catch_1b
    .catchall {:try_start_7 .. :try_end_19} :catchall_20

    move-result p2

    goto :goto_5

    .line 188
    :catch_1b
    move-exception v0

    .line 189
    :try_start_1c
    invoke-static {v0}, Lcom/iflytek/cloud/msc/util/log/DebugLog;->LogE(Ljava/lang/Throwable;)V
    :try_end_1f
    .catchall {:try_start_1c .. :try_end_1f} :catchall_20

    goto :goto_5

    .line 178
    :catchall_20
    move-exception v0

    monitor-exit p0

    throw v0
.end method

.method public getResultData()[B
    .registers 2

    .prologue
    .line 283
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mResult:[B

    return-object v0
.end method

.method protected getSessionID()Ljava/lang/String;
    .registers 2

    .prologue
    .line 317
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mSessionID:Ljava/lang/String;

    if-nez v0, :cond_c

    .line 318
    const-string v0, "sid"

    invoke-virtual {p0, v0}, Lcom/iflytek/cloud/msc/ist/IstSession;->getStringValue(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v0

    iput-object v0, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mSessionID:Ljava/lang/String;

    .line 320
    :cond_c
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mSessionID:Ljava/lang/String;

    return-object v0
.end method

.method public getStatus()Lcom/iflytek/thirdparty/t$a;
    .registers 7
    .annotation system Ldalvik/annotation/Throws;
        value = {
            Lcom/iflytek/cloud/SpeechError;
        }
    .end annotation

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

    move-result-wide v2

    .line 289
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mClientID:[C

    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mSessionOut:Lcom/iflytek/msc/MSCSessionInfo;

    invoke-static {v0, v1}, Lcom/iflytek/msc/MSC;->QISRGetResult([CLcom/iflytek/msc/MSCSessionInfo;)[B

    move-result-object v0

    iput-object v0, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mResult:[B

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

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

    const-string v1, "QISRGetResult leave: "

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

    move-result-object v1

    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mResult:[B

    if-eqz v0, :cond_49

    const/4 v0, 0x1

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

    move-result-object v0

    const-string v1, " time:"

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

    move-result-object v0

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

    move-result-wide v4

    sub-long v2, v4, v2

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

    move-result-object v0

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

    move-result-object v0

    .line 290
    invoke-static {v0}, Lcom/iflytek/cloud/msc/util/log/DebugLog;->LogI(Ljava/lang/String;)V

    .line 293
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mSessionOut:Lcom/iflytek/msc/MSCSessionInfo;

    iget v0, v0, Lcom/iflytek/msc/MSCSessionInfo;->errorcode:I

    .line 294
    if-nez v0, :cond_96

    .line 295
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mSessionOut:Lcom/iflytek/msc/MSCSessionInfo;

    iget v0, v0, Lcom/iflytek/msc/MSCSessionInfo;->rsltstatus:I

    .line 296
    packed-switch v0, :pswitch_data_b2

    .line 307
    :pswitch_46
    sget-object v0, Lcom/iflytek/thirdparty/t$a;->c:Lcom/iflytek/thirdparty/t$a;

    :goto_48
    return-object v0

    .line 290
    :cond_49
    const/4 v0, 0x0

    goto :goto_1e

    .line 298
    :pswitch_4b
    new-instance v1, Ljava/lang/StringBuilder;

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

    const-string v2, "ResultStatus: hasResult"

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

    move-result-object v1

    invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(I)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/iflytek/cloud/msc/util/log/DebugLog;->LogD(Ljava/lang/String;)V

    .line 299
    sget-object v0, Lcom/iflytek/thirdparty/t$a;->a:Lcom/iflytek/thirdparty/t$a;

    goto :goto_48

    .line 301
    :pswitch_64
    new-instance v1, Ljava/lang/StringBuilder;

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

    const-string v2, "ResultStatus: noResult"

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

    move-result-object v1

    invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(I)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/iflytek/cloud/msc/util/log/DebugLog;->LogI(Ljava/lang/String;)V

    .line 302
    sget-object v0, Lcom/iflytek/thirdparty/t$a;->c:Lcom/iflytek/thirdparty/t$a;

    goto :goto_48

    .line 304
    :pswitch_7d
    new-instance v1, Ljava/lang/StringBuilder;

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

    const-string v2, "ResultStatus: resultOver"

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

    move-result-object v1

    invoke-virtual {v1, v0}, Ljava/lang/StringBuilder;->append(I)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/iflytek/cloud/msc/util/log/DebugLog;->LogD(Ljava/lang/String;)V

    .line 305
    sget-object v0, Lcom/iflytek/thirdparty/t$a;->f:Lcom/iflytek/thirdparty/t$a;

    goto :goto_48

    .line 309
    :cond_96
    new-instance v1, Ljava/lang/StringBuilder;

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

    const-string v2, "Result: error errorcode is "

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

    move-result-object v1

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

    move-result-object v1

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

    move-result-object v1

    invoke-static {v1}, Lcom/iflytek/cloud/msc/util/log/DebugLog;->LogE(Ljava/lang/String;)V

    .line 310
    new-instance v1, Lcom/iflytek/cloud/SpeechError;

    invoke-direct {v1, v0}, Lcom/iflytek/cloud/SpeechError;-><init>(I)V

    throw v1

    .line 296
    :pswitch_data_b2
    .packed-switch 0x0
        :pswitch_4b
        :pswitch_46
        :pswitch_64
        :pswitch_46
        :pswitch_46
        :pswitch_7d
    .end packed-switch
.end method

.method public declared-synchronized getStringValue(Ljava/lang/String;)Ljava/lang/String;
    .registers 6

    .prologue
    const/4 v0, 0x0

    .line 220
    monitor-enter p0

    :try_start_2
    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mClientID:[C
    :try_end_4
    .catchall {:try_start_2 .. :try_end_4} :catchall_21

    if-nez v1, :cond_8

    .line 232
    :cond_6
    :goto_6
    monitor-exit p0

    return-object v0

    .line 225
    :cond_8
    :try_start_8
    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mClientID:[C

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

    move-result-object v2

    iget-object v3, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mSessionOut:Lcom/iflytek/msc/MSCSessionInfo;

    invoke-static {v1, v2, v3}, Lcom/iflytek/msc/MSC;->QISRGetParam([C[BLcom/iflytek/msc/MSCSessionInfo;)I

    move-result v1

    .line 226
    if-nez v1, :cond_6

    .line 227
    new-instance v1, Ljava/lang/String;

    iget-object v2, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mSessionOut:Lcom/iflytek/msc/MSCSessionInfo;

    iget-object v2, v2, Lcom/iflytek/msc/MSCSessionInfo;->buffer:[B

    invoke-direct {v1, v2}, Ljava/lang/String;-><init>([B)V
    :try_end_1f
    .catch Ljava/lang/Exception; {:try_start_8 .. :try_end_1f} :catch_24
    .catchall {:try_start_8 .. :try_end_1f} :catchall_21

    move-object v0, v1

    goto :goto_6

    .line 220
    :catchall_21
    move-exception v0

    monitor-exit p0

    throw v0

    .line 230
    :catch_24
    move-exception v1

    goto :goto_6
.end method

.method public declared-synchronized hasResult()Z
    .registers 2

    .prologue
    .line 279
    monitor-enter p0

    :try_start_1
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mSessionOut:Lcom/iflytek/msc/MSCSessionInfo;

    iget v0, v0, Lcom/iflytek/msc/MSCSessionInfo;->sesstatus:I
    :try_end_5
    .catchall {:try_start_1 .. :try_end_5} :catchall_c

    if-nez v0, :cond_a

    const/4 v0, 0x1

    :goto_8
    monitor-exit p0

    return v0

    :cond_a
    const/4 v0, 0x0

    goto :goto_8

    :catchall_c
    move-exception v0

    monitor-exit p0

    throw v0
.end method

.method public declared-synchronized pushAudioData([BI)V
    .registers 4
    .annotation system Ldalvik/annotation/Throws;
        value = {
            Lcom/iflytek/cloud/SpeechError;
        }
    .end annotation

    .prologue
    .line 84
    monitor-enter p0

    const/4 v0, 0x2

    :try_start_2
    invoke-direct {p0, p1, p2, v0}, Lcom/iflytek/cloud/msc/ist/IstSession;->writeData([BII)V
    :try_end_5
    .catchall {:try_start_2 .. :try_end_5} :catchall_7

    .line 85
    monitor-exit p0

    return-void

    .line 84
    :catchall_7
    move-exception v0

    monitor-exit p0

    throw v0
.end method

.method public declared-synchronized pushEndFlag()V
    .registers 4
    .annotation system Ldalvik/annotation/Throws;
        value = {
            Lcom/iflytek/cloud/SpeechError;
        }
    .end annotation

    .prologue
    .line 88
    monitor-enter p0

    const/4 v0, 0x0

    :try_start_2
    new-array v0, v0, [B

    .line 89
    const-string v1, "LastDataFlag"

    const/4 v2, 0x0

    invoke-static {v1, v2}, Lcom/iflytek/cloud/msc/util/log/PerfLogger;->appendInfo(Ljava/lang/String;Ljava/lang/String;)V

    .line 90
    const-string v1, "IstSession pushEndFlag"

    invoke-static {v1}, Lcom/iflytek/cloud/msc/util/log/DebugLog;->LogD(Ljava/lang/String;)V

    .line 91
    const/4 v1, 0x0

    const/4 v2, 0x4

    invoke-direct {p0, v0, v1, v2}, Lcom/iflytek/cloud/msc/ist/IstSession;->writeData([BII)V
    :try_end_14
    .catchall {:try_start_2 .. :try_end_14} :catchall_16

    .line 92
    monitor-exit p0

    return-void

    .line 88
    :catchall_16
    move-exception v0

    monitor-exit p0

    throw v0
.end method

.method public sessionBegin(Landroid/content/Context;Ljava/lang/String;Lcom/iflytek/thirdparty/s;)I
    .registers 10
    .annotation system Ldalvik/annotation/Throws;
        value = {
            Lcom/iflytek/cloud/SpeechError;,
            Ljava/io/UnsupportedEncodingException;
        }
    .end annotation

    .prologue
    .line 35
    invoke-static {p1, p2, p3}, Lcom/iflytek/thirdparty/af;->c(Landroid/content/Context;Ljava/lang/String;Lcom/iflytek/thirdparty/s;)Ljava/lang/String;

    move-result-object v0

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

    move-result-wide v2

    .line 39
    const-class v1, Lcom/iflytek/cloud/msc/ist/IstSession;

    monitor-enter v1

    .line 40
    :try_start_b
    const-string v4, "MSCSessionBegin"

    const/4 v5, 0x0

    invoke-static {v4, v5}, Lcom/iflytek/cloud/msc/util/log/PerfLogger;->appendInfo(Ljava/lang/String;Ljava/lang/String;)V

    .line 41
    invoke-static {p2}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z

    move-result v4

    if-eqz v4, :cond_74

    .line 42
    invoke-static {v0}, Lcom/iflytek/cloud/msc/util/log/DebugLog;->LogD(Ljava/lang/String;)V

    .line 43
    const/4 v4, 0x0

    .line 44
    invoke-virtual {p3}, Lcom/iflytek/thirdparty/s;->getParamEncoding()Ljava/lang/String;

    move-result-object v5

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

    move-result-object v0

    iget-object v5, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mSessionOut:Lcom/iflytek/msc/MSCSessionInfo;

    .line 43
    invoke-static {v4, v0, v5}, Lcom/iflytek/msc/MSC;->QISRSessionBegin([B[BLcom/iflytek/msc/MSCSessionInfo;)[C

    move-result-object v0

    iput-object v0, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mClientID:[C

    .line 51
    :goto_2b
    const-string v0, "SessionBeginEnd"

    const/4 v4, 0x0

    invoke-static {v0, v4}, Lcom/iflytek/cloud/msc/util/log/PerfLogger;->appendInfo(Ljava/lang/String;Ljava/lang/String;)V

    .line 52
    monitor-exit v1
    :try_end_32
    .catchall {:try_start_b .. :try_end_32} :catchall_a3

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

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

    const-string v1, "sessionBegin ErrCode:"

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

    move-result-object v0

    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mSessionOut:Lcom/iflytek/msc/MSCSessionInfo;

    iget v1, v1, Lcom/iflytek/msc/MSCSessionInfo;->errorcode:I

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

    move-result-object v0

    const-string v1, " time:"

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

    move-result-object v0

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

    move-result-wide v4

    sub-long v2, v4, v2

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

    move-result-object v0

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

    move-result-object v0

    .line 53
    invoke-static {v0}, Lcom/iflytek/cloud/msc/util/log/DebugLog;->LogD(Ljava/lang/String;)V

    .line 56
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mSessionOut:Lcom/iflytek/msc/MSCSessionInfo;

    iget v0, v0, Lcom/iflytek/msc/MSCSessionInfo;->errorcode:I

    .line 57
    if-eqz v0, :cond_a6

    .line 59
    const/16 v1, 0x2791

    if-eq v0, v1, :cond_a6

    const/16 v1, 0x2781

    if-eq v0, v1, :cond_a6

    const/16 v1, 0x2794

    if-eq v0, v1, :cond_a6

    .line 62
    new-instance v1, Lcom/iflytek/cloud/SpeechError;

    invoke-direct {v1, v0}, Lcom/iflytek/cloud/SpeechError;-><init>(I)V

    throw v1

    .line 47
    :cond_74
    :try_start_74
    invoke-virtual {p3}, Lcom/iflytek/thirdparty/s;->getParamEncoding()Ljava/lang/String;

    move-result-object v4

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

    move-result-object v4

    .line 48
    invoke-virtual {p3}, Lcom/iflytek/thirdparty/s;->getParamEncoding()Ljava/lang/String;

    move-result-object v5

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

    move-result-object v0

    iget-object v5, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mSessionOut:Lcom/iflytek/msc/MSCSessionInfo;

    .line 46
    invoke-static {v4, v0, v5}, Lcom/iflytek/msc/MSC;->QISRSessionBegin([B[BLcom/iflytek/msc/MSCSessionInfo;)[C

    move-result-object v0

    iput-object v0, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mClientID:[C

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

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

    const-string v4, "sessionBegin grammarId:"

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

    move-result-object v0

    invoke-virtual {v0, p2}, 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/iflytek/cloud/msc/util/log/DebugLog;->LogD(Ljava/lang/String;)V

    goto :goto_2b

    .line 52
    :catchall_a3
    move-exception v0

    monitor-exit v1
    :try_end_a5
    .catchall {:try_start_74 .. :try_end_a5} :catchall_a3

    throw v0

    .line 65
    :cond_a6
    return v0
.end method

.method public sessionEnd(Ljava/lang/String;)V
    .registers 9

    .prologue
    const/4 v6, 0x0

    .line 70
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mClientID:[C

    if-nez v0, :cond_6

    .line 80
    :goto_5
    return-void

    .line 73
    :cond_6
    const-string v0, "sessionEnd enter "

    invoke-static {v0}, Lcom/iflytek/cloud/msc/util/log/DebugLog;->LogD(Ljava/lang/String;)V

    .line 74
    invoke-static {}, Ljava/lang/System;->currentTimeMillis()J

    move-result-wide v2

    .line 75
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mClientID:[C

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

    move-result-object v1

    invoke-static {v0, v1}, Lcom/iflytek/msc/MSC;->QISRSessionEnd([C[B)I

    move-result v0

    if-nez v0, :cond_47

    const/4 v0, 0x1

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

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

    const-string v4, "sessionEnd leavel:"

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

    move-result-object v1

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

    move-result-object v0

    const-string v1, " time:"

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

    move-result-object v0

    .line 77
    invoke-static {}, Ljava/lang/System;->currentTimeMillis()J

    move-result-wide v4

    sub-long v2, v4, v2

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

    move-result-object v0

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

    move-result-object v0

    .line 76
    invoke-static {v0}, Lcom/iflytek/cloud/msc/util/log/DebugLog;->LogD(Ljava/lang/String;)V

    .line 78
    iput-object v6, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mClientID:[C

    .line 79
    iput-object v6, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mSessionID:Ljava/lang/String;

    goto :goto_5

    .line 75
    :cond_47
    const/4 v0, 0x0

    goto :goto_1c
.end method

.method public declared-synchronized setParam(Ljava/lang/String;Ljava/lang/String;)Z
    .registers 8

    .prologue
    const/4 v0, 0x0

    .line 200
    monitor-enter p0

    :try_start_2
    invoke-static {p1}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z

    move-result v1

    if-nez v1, :cond_12

    invoke-static {p2}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z

    move-result v1

    if-nez v1, :cond_12

    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mClientID:[C
    :try_end_10
    .catchall {:try_start_2 .. :try_end_10} :catchall_31

    if-nez v1, :cond_14

    .line 211
    :cond_12
    :goto_12
    monitor-exit p0

    return v0

    .line 204
    :cond_14
    const/4 v2, -0x1

    .line 206
    :try_start_15
    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/IstSession;->mClientID:[C

    const-string v3, "utf-8"

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

    move-result-object v3

    const-string v4, "utf-8"

    .line 207
    invoke-virtual {p2, v4}, Ljava/lang/String;->getBytes(Ljava/lang/String;)[B

    move-result-object v4

    .line 206
    invoke-static {v1, v3, v4}, Lcom/iflytek/msc/MSC;->QISRSetParam([C[B[B)I
    :try_end_26
    .catch Ljava/io/UnsupportedEncodingException; {:try_start_15 .. :try_end_26} :catch_2b
    .catchall {:try_start_15 .. :try_end_26} :catchall_31

    move-result v1

    .line 211
    :goto_27
    if-nez v1, :cond_12

    const/4 v0, 0x1

    goto :goto_12

    .line 208
    :catch_2b
    move-exception v1

    .line 209
    :try_start_2c
    invoke-static {v1}, Lcom/iflytek/cloud/msc/util/log/DebugLog;->LogE(Ljava/lang/Throwable;)V
    :try_end_2f
    .catchall {:try_start_2c .. :try_end_2f} :catchall_31

    move v1, v2

    goto :goto_27

    .line 200
    :catchall_31
    move-exception v0

    monitor-exit p0

    throw v0
.end method