MscTranscripter.smali

.class public Lcom/iflytek/cloud/msc/ist/MscTranscripter;
.super Lcom/iflytek/thirdparty/s;
.source "SourceFile"

# interfaces
.implements Lcom/iflytek/cloud/record/PcmRecorder$PcmRecordListener;


# static fields
.field protected static final MSG_CUSTOM_MIN:I = 0x8015

.field private static final MSG_WAIT_RESULT:I = 0x8016

.field private static final NET_PERF_MSG_DELAY:I = 0x1f4

.field private static final STATUS_HASRESULT:I = 0x0

.field private static final STATUS_LASTRESULT:I = 0x5

.field private static final STATUS_NORESULT:I = 0x2

.field private static final WAIT_RESULT_PERIOD:I = 0x1f4

.field public static mDownflow:I

.field public static mUpflow:I


# instance fields
.field private final KEY_TOTAL_AUDIO:Ljava/lang/String;

.field private final SESSION_RETRY_PERIOD:I

.field private mAccesser:Lcom/iflytek/cloud/msc/ist/AudioAccessor;

.field protected mAudioSource:I

.field private mBuffer:[B

.field private mError:Lcom/iflytek/cloud/SpeechError;

.field private mFilePath:Ljava/lang/String;

.field protected mFirstDataArrival:Z

.field protected mFirstDataWrite:Z

.field protected mFirstRecordAudio:Z

.field private mIsFirstSession:Z

.field private mIsProcRecordDataOn:Z

.field private mIsRecording:Z

.field private mIsRestarting:Z

.field private mLastMscOffset:I

.field private mLastServerOffset:I

.field protected volatile mListener:Lcom/iflytek/cloud/TranscripterListener;

.field private mMaxSessionTry:I

.field protected mPerflog:Lcom/iflytek/thirdparty/u;

.field protected mRecorder:Lcom/iflytek/cloud/record/PcmRecorder;

.field private mResultSecondLeft:I

.field protected mResults:Ljava/util/ArrayList;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/ArrayList",
            "<",
            "Ljava/lang/String;",
            ">;"
        }
    .end annotation
.end field

.field protected mSession:Lcom/iflytek/cloud/msc/ist/IstSession;

.field private mSessionID:Ljava/lang/String;

.field private mSessionRetryCount:I

.field private mSyncID:I

.field private mUseBluetooth:Z

.field protected mUstopRecord:Z


# direct methods
.method static constructor <clinit>()V
    .registers 1

    .prologue
    const/4 v0, 0x0

    .line 60
    sput v0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mUpflow:I

    .line 61
    sput v0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mDownflow:I

    return-void
.end method

.method public constructor <init>(Landroid/content/Context;Lcom/iflytek/thirdparty/ad;Landroid/os/HandlerThread;)V
    .registers 8

    .prologue
    const/4 v3, 0x1

    const/4 v2, 0x0

    const/4 v1, 0x0

    .line 107
    invoke-direct {p0, p1, p3}, Lcom/iflytek/thirdparty/s;-><init>(Landroid/content/Context;Landroid/os/HandlerThread;)V

    .line 43
    iput-object v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    .line 46
    iput-boolean v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mFirstRecordAudio:Z

    .line 48
    iput-boolean v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mFirstDataWrite:Z

    .line 50
    iput-boolean v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mFirstDataArrival:Z

    .line 52
    iput-boolean v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mUstopRecord:Z

    .line 54
    iput v3, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAudioSource:I

    .line 56
    new-instance v0, Lcom/iflytek/cloud/msc/ist/IstSession;

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

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

    .line 57
    iput-object v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mRecorder:Lcom/iflytek/cloud/record/PcmRecorder;

    .line 64
    iput-object v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mResults:Ljava/util/ArrayList;

    .line 68
    iput-object v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mBuffer:[B

    .line 69
    iput v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mLastMscOffset:I

    .line 70
    iput v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mLastServerOffset:I

    .line 71
    const/4 v0, -0x1

    iput v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mResultSecondLeft:I

    .line 72
    iput-object v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSessionID:Ljava/lang/String;

    .line 73
    iput v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSyncID:I

    .line 75
    iput-object v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mFilePath:Ljava/lang/String;

    .line 76
    iput-object v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAccesser:Lcom/iflytek/cloud/msc/ist/AudioAccessor;

    .line 77
    const-string v0, "total"

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

    .line 79
    iput v3, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mMaxSessionTry:I

    .line 80
    const/16 v0, 0x1f4

    iput v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->SESSION_RETRY_PERIOD:I

    .line 92
    iput-boolean v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mIsProcRecordDataOn:Z

    .line 93
    iput-boolean v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mIsRecording:Z

    .line 94
    iput-object v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mError:Lcom/iflytek/cloud/SpeechError;

    .line 95
    iput-boolean v3, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mIsFirstSession:Z

    .line 96
    iput-boolean v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mIsRestarting:Z

    .line 101
    iput-boolean v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mUseBluetooth:Z

    .line 104
    new-instance v0, Lcom/iflytek/thirdparty/u;

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

    iput-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mPerflog:Lcom/iflytek/thirdparty/u;

    .line 247
    iput v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSessionRetryCount:I

    .line 108
    new-instance v0, Ljava/util/ArrayList;

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

    iput-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mResults:Ljava/util/ArrayList;

    .line 109
    iput-boolean v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mUstopRecord:Z

    .line 110
    invoke-virtual {p0, p2}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->setParams(Lcom/iflytek/thirdparty/ad;)V

    .line 111
    return-void
.end method

.method private assertSessionTimes()V
    .registers 3
    .annotation system Ldalvik/annotation/Throws;
        value = {
            Lcom/iflytek/cloud/SpeechError;
        }
    .end annotation

    .prologue
    .line 775
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->isRecordMode()Z

    move-result v0

    if-eqz v0, :cond_12

    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->isRecordMode()Z

    move-result v0

    if-eqz v0, :cond_43

    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->isRecording()Z

    move-result v0

    if-nez v0, :cond_43

    .line 776
    :cond_12
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getMaxSessionTry()I

    move-result v0

    const/4 v1, -0x1

    if-eq v0, v1, :cond_43

    .line 777
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getMaxSessionTry()I

    move-result v0

    iget v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSessionRetryCount:I

    if-gt v0, v1, :cond_43

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

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

    const-string v1, "proc_Msg_Session_Begin max session try:"

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

    move-result-object v0

    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getMaxSessionTry()I

    move-result v1

    invoke-virtual {v0, v1}, 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;->LogE(Ljava/lang/String;)V

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

    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mError:Lcom/iflytek/cloud/SpeechError;

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

    throw v0

    .line 781
    :cond_43
    return-void
.end method

.method private closeAudioFile()V
    .registers 2
    .annotation system Ldalvik/annotation/Throws;
        value = {
            Ljava/io/IOException;
        }
    .end annotation

    .prologue
    .line 847
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAccesser:Lcom/iflytek/cloud/msc/ist/AudioAccessor;

    if-eqz v0, :cond_c

    .line 848
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAccesser:Lcom/iflytek/cloud/msc/ist/AudioAccessor;

    invoke-virtual {v0}, Lcom/iflytek/cloud/msc/ist/AudioAccessor;->close()V

    .line 849
    const/4 v0, 0x0

    iput-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAccesser:Lcom/iflytek/cloud/msc/ist/AudioAccessor;

    .line 851
    :cond_c
    return-void
.end method

.method private getAudioData()I
    .registers 3
    .annotation system Ldalvik/annotation/Throws;
        value = {
            Lcom/iflytek/cloud/SpeechError;,
            Ljava/io/IOException;
        }
    .end annotation

    .prologue
    .line 854
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAccesser:Lcom/iflytek/cloud/msc/ist/AudioAccessor;

    if-eqz v0, :cond_d

    .line 855
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAccesser:Lcom/iflytek/cloud/msc/ist/AudioAccessor;

    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mBuffer:[B

    invoke-virtual {v0, v1}, Lcom/iflytek/cloud/msc/ist/AudioAccessor;->getAudio([B)I

    move-result v0

    .line 857
    :goto_c
    return v0

    :cond_d
    const/4 v0, 0x0

    goto :goto_c
.end method

.method private getDataLength()J
    .registers 5

    .prologue
    .line 836
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAccesser:Lcom/iflytek/cloud/msc/ist/AudioAccessor;

    if-eqz v0, :cond_27

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

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

    const-string v1, "getDataLength len="

    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/MscTranscripter;->mAccesser:Lcom/iflytek/cloud/msc/ist/AudioAccessor;

    invoke-virtual {v1}, Lcom/iflytek/cloud/msc/ist/AudioAccessor;->getDataLength()J

    move-result-wide 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

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

    .line 838
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAccesser:Lcom/iflytek/cloud/msc/ist/AudioAccessor;

    invoke-virtual {v0}, Lcom/iflytek/cloud/msc/ist/AudioAccessor;->getDataLength()J

    move-result-wide v0

    .line 841
    :goto_26
    return-wide v0

    .line 840
    :cond_27
    const-string v0, "getDataLength file accesser is null."

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

    .line 841
    const-wide/16 v0, -0x1

    goto :goto_26
.end method

.method private getMaxSessionTry()I
    .registers 2

    .prologue
    .line 832
    iget v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mMaxSessionTry:I

    return v0
.end method

.method private hasMoreData()Z
    .registers 5

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

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

    const-string v1, "hasMoreData >>> isRecording ? "

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

    move-result-object v0

    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->isRecording()Z

    move-result v1

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

    move-result-object v0

    const-string v1, " && datalength == "

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

    move-result-object v0

    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getDataLength()J

    move-result-wide 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

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

    .line 790
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->isRecording()Z

    move-result v0

    if-nez v0, :cond_39

    .line 791
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getDataLength()J

    move-result-wide v0

    iget v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mLastMscOffset:I

    int-to-long v2, v2

    cmp-long v0, v0, v2

    if-lez v0, :cond_3b

    :cond_39
    const/4 v0, 0x1

    .line 790
    :goto_3a
    return v0

    .line 791
    :cond_3b
    const/4 v0, 0x0

    goto :goto_3a
.end method

.method private isRecordMode()Z
    .registers 3

    .prologue
    .line 770
    const/4 v0, -0x1

    iget v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAudioSource:I

    if-eq v0, v1, :cond_c

    const/4 v0, -0x2

    iget v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAudioSource:I

    if-eq v0, v1, :cond_c

    const/4 v0, 0x1

    :goto_b
    return v0

    :cond_c
    const/4 v0, 0x0

    goto :goto_b
.end method

.method private isRecording()Z
    .registers 3

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

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

    const-string v1, "isRecording:"

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

    move-result-object v0

    iget-boolean v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mIsRecording:Z

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Z)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;->LogE(Ljava/lang/String;)V

    .line 785
    iget-boolean v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mIsRecording:Z

    return v0
.end method

.method private isSessionOn()Z
    .registers 2

    .prologue
    .line 862
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSession:Lcom/iflytek/cloud/msc/ist/IstSession;

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

    if-eqz v0, :cond_8

    const/4 v0, 0x1

    :goto_7
    return v0

    :cond_8
    const/4 v0, 0x0

    goto :goto_7
.end method

.method private notifyResult(Z[B)V
    .registers 7
    .annotation system Ldalvik/annotation/Throws;
        value = {
            Lcom/iflytek/cloud/SpeechError;,
            Ljava/io/UnsupportedEncodingException;
        }
    .end annotation

    .prologue
    const/4 v1, 0x0

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

    move-result-wide v2

    iput-wide v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mStatusBegin:J

    .line 506
    if-eqz p2, :cond_54

    array-length v0, p2

    if-lez v0, :cond_54

    .line 508
    new-instance v0, Ljava/lang/String;

    const-string v2, "utf-8"

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

    .line 518
    :goto_13
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getSessionID()Ljava/lang/String;

    .line 521
    iget-object v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mResults:Ljava/util/ArrayList;

    invoke-virtual {v2, v0}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z

    .line 522
    iget-object v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    if-eqz v2, :cond_34

    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->isRunning()Z

    move-result v2

    if-eqz v2, :cond_34

    .line 525
    new-instance v2, Lcom/iflytek/cloud/TranscripterResult;

    invoke-direct {v2, v0}, Lcom/iflytek/cloud/TranscripterResult;-><init>(Ljava/lang/String;)V

    .line 526
    const-string v0, "GetNotifyResult"

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

    .line 527
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    invoke-interface {v0, v2, p1}, Lcom/iflytek/cloud/TranscripterListener;->onResult(Lcom/iflytek/cloud/TranscripterResult;Z)V

    .line 530
    :cond_34
    new-instance v0, Ljava/lang/StringBuilder;

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

    const-string v2, "msc result time:"

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

    move-result-object v0

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

    move-result-wide 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

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

    .line 533
    if-eqz p1, :cond_53

    .line 535
    invoke-virtual {p0, v1}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->exit(Lcom/iflytek/cloud/SpeechError;)V

    .line 537
    :cond_53
    return-void

    .line 509
    :cond_54
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mResults:Ljava/util/ArrayList;

    invoke-virtual {v0}, Ljava/util/ArrayList;->size()I

    move-result v0

    if-gtz v0, :cond_5e

    move-object v0, v1

    goto :goto_13

    .line 514
    :cond_5e
    const-string v0, ""

    goto :goto_13
.end method

.method private proc_Msg_Record_Stoped()V
    .registers 3
    .annotation system Ldalvik/annotation/Throws;
        value = {
            Lcom/iflytek/cloud/SpeechError;,
            Ljava/io/IOException;,
            Ljava/lang/InterruptedException;
        }
    .end annotation

    .prologue
    .line 372
    const-string v0, "recording stop"

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

    .line 373
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->releaseRecord()V

    .line 375
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mPerflog:Lcom/iflytek/thirdparty/u;

    const-string v1, "app_lau"

    invoke-virtual {v0, v1}, Lcom/iflytek/thirdparty/u;->a(Ljava/lang/String;)V

    .line 380
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    if-eqz v0, :cond_18

    .line 381
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    invoke-interface {v0}, Lcom/iflytek/cloud/TranscripterListener;->onEndOfSpeech()V

    .line 383
    :cond_18
    return-void
.end method

.method private releaseRecord()V
    .registers 5

    .prologue
    const/4 v3, 0x0

    .line 584
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mRecorder:Lcom/iflytek/cloud/record/PcmRecorder;

    if-eqz v0, :cond_30

    .line 585
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mRecorder:Lcom/iflytek/cloud/record/PcmRecorder;

    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getParam()Lcom/iflytek/thirdparty/ad;

    move-result-object v1

    const-string v2, "record_force_stop"

    invoke-virtual {v1, v2, v3}, Lcom/iflytek/thirdparty/ad;->a(Ljava/lang/String;Z)Z

    move-result v1

    invoke-virtual {v0, v1}, Lcom/iflytek/cloud/record/PcmRecorder;->stopRecord(Z)V

    .line 586
    const/4 v0, 0x0

    iput-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mRecorder:Lcom/iflytek/cloud/record/PcmRecorder;

    .line 587
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mPerflog:Lcom/iflytek/thirdparty/u;

    const-string v1, "rec_close"

    invoke-virtual {v0, v1}, Lcom/iflytek/thirdparty/u;->a(Ljava/lang/String;)V

    .line 590
    :try_start_1e
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAccesser:Lcom/iflytek/cloud/msc/ist/AudioAccessor;

    if-eqz v0, :cond_27

    .line 591
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAccesser:Lcom/iflytek/cloud/msc/ist/AudioAccessor;

    invoke-virtual {v0}, Lcom/iflytek/cloud/msc/ist/AudioAccessor;->flush()V
    :try_end_27
    .catch Ljava/lang/Exception; {:try_start_1e .. :try_end_27} :catch_33

    .line 599
    :cond_27
    iput v3, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSessionRetryCount:I

    .line 601
    iget-boolean v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mUseBluetooth:Z

    if-eqz v0, :cond_30

    .line 602
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->stopBluetooth()V

    .line 606
    :cond_30
    iput-boolean v3, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mIsRecording:Z

    .line 607
    :goto_32
    return-void

    .line 593
    :catch_33
    move-exception v0

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

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

    invoke-virtual {p0, v1}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->exit(Lcom/iflytek/cloud/SpeechError;)V

    goto :goto_32
.end method

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

    .prologue
    .line 795
    monitor-enter p0

    :try_start_1
    iget-boolean v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mIsRestarting:Z
    :try_end_3
    .catchall {:try_start_1 .. :try_end_3} :catchall_5e

    if-eqz v0, :cond_7

    .line 829
    :goto_5
    monitor-exit p0

    return-void

    .line 799
    :cond_7
    :try_start_7
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->assertSessionTimes()V

    .line 802
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->updateUploadBytes()V

    .line 803
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->updateSessionID()V

    .line 804
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->updateSyncID()V

    .line 807
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSession:Lcom/iflytek/cloud/msc/ist/IstSession;

    const-string v1, "restart"

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

    .line 810
    iget v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mLastServerOffset:I

    iput v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mLastMscOffset:I

    .line 812
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSession:Lcom/iflytek/cloud/msc/ist/IstSession;

    const/4 v1, 0x0

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

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

    if-eqz v0, :cond_52

    .line 816
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getParam()Lcom/iflytek/thirdparty/ad;

    move-result-object v0

    const-string v1, "sid"

    iget-object v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSessionID:Ljava/lang/String;

    invoke-virtual {v0, v1, v2}, Lcom/iflytek/thirdparty/ad;->a(Ljava/lang/String;Ljava/lang/String;)V

    .line 817
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getParam()Lcom/iflytek/thirdparty/ad;

    move-result-object v0

    const-string v1, "spos"

    iget v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mLastServerOffset:I

    .line 818
    invoke-static {v2}, Ljava/lang/Integer;->toString(I)Ljava/lang/String;

    move-result-object v2

    const/4 v3, 0x1

    .line 817
    invoke-virtual {v0, v1, v2, v3}, Lcom/iflytek/thirdparty/ad;->a(Ljava/lang/String;Ljava/lang/String;Z)V

    .line 820
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getParam()Lcom/iflytek/thirdparty/ad;

    move-result-object v0

    const-string v1, "syncid"

    iget v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSyncID:I

    .line 821
    invoke-static {v2}, Ljava/lang/Integer;->toString(I)Ljava/lang/String;

    move-result-object v2

    const/4 v3, 0x1

    .line 820
    invoke-virtual {v0, v1, v2, v3}, Lcom/iflytek/thirdparty/ad;->a(Ljava/lang/String;Ljava/lang/String;Z)V

    .line 826
    :cond_52
    const/4 v0, 0x1

    sget-object v1, Lcom/iflytek/thirdparty/s$a;->a:Lcom/iflytek/thirdparty/s$a;

    const/4 v2, 0x0

    const/4 v3, 0x0

    invoke-virtual {p0, v0, v1, v2, v3}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->sendMsg(ILcom/iflytek/thirdparty/s$a;ZI)V

    .line 828
    const/4 v0, 0x1

    iput-boolean v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mIsRestarting:Z
    :try_end_5d
    .catchall {:try_start_7 .. :try_end_5d} :catchall_5e

    goto :goto_5

    .line 795
    :catchall_5e
    move-exception v0

    monitor-exit p0

    throw v0
.end method

.method private stopWriteAutio()V
    .registers 3
    .annotation system Ldalvik/annotation/Throws;
        value = {
            Lcom/iflytek/cloud/SpeechError;
        }
    .end annotation

    .prologue
    .line 927
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSession:Lcom/iflytek/cloud/msc/ist/IstSession;

    invoke-virtual {v0}, Lcom/iflytek/cloud/msc/ist/IstSession;->pushEndFlag()V

    .line 928
    const v0, 0x8016

    const/4 v1, 0x0

    invoke-virtual {p0, v0, v1}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->obtainMessage(ILjava/lang/Object;)Landroid/os/Message;

    move-result-object v0

    invoke-virtual {p0, v0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->sendMsg(Landroid/os/Message;)V

    .line 929
    return-void
.end method

.method private updateCatchLeft()V
    .registers 6

    .prologue
    .line 897
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->isRecordMode()Z

    move-result v0

    if-nez v0, :cond_1d

    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    if-eqz v0, :cond_1d

    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAccesser:Lcom/iflytek/cloud/msc/ist/AudioAccessor;

    if-eqz v0, :cond_1d

    .line 898
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    const/16 v1, 0x2717

    iget-object v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAccesser:Lcom/iflytek/cloud/msc/ist/AudioAccessor;

    invoke-virtual {v2}, Lcom/iflytek/cloud/msc/ist/AudioAccessor;->getCacheLeft()I

    move-result v2

    const/4 v3, 0x0

    const/4 v4, 0x0

    invoke-interface {v0, v1, v2, v3, v4}, Lcom/iflytek/cloud/TranscripterListener;->onEvent(IIILandroid/os/Bundle;)V

    .line 900
    :cond_1d
    return-void
.end method

.method private updateSessionID()V
    .registers 5

    .prologue
    const/4 v3, 0x0

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

    if-nez v0, :cond_26

    .line 871
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getSessionID()Ljava/lang/String;

    move-result-object v0

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

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

    if-eqz v0, :cond_26

    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    if-eqz v0, :cond_26

    .line 873
    new-instance v0, Landroid/os/Bundle;

    invoke-direct {v0}, Landroid/os/Bundle;-><init>()V

    .line 874
    const-string v1, "session_id"

    iget-object v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSessionID:Ljava/lang/String;

    invoke-virtual {v0, v1, v2}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V

    .line 875
    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    const/16 v2, 0x4e21

    invoke-interface {v1, v2, v3, v3, v0}, Lcom/iflytek/cloud/TranscripterListener;->onEvent(IIILandroid/os/Bundle;)V

    .line 878
    :cond_26
    return-void
.end method

.method private updateSyncID()V
    .registers 6

    .prologue
    .line 907
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSession:Lcom/iflytek/cloud/msc/ist/IstSession;

    const-string v1, "syncid"

    iget v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSyncID:I

    invoke-virtual {v0, v1, v2}, Lcom/iflytek/cloud/msc/ist/IstSession;->getIntValue(Ljava/lang/String;I)I

    move-result v0

    .line 908
    const-string v1, "updateSyncID"

    new-instance v2, Ljava/lang/StringBuilder;

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

    const-string v3, "syncid="

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

    move-result-object v2

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

    move-result-object v2

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

    move-result-object v2

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

    .line 909
    iget v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSyncID:I

    if-eq v0, v1, :cond_35

    .line 910
    iput v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSyncID:I

    .line 911
    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    if-eqz v1, :cond_35

    .line 912
    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    const/16 v2, 0x2719

    const/4 v3, 0x0

    const/4 v4, 0x0

    invoke-interface {v1, v2, v0, v3, v4}, Lcom/iflytek/cloud/TranscripterListener;->onEvent(IIILandroid/os/Bundle;)V

    .line 915
    :cond_35
    return-void
.end method

.method private updateUploadBytes()V
    .registers 9

    .prologue
    const/4 v0, -0x1

    .line 881
    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSession:Lcom/iflytek/cloud/msc/ist/IstSession;

    const-string v2, "spos"

    iget v3, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mLastServerOffset:I

    invoke-virtual {v1, v2, v3}, Lcom/iflytek/cloud/msc/ist/IstSession;->getIntValue(Ljava/lang/String;I)I

    move-result v2

    .line 882
    const-string v1, "updateUploadBytes"

    new-instance v3, Ljava/lang/StringBuilder;

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

    const-string v4, "uploadLen="

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

    move-result-object v3

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

    move-result-object v3

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

    move-result-object v3

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

    .line 883
    iget v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mLastServerOffset:I

    if-eq v2, v1, :cond_5b

    .line 884
    iput v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mLastServerOffset:I

    .line 885
    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    if-eqz v1, :cond_5b

    .line 886
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getAudioSource()I

    move-result v1

    if-ne v0, v1, :cond_38

    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getDataLength()J

    move-result-wide v0

    long-to-int v0, v0

    .line 887
    :cond_38
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->isRecording()Z

    move-result v1

    if-nez v1, :cond_5c

    .line 888
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getDataLength()J

    move-result-wide v4

    iget v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mLastServerOffset:I

    int-to-long v6, v1

    cmp-long v1, v4, v6

    if-nez v1, :cond_5c

    const/4 v1, 0x1

    .line 889
    :goto_4a
    new-instance v3, Landroid/os/Bundle;

    invoke-direct {v3}, Landroid/os/Bundle;-><init>()V

    .line 890
    const-string v4, "ist_upload_complete"

    invoke-virtual {v3, v4, v1}, Landroid/os/Bundle;->putBoolean(Ljava/lang/String;Z)V

    .line 891
    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    const/16 v4, 0x2716

    invoke-interface {v1, v4, v2, v0, v3}, Lcom/iflytek/cloud/TranscripterListener;->onEvent(IIILandroid/os/Bundle;)V

    .line 894
    :cond_5b
    return-void

    .line 888
    :cond_5c
    const/4 v1, 0x0

    goto :goto_4a
.end method


# virtual methods
.method public callbackVolume([BI)V
    .registers 4

    .prologue
    .line 128
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->isRunning()Z

    move-result v0

    if-eqz v0, :cond_b

    .line 130
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    invoke-interface {v0, p2, p1}, Lcom/iflytek/cloud/TranscripterListener;->onVolumeChanged(I[B)V

    .line 132
    :cond_b
    return-void
.end method

.method public cancel(Z)V
    .registers 5

    .prologue
    .line 390
    if-eqz p1, :cond_18

    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->isRunning()Z

    move-result v0

    if-eqz v0, :cond_18

    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    if-eqz v0, :cond_18

    .line 391
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    new-instance v1, Lcom/iflytek/cloud/SpeechError;

    const/16 v2, 0x4e31

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

    invoke-interface {v0, v1}, Lcom/iflytek/cloud/TranscripterListener;->onError(Lcom/iflytek/cloud/SpeechError;)V

    .line 393
    :cond_18
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->releaseRecord()V

    .line 395
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getStatus()Lcom/iflytek/thirdparty/s$b;

    move-result-object v0

    sget-object v1, Lcom/iflytek/thirdparty/s$b;->c:Lcom/iflytek/thirdparty/s$b;

    if-ne v0, v1, :cond_26

    .line 396
    const/4 v0, 0x1

    iput-boolean v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mUstopRecord:Z

    .line 398
    :cond_26
    invoke-super {p0, p1}, Lcom/iflytek/thirdparty/s;->cancel(Z)V

    .line 399
    return-void
.end method

.method public getAudioPath()Ljava/lang/String;
    .registers 2

    .prologue
    .line 918
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAccesser:Lcom/iflytek/cloud/msc/ist/AudioAccessor;

    if-eqz v0, :cond_b

    .line 919
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAccesser:Lcom/iflytek/cloud/msc/ist/AudioAccessor;

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

    move-result-object v0

    .line 921
    :goto_a
    return-object v0

    :cond_b
    const/4 v0, 0x0

    goto :goto_a
.end method

.method public getAudioSource()I
    .registers 2

    .prologue
    .line 119
    iget v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAudioSource:I

    return v0
.end method

.method public getClientID()Ljava/lang/String;
    .registers 2

    .prologue
    .line 766
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSession:Lcom/iflytek/cloud/msc/ist/IstSession;

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

    move-result-object v0

    return-object v0
.end method

.method public getPerfLog()Lcom/iflytek/thirdparty/u;
    .registers 2

    .prologue
    .line 737
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mPerflog:Lcom/iflytek/thirdparty/u;

    return-object v0
.end method

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

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

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

    move-result v0

    if-eqz v0, :cond_10

    .line 755
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSession:Lcom/iflytek/cloud/msc/ist/IstSession;

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

    move-result-object v0

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

    .line 757
    :cond_10
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSessionID:Ljava/lang/String;

    return-object v0
.end method

.method public getSyncID()I
    .registers 2

    .prologue
    .line 903
    iget v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSyncID:I

    return v0
.end method

.method public getTranscriptResult()Lcom/iflytek/cloud/TranscripterResult;
    .registers 5
    .annotation system Ldalvik/annotation/Throws;
        value = {
            Lcom/iflytek/cloud/SpeechError;
        }
    .end annotation

    .prologue
    .line 545
    const/4 v0, 0x0

    .line 547
    :try_start_1
    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSession:Lcom/iflytek/cloud/msc/ist/IstSession;

    invoke-virtual {v1}, Lcom/iflytek/cloud/msc/ist/IstSession;->getResultData()[B

    move-result-object v1

    if-eqz v1, :cond_1b

    .line 549
    new-instance v0, Lcom/iflytek/cloud/TranscripterResult;

    new-instance v1, Ljava/lang/String;

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

    invoke-virtual {v2}, Lcom/iflytek/cloud/msc/ist/IstSession;->getResultData()[B

    move-result-object v2

    const-string v3, "utf-8"

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

    invoke-direct {v0, v1}, Lcom/iflytek/cloud/TranscripterResult;-><init>(Ljava/lang/String;)V
    :try_end_1b
    .catch Ljava/io/UnsupportedEncodingException; {:try_start_1 .. :try_end_1b} :catch_1c

    .line 555
    :cond_1b
    return-object v0

    .line 551
    :catch_1c
    move-exception v0

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

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

    const/16 v1, 0x4e24

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

    throw v0
.end method

.method public getUploadBytes()I
    .registers 2

    .prologue
    .line 866
    iget v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mLastServerOffset:I

    return v0
.end method

.method protected onEnd(Lcom/iflytek/cloud/SpeechError;)V
    .registers 8

    .prologue
    const/4 v5, 0x0

    const/4 v4, 0x0

    .line 420
    const-string v0, "onSessionEnd"

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

    .line 421
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->releaseRecord()V

    .line 422
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSession:Lcom/iflytek/cloud/msc/ist/IstSession;

    const-string v1, "upflow"

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

    move-result v0

    sput v0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mUpflow:I

    .line 423
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSession:Lcom/iflytek/cloud/msc/ist/IstSession;

    const-string v1, "downflow"

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

    move-result v0

    sput v0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mDownflow:I

    .line 424
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getSessionID()Ljava/lang/String;

    .line 427
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->updateUploadBytes()V

    .line 428
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->updateSessionID()V

    .line 429
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->updateSyncID()V

    .line 432
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    if-eqz v0, :cond_67

    .line 433
    new-instance v0, Landroid/os/Bundle;

    invoke-direct {v0}, Landroid/os/Bundle;-><init>()V

    .line 434
    const-string v1, "sid"

    iget-object v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSessionID:Ljava/lang/String;

    invoke-virtual {v0, v1, v2}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V

    .line 435
    const-string v1, "syncid"

    iget v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSyncID:I

    invoke-virtual {v0, v1, v2}, Landroid/os/Bundle;->putInt(Ljava/lang/String;I)V

    .line 436
    const-string v1, "spos"

    iget v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mLastServerOffset:I

    invoke-virtual {v0, v1, v2}, Landroid/os/Bundle;->putInt(Ljava/lang/String;I)V

    .line 437
    const-string v1, "total"

    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getDataLength()J

    move-result-wide v2

    long-to-int v2, v2

    invoke-virtual {v0, v1, v2}, Landroid/os/Bundle;->putInt(Ljava/lang/String;I)V

    .line 438
    const-string v1, "ist_audio_path"

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

    move-result-object v2

    invoke-virtual {v0, v1, v2}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V

    .line 439
    const-string v1, "error"

    invoke-virtual {v0, v1, p1}, Landroid/os/Bundle;->putSerializable(Ljava/lang/String;Ljava/io/Serializable;)V

    .line 441
    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    const/16 v2, 0x271b

    invoke-interface {v1, v2, v4, v4, v0}, Lcom/iflytek/cloud/TranscripterListener;->onEvent(IIILandroid/os/Bundle;)V

    .line 445
    :cond_67
    :try_start_67
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->closeAudioFile()V
    :try_end_6a
    .catch Ljava/lang/Exception; {:try_start_67 .. :try_end_6a} :catch_d6

    .line 453
    :cond_6a
    :goto_6a
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mResults:Ljava/util/ArrayList;

    invoke-virtual {v0}, Ljava/util/ArrayList;->size()I

    move-result v0

    if-gtz v0, :cond_88

    if-nez p1, :cond_88

    .line 454
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getParam()Lcom/iflytek/thirdparty/ad;

    move-result-object v0

    const-string v1, "asr_nomatch_error"

    const/4 v2, 0x1

    invoke-virtual {v0, v1, v2}, Lcom/iflytek/thirdparty/ad;->a(Ljava/lang/String;Z)Z

    move-result v0

    if-eqz v0, :cond_88

    .line 456
    new-instance p1, Lcom/iflytek/cloud/SpeechError;

    const/16 v0, 0x2786

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

    .line 459
    :cond_88
    if-eqz p1, :cond_df

    .line 460
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mPerflog:Lcom/iflytek/thirdparty/u;

    const-string v1, "app_ret"

    invoke-virtual {p1}, Lcom/iflytek/cloud/SpeechError;->getErrorCode()I

    move-result v2

    int-to-long v2, v2

    invoke-virtual {v0, v1, v2, v3, v4}, Lcom/iflytek/thirdparty/u;->a(Ljava/lang/String;JZ)V

    .line 468
    :goto_96
    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mPerflog:Lcom/iflytek/thirdparty/u;

    const-string v2, "rec_ustop"

    iget-boolean v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mUstopRecord:Z

    if-eqz v0, :cond_e9

    const-string v0, "1"

    :goto_a0
    invoke-virtual {v1, v2, v0, v4}, Lcom/iflytek/thirdparty/u;->a(Ljava/lang/String;Ljava/lang/String;Z)V

    .line 469
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSession:Lcom/iflytek/cloud/msc/ist/IstSession;

    const-string v1, "sessinfo"

    iget-object v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mPerflog:Lcom/iflytek/thirdparty/u;

    invoke-virtual {v2}, Lcom/iflytek/thirdparty/u;->a()Ljava/lang/String;

    move-result-object v2

    invoke-virtual {v0, v1, v2}, Lcom/iflytek/cloud/msc/ist/IstSession;->setParam(Ljava/lang/String;Ljava/lang/String;)Z

    .line 471
    const-string v0, "SessionEndBegin"

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

    .line 472
    iget-boolean v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mUserCancel:Z

    if-eqz v0, :cond_ec

    .line 473
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSession:Lcom/iflytek/cloud/msc/ist/IstSession;

    const-string v1, "user abort"

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

    .line 478
    :goto_c0
    const-string v0, "SessionEndEnd"

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

    .line 480
    invoke-super {p0, p1}, Lcom/iflytek/thirdparty/s;->onEnd(Lcom/iflytek/cloud/SpeechError;)V

    .line 482
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    if-eqz v0, :cond_d5

    .line 484
    iget-boolean v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mUserCancel:Z

    if-eqz v0, :cond_113

    .line 486
    const-string v0, "TranscripterListener#onCancel"

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

    .line 495
    :cond_d5
    :goto_d5
    return-void

    .line 446
    :catch_d6
    move-exception v0

    .line 447
    if-nez p1, :cond_6a

    .line 448
    new-instance p1, Lcom/iflytek/cloud/SpeechError;

    invoke-direct {p1, v0}, Lcom/iflytek/cloud/SpeechError;-><init>(Ljava/lang/Exception;)V

    goto :goto_6a

    .line 462
    :cond_df
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mPerflog:Lcom/iflytek/thirdparty/u;

    const-string v1, "app_ret"

    const-wide/16 v2, 0x0

    invoke-virtual {v0, v1, v2, v3, v4}, Lcom/iflytek/thirdparty/u;->a(Ljava/lang/String;JZ)V

    goto :goto_96

    .line 468
    :cond_e9
    const-string v0, "0"

    goto :goto_a0

    .line 474
    :cond_ec
    if-eqz p1, :cond_10b

    .line 475
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSession:Lcom/iflytek/cloud/msc/ist/IstSession;

    new-instance v1, Ljava/lang/StringBuilder;

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

    const-string v2, "error"

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

    move-result-object v1

    invoke-virtual {p1}, Lcom/iflytek/cloud/SpeechError;->getErrorCode()I

    move-result v2

    invoke-virtual {v1, v2}, 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-virtual {v0, v1}, Lcom/iflytek/cloud/msc/ist/IstSession;->sessionEnd(Ljava/lang/String;)V

    goto :goto_c0

    .line 477
    :cond_10b
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSession:Lcom/iflytek/cloud/msc/ist/IstSession;

    const-string v1, "success"

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

    goto :goto_c0

    .line 490
    :cond_113
    const-string v0, "TranscripterListener#onEnd"

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

    .line 491
    if-eqz p1, :cond_d5

    .line 492
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    invoke-interface {v0, p1}, Lcom/iflytek/cloud/TranscripterListener;->onError(Lcom/iflytek/cloud/SpeechError;)V

    goto :goto_d5
.end method

.method public onError(Lcom/iflytek/cloud/SpeechError;)V
    .registers 2

    .prologue
    .line 719
    invoke-virtual {p0, p1}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->exit(Lcom/iflytek/cloud/SpeechError;)V

    .line 720
    return-void
.end method

.method protected onMsgProcess(Landroid/os/Message;)V
    .registers 3
    .annotation system Ldalvik/annotation/Throws;
        value = {
            Ljava/lang/Throwable;,
            Lcom/iflytek/cloud/SpeechError;
        }
    .end annotation

    .prologue
    .line 155
    invoke-super {p0, p1}, Lcom/iflytek/thirdparty/s;->onMsgProcess(Landroid/os/Message;)V

    .line 157
    iget v0, p1, Landroid/os/Message;->what:I

    if-eqz v0, :cond_e

    .line 158
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->isRunning()Z

    move-result v0

    if-nez v0, :cond_e

    .line 190
    :goto_d
    return-void

    .line 162
    :cond_e
    iget v0, p1, Landroid/os/Message;->what:I

    sparse-switch v0, :sswitch_data_34

    goto :goto_d

    .line 164
    :sswitch_14
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->proc_Msg_Start()V

    goto :goto_d

    .line 167
    :sswitch_18
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->proc_Msg_Session_Begin()V

    goto :goto_d

    .line 170
    :sswitch_1c
    invoke-virtual {p0, p1}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->proc_Msg_Record_Data(Landroid/os/Message;)V

    goto :goto_d

    .line 173
    :sswitch_20
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->proc_Msg_Record_Stoped()V

    goto :goto_d

    .line 176
    :sswitch_24
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->proc_Msg_Wait_Result()V

    goto :goto_d

    .line 179
    :sswitch_28
    invoke-virtual {p0, p1}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->proc_Msg_Result(Landroid/os/Message;)V

    goto :goto_d

    .line 182
    :sswitch_2c
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->proc_Msg_Netperf()V

    goto :goto_d

    .line 185
    :sswitch_30
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->requestResult()Lcom/iflytek/thirdparty/t$a;

    goto :goto_d

    .line 162
    :sswitch_data_34
    .sparse-switch
        0x0 -> :sswitch_14
        0x1 -> :sswitch_18
        0x2 -> :sswitch_1c
        0x3 -> :sswitch_20
        0x4 -> :sswitch_28
        0x7 -> :sswitch_2c
        0x16 -> :sswitch_30
        0x8016 -> :sswitch_24
    .end sparse-switch
.end method

.method protected onParseParam()V
    .registers 6

    .prologue
    const/4 v4, 0x0

    .line 561
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getParam()Lcom/iflytek/thirdparty/ad;

    move-result-object v0

    const-string v1, "audio_source"

    const/4 v2, 0x1

    invoke-virtual {v0, v1, v2}, Lcom/iflytek/thirdparty/ad;->a(Ljava/lang/String;I)I

    move-result v0

    iput v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAudioSource:I

    .line 564
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getParam()Lcom/iflytek/thirdparty/ad;

    move-result-object v0

    const-string v1, "ist_session_try"

    iget v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mMaxSessionTry:I

    invoke-virtual {v0, v1, v2}, Lcom/iflytek/thirdparty/ad;->a(Ljava/lang/String;I)I

    move-result v0

    iput v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mMaxSessionTry:I

    .line 567
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getParam()Lcom/iflytek/thirdparty/ad;

    move-result-object v0

    const-string v1, "spos"

    invoke-virtual {v0, v1, v4}, Lcom/iflytek/thirdparty/ad;->a(Ljava/lang/String;I)I

    move-result v0

    iput v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mLastServerOffset:I

    .line 568
    iget v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mLastServerOffset:I

    iput v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mLastMscOffset:I

    .line 569
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getParam()Lcom/iflytek/thirdparty/ad;

    move-result-object v0

    const-string v1, "sid"

    const/4 v2, 0x0

    invoke-virtual {v0, v1, v2}, Lcom/iflytek/thirdparty/ad;->b(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;

    move-result-object v0

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

    .line 570
    new-instance v0, Ljava/lang/String;

    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getParam()Lcom/iflytek/thirdparty/ad;

    move-result-object v1

    const-string v2, "ist_audio_path"

    sget-object v3, Lcom/iflytek/thirdparty/ae;->b:Ljava/lang/String;

    invoke-virtual {v1, v2, v3}, Lcom/iflytek/thirdparty/ad;->b(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;

    move-result-object v1

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

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

    .line 571
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getParam()Lcom/iflytek/thirdparty/ad;

    move-result-object v0

    const-string v1, "syncid"

    invoke-virtual {v0, v1, v4}, Lcom/iflytek/thirdparty/ad;->a(Ljava/lang/String;I)I

    move-result v0

    iput v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSyncID:I

    .line 573
    invoke-super {p0}, Lcom/iflytek/thirdparty/s;->onParseParam()V

    .line 574
    return-void
.end method

.method public onRecordBuffer([BII)V
    .registers 9

    .prologue
    const/4 v4, 0x1

    .line 676
    if-eqz p1, :cond_8

    if-lez p3, :cond_8

    array-length v0, p1

    if-ge v0, p3, :cond_9

    .line 711
    :cond_8
    :goto_8
    return-void

    .line 678
    :cond_9
    if-lez p3, :cond_8

    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->isRunning()Z

    move-result v0

    if-eqz v0, :cond_8

    .line 680
    iget-boolean v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mFirstRecordAudio:Z

    if-nez v0, :cond_1e

    .line 681
    iput-boolean v4, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mFirstRecordAudio:Z

    .line 682
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mPerflog:Lcom/iflytek/thirdparty/u;

    const-string v1, "rec_start"

    invoke-virtual {v0, v1}, Lcom/iflytek/thirdparty/u;->a(Ljava/lang/String;)V

    .line 686
    :cond_1e
    :try_start_1e
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAccesser:Lcom/iflytek/cloud/msc/ist/AudioAccessor;

    if-nez v0, :cond_2d

    .line 687
    const/4 v0, -0x1

    iget v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAudioSource:I

    if-ne v0, v1, :cond_45

    .line 688
    invoke-static {}, Lcom/iflytek/cloud/msc/ist/AudioAccessor;->createBufferAccessor()Lcom/iflytek/cloud/msc/ist/AudioAccessor;

    move-result-object v0

    iput-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAccesser:Lcom/iflytek/cloud/msc/ist/AudioAccessor;

    .line 697
    :cond_2d
    :goto_2d
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAccesser:Lcom/iflytek/cloud/msc/ist/AudioAccessor;

    invoke-virtual {v0, p1, p3}, Lcom/iflytek/cloud/msc/ist/AudioAccessor;->putAudio([BI)Z
    :try_end_32
    .catch Ljava/lang/Exception; {:try_start_1e .. :try_end_32} :catch_65

    .line 704
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->updateCatchLeft()V

    .line 706
    iget-boolean v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mIsProcRecordDataOn:Z

    if-nez v0, :cond_8

    .line 707
    iput-boolean v4, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mIsProcRecordDataOn:Z

    .line 708
    const/4 v0, 0x2

    const/4 v1, 0x0

    invoke-virtual {p0, v0, v1}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->obtainMessage(ILjava/lang/Object;)Landroid/os/Message;

    move-result-object v0

    invoke-virtual {p0, v0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->sendMsg(Landroid/os/Message;)V

    goto :goto_8

    .line 689
    :cond_45
    const/4 v0, -0x2

    :try_start_46
    iget v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAudioSource:I

    if-ne v0, v1, :cond_2d

    .line 690
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mFilePath:Ljava/lang/String;

    invoke-static {v0}, Lcom/iflytek/cloud/msc/ist/AudioAccessor;->createReadOnlyAccessor(Ljava/lang/String;)Lcom/iflytek/cloud/msc/ist/AudioAccessor;

    move-result-object v0

    iput-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAccesser:Lcom/iflytek/cloud/msc/ist/AudioAccessor;

    .line 692
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getParam()Lcom/iflytek/thirdparty/ad;

    move-result-object v0

    const-string v1, "sample_rate"

    iget-object v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAccesser:Lcom/iflytek/cloud/msc/ist/AudioAccessor;

    sget-object v3, Lcom/iflytek/cloud/msc/ist/AudioAccessor$AudioKeys;->RATE:Lcom/iflytek/cloud/msc/ist/AudioAccessor$AudioKeys;

    .line 693
    invoke-virtual {v2, v3}, Lcom/iflytek/cloud/msc/ist/AudioAccessor;->getAudioInfo(Lcom/iflytek/cloud/msc/ist/AudioAccessor$AudioKeys;)Ljava/lang/String;

    move-result-object v2

    const/4 v3, 0x0

    .line 692
    invoke-virtual {v0, v1, v2, v3}, Lcom/iflytek/thirdparty/ad;->a(Ljava/lang/String;Ljava/lang/String;Z)V
    :try_end_64
    .catch Ljava/lang/Exception; {:try_start_46 .. :try_end_64} :catch_65

    goto :goto_2d

    .line 698
    :catch_65
    move-exception v0

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

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

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

    invoke-virtual {p0, v1}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->exit(Lcom/iflytek/cloud/SpeechError;)V

    goto :goto_8
.end method

.method public onRecordReleased()V
    .registers 1

    .prologue
    .line 746
    return-void
.end method

.method public onRecordStarted(Z)V
    .registers 4

    .prologue
    .line 727
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mPerflog:Lcom/iflytek/thirdparty/u;

    const-string v1, "rec_ready"

    invoke-virtual {v0, v1}, Lcom/iflytek/thirdparty/u;->a(Ljava/lang/String;)V

    .line 728
    iput-boolean p1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mIsRecording:Z

    .line 729
    return-void
.end method

.method public proc_Msg_Netperf()V
    .registers 6

    .prologue
    const/4 v4, 0x0

    .line 408
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->isRunning()Z

    move-result v0

    if-eqz v0, :cond_23

    .line 410
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSession:Lcom/iflytek/cloud/msc/ist/IstSession;

    const-string v1, "netperf"

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

    move-result v0

    .line 411
    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    if-eqz v1, :cond_1b

    .line 412
    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    const/16 v2, 0x2711

    const/4 v3, 0x0

    invoke-interface {v1, v2, v0, v4, v3}, Lcom/iflytek/cloud/TranscripterListener;->onEvent(IIILandroid/os/Bundle;)V

    .line 414
    :cond_1b
    const/4 v0, 0x7

    sget-object v1, Lcom/iflytek/thirdparty/s$a;->b:Lcom/iflytek/thirdparty/s$a;

    const/16 v2, 0x1f4

    invoke-virtual {p0, v0, v1, v4, v2}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->sendMsg(ILcom/iflytek/thirdparty/s$a;ZI)V

    .line 416
    :cond_23
    return-void
.end method

.method protected proc_Msg_Record_Data(Landroid/os/Message;)V
    .registers 8
    .annotation system Ldalvik/annotation/Throws;
        value = {
            Ljava/lang/Exception;
        }
    .end annotation

    .prologue
    const/4 v5, 0x2

    const/4 v4, 0x0

    .line 305
    .line 307
    :try_start_2
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getAudioData()I
    :try_end_5
    .catch Ljava/io/IOException; {:try_start_2 .. :try_end_5} :catch_5e

    move-result v0

    .line 315
    :try_start_6
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->isSessionOn()Z

    move-result v1

    if-eqz v1, :cond_50

    .line 316
    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mBuffer:[B

    if-eqz v1, :cond_35

    if-lez v0, :cond_35

    .line 317
    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mBuffer:[B

    const/4 v2, 0x0

    invoke-virtual {p0, v1, v0, v2}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->uploadData([BIZ)V

    .line 318
    iget v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mLastMscOffset:I

    add-int/2addr v0, v1

    iput v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mLastMscOffset:I

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

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

    const-string v1, "LastMscOffset: "

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

    move-result-object v0

    iget v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mLastMscOffset:I

    invoke-virtual {v0, v1}, 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 324
    :cond_35
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->updateUploadBytes()V

    .line 325
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->updateSessionID()V

    .line 326
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->updateSyncID()V

    .line 327
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->updateCatchLeft()V

    .line 329
    const/16 v0, 0x16

    const/4 v1, 0x0

    invoke-virtual {p0, v0, v1}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->obtainMessage(ILjava/lang/Object;)Landroid/os/Message;

    move-result-object v0

    sget-object v1, Lcom/iflytek/thirdparty/s$a;->b:Lcom/iflytek/thirdparty/s$a;

    const/4 v2, 0x0

    const/16 v3, 0x64

    invoke-virtual {p0, v0, v1, v2, v3}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->sendMsg(Landroid/os/Message;Lcom/iflytek/thirdparty/s$a;ZI)V
    :try_end_50
    .catch Lcom/iflytek/cloud/SpeechError; {:try_start_6 .. :try_end_50} :catch_8b
    .catchall {:try_start_6 .. :try_end_50} :catchall_a8

    .line 341
    :cond_50
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->hasMoreData()Z

    move-result v0

    if-eqz v0, :cond_81

    .line 342
    invoke-virtual {p0, v5, v4}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->obtainMessage(ILjava/lang/Object;)Landroid/os/Message;

    move-result-object v0

    invoke-virtual {p0, v0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->sendMsg(Landroid/os/Message;)V

    .line 348
    :cond_5d
    :goto_5d
    return-void

    .line 309
    :catch_5e
    move-exception v0

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

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

    const/16 v2, 0x2779

    new-instance v3, Ljava/lang/StringBuilder;

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

    const-string v4, "Read file Error"

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

    move-result-object v3

    invoke-virtual {v0}, Ljava/io/IOException;->getLocalizedMessage()Ljava/lang/String;

    move-result-object v0

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

    move-result-object v0

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

    move-result-object v0

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

    throw v1

    .line 343
    :cond_81
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->isSessionOn()Z

    move-result v0

    if-eqz v0, :cond_5d

    .line 344
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->stopWriteAutio()V

    goto :goto_5d

    .line 332
    :catch_8b
    move-exception v0

    .line 333
    :try_start_8c
    iput-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mError:Lcom/iflytek/cloud/SpeechError;

    .line 334
    const/16 v1, 0x2782

    invoke-virtual {v0}, Lcom/iflytek/cloud/SpeechError;->getErrorCode()I

    move-result v2

    if-ne v1, v2, :cond_a7

    .line 335
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->restartSession()V
    :try_end_99
    .catchall {:try_start_8c .. :try_end_99} :catchall_a8

    .line 341
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->hasMoreData()Z

    move-result v0

    if-eqz v0, :cond_b7

    .line 342
    invoke-virtual {p0, v5, v4}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->obtainMessage(ILjava/lang/Object;)Landroid/os/Message;

    move-result-object v0

    invoke-virtual {p0, v0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->sendMsg(Landroid/os/Message;)V

    goto :goto_5d

    .line 337
    :cond_a7
    :try_start_a7
    throw v0
    :try_end_a8
    .catchall {:try_start_a7 .. :try_end_a8} :catchall_a8

    .line 341
    :catchall_a8
    move-exception v0

    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->hasMoreData()Z

    move-result v1

    if-eqz v1, :cond_c1

    .line 342
    invoke-virtual {p0, v5, v4}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->obtainMessage(ILjava/lang/Object;)Landroid/os/Message;

    move-result-object v1

    invoke-virtual {p0, v1}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->sendMsg(Landroid/os/Message;)V

    .line 346
    :cond_b6
    :goto_b6
    throw v0

    .line 343
    :cond_b7
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->isSessionOn()Z

    move-result v0

    if-eqz v0, :cond_5d

    .line 344
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->stopWriteAutio()V

    goto :goto_5d

    .line 343
    :cond_c1
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->isSessionOn()Z

    move-result v1

    if-eqz v1, :cond_b6

    .line 344
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->stopWriteAutio()V

    goto :goto_b6
.end method

.method proc_Msg_Result(Landroid/os/Message;)V
    .registers 6
    .annotation system Ldalvik/annotation/Throws;
        value = {
            Lcom/iflytek/cloud/SpeechError;,
            Ljava/lang/InterruptedException;,
            Ljava/io/UnsupportedEncodingException;
        }
    .end annotation

    .prologue
    const/4 v3, 0x1

    .line 617
    iget v1, p1, Landroid/os/Message;->arg1:I

    .line 618
    iget-object v0, p1, Landroid/os/Message;->obj:Ljava/lang/Object;

    check-cast v0, [B

    check-cast v0, [B

    .line 620
    packed-switch v1, :pswitch_data_38

    .line 642
    :goto_c
    :pswitch_c
    return-void

    .line 624
    :pswitch_d
    iget-boolean v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mFirstDataArrival:Z

    if-nez v1, :cond_1a

    .line 625
    iput-boolean v3, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mFirstDataArrival:Z

    .line 626
    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mPerflog:Lcom/iflytek/thirdparty/u;

    const-string v2, "app_frs"

    invoke-virtual {v1, v2}, Lcom/iflytek/thirdparty/u;->a(Ljava/lang/String;)V

    .line 628
    :cond_1a
    const/4 v1, 0x0

    invoke-direct {p0, v1, v0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->notifyResult(Z[B)V

    goto :goto_c

    .line 631
    :pswitch_1f
    iget-boolean v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mFirstDataArrival:Z

    if-nez v1, :cond_2c

    .line 632
    iput-boolean v3, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mFirstDataArrival:Z

    .line 633
    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mPerflog:Lcom/iflytek/thirdparty/u;

    const-string v2, "app_frs"

    invoke-virtual {v1, v2}, Lcom/iflytek/thirdparty/u;->a(Ljava/lang/String;)V

    .line 635
    :cond_2c
    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mPerflog:Lcom/iflytek/thirdparty/u;

    const-string v2, "app_lrs"

    invoke-virtual {v1, v2}, Lcom/iflytek/thirdparty/u;->a(Ljava/lang/String;)V

    .line 636
    invoke-direct {p0, v3, v0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->notifyResult(Z[B)V

    goto :goto_c

    .line 620
    nop

    :pswitch_data_38
    .packed-switch 0x0
        :pswitch_d
        :pswitch_c
        :pswitch_c
        :pswitch_c
        :pswitch_c
        :pswitch_1f
    .end packed-switch
.end method

.method protected proc_Msg_Session_Begin()V
    .registers 9
    .annotation system Ldalvik/annotation/Throws;
        value = {
            Ljava/lang/Exception;
        }
    .end annotation

    .prologue
    const/16 v7, 0x271a

    const/16 v6, 0x1f4

    const/4 v5, 0x0

    const/4 v4, 0x1

    const/4 v2, 0x0

    .line 255
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->isSessionOn()Z

    move-result v0

    if-eqz v0, :cond_e

    .line 297
    :cond_d
    :goto_d
    return-void

    .line 259
    :cond_e
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->assertSessionTimes()V

    .line 263
    :try_start_11
    const-string v0, "SDKSessionBegin"

    const/4 v1, 0x0

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

    .line 264
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSession:Lcom/iflytek/cloud/msc/ist/IstSession;

    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mContext:Landroid/content/Context;

    const/4 v3, 0x0

    invoke-virtual {v0, v1, v3, p0}, Lcom/iflytek/cloud/msc/ist/IstSession;->sessionBegin(Landroid/content/Context;Ljava/lang/String;Lcom/iflytek/thirdparty/s;)I
    :try_end_1f
    .catch Lcom/iflytek/cloud/SpeechError; {:try_start_11 .. :try_end_1f} :catch_58
    .catchall {:try_start_11 .. :try_end_1f} :catchall_9c

    move-result v0

    .line 270
    iget v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSessionRetryCount:I

    add-int/lit8 v1, v1, 0x1

    iput v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSessionRetryCount:I

    .line 272
    if-nez v0, :cond_40

    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSession:Lcom/iflytek/cloud/msc/ist/IstSession;

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

    if-eqz v0, :cond_40

    .line 273
    iput-boolean v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mIsRestarting:Z

    .line 275
    iget-boolean v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mIsFirstSession:Z

    if-eqz v0, :cond_d

    .line 276
    iput-boolean v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mIsFirstSession:Z

    .line 278
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    if-eqz v0, :cond_d

    .line 279
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    invoke-interface {v0, v7, v2, v2, v5}, Lcom/iflytek/cloud/TranscripterListener;->onEvent(IIILandroid/os/Bundle;)V

    goto :goto_d

    .line 284
    :cond_40
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->isRunning()Z

    move-result v0

    if-eqz v0, :cond_d

    .line 285
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->isRecordMode()Z

    move-result v0

    if-eqz v0, :cond_52

    .line 287
    sget-object v0, Lcom/iflytek/thirdparty/s$a;->b:Lcom/iflytek/thirdparty/s$a;

    invoke-virtual {p0, v4, v0, v2, v6}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->sendMsg(ILcom/iflytek/thirdparty/s$a;ZI)V

    goto :goto_d

    .line 289
    :cond_52
    sget-object v0, Lcom/iflytek/thirdparty/s$a;->a:Lcom/iflytek/thirdparty/s$a;

    invoke-virtual {p0, v4, v0, v2, v2}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->sendMsg(ILcom/iflytek/thirdparty/s$a;ZI)V

    goto :goto_d

    .line 265
    :catch_58
    move-exception v0

    .line 266
    :try_start_59
    invoke-virtual {v0}, Lcom/iflytek/cloud/SpeechError;->printStackTrace()V

    .line 267
    invoke-virtual {v0}, Lcom/iflytek/cloud/SpeechError;->getErrorCode()I
    :try_end_5f
    .catchall {:try_start_59 .. :try_end_5f} :catchall_9c

    move-result v1

    .line 268
    :try_start_60
    iput-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mError:Lcom/iflytek/cloud/SpeechError;
    :try_end_62
    .catchall {:try_start_60 .. :try_end_62} :catchall_d6

    .line 270
    iget v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSessionRetryCount:I

    add-int/lit8 v0, v0, 0x1

    iput v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSessionRetryCount:I

    .line 272
    if-nez v1, :cond_82

    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSession:Lcom/iflytek/cloud/msc/ist/IstSession;

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

    if-eqz v0, :cond_82

    .line 273
    iput-boolean v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mIsRestarting:Z

    .line 275
    iget-boolean v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mIsFirstSession:Z

    if-eqz v0, :cond_d

    .line 276
    iput-boolean v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mIsFirstSession:Z

    .line 278
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    if-eqz v0, :cond_d

    .line 279
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    invoke-interface {v0, v7, v2, v2, v5}, Lcom/iflytek/cloud/TranscripterListener;->onEvent(IIILandroid/os/Bundle;)V

    goto :goto_d

    .line 284
    :cond_82
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->isRunning()Z

    move-result v0

    if-eqz v0, :cond_d

    .line 285
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->isRecordMode()Z

    move-result v0

    if-eqz v0, :cond_95

    .line 287
    sget-object v0, Lcom/iflytek/thirdparty/s$a;->b:Lcom/iflytek/thirdparty/s$a;

    invoke-virtual {p0, v4, v0, v2, v6}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->sendMsg(ILcom/iflytek/thirdparty/s$a;ZI)V

    goto/16 :goto_d

    .line 289
    :cond_95
    sget-object v0, Lcom/iflytek/thirdparty/s$a;->a:Lcom/iflytek/thirdparty/s$a;

    invoke-virtual {p0, v4, v0, v2, v2}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->sendMsg(ILcom/iflytek/thirdparty/s$a;ZI)V

    goto/16 :goto_d

    .line 270
    :catchall_9c
    move-exception v0

    move v1, v2

    :goto_9e
    iget v3, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSessionRetryCount:I

    add-int/lit8 v3, v3, 0x1

    iput v3, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSessionRetryCount:I

    .line 272
    if-nez v1, :cond_be

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

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

    if-eqz v1, :cond_be

    .line 273
    iput-boolean v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mIsRestarting:Z

    .line 275
    iget-boolean v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mIsFirstSession:Z

    if-eqz v1, :cond_bd

    .line 276
    iput-boolean v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mIsFirstSession:Z

    .line 278
    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    if-eqz v1, :cond_bd

    .line 279
    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    invoke-interface {v1, v7, v2, v2, v5}, Lcom/iflytek/cloud/TranscripterListener;->onEvent(IIILandroid/os/Bundle;)V

    .line 294
    :cond_bd
    :goto_bd
    throw v0

    .line 284
    :cond_be
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->isRunning()Z

    move-result v1

    if-eqz v1, :cond_bd

    .line 285
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->isRecordMode()Z

    move-result v1

    if-eqz v1, :cond_d0

    .line 287
    sget-object v1, Lcom/iflytek/thirdparty/s$a;->b:Lcom/iflytek/thirdparty/s$a;

    invoke-virtual {p0, v4, v1, v2, v6}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->sendMsg(ILcom/iflytek/thirdparty/s$a;ZI)V

    goto :goto_bd

    .line 289
    :cond_d0
    sget-object v1, Lcom/iflytek/thirdparty/s$a;->a:Lcom/iflytek/thirdparty/s$a;

    invoke-virtual {p0, v4, v1, v2, v2}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->sendMsg(ILcom/iflytek/thirdparty/s$a;ZI)V

    goto :goto_bd

    .line 270
    :catchall_d6
    move-exception v0

    goto :goto_9e
.end method

.method protected proc_Msg_Start()V
    .registers 8
    .annotation system Ldalvik/annotation/Throws;
        value = {
            Ljava/lang/Exception;
        }
    .end annotation

    .prologue
    const/4 v6, 0x1

    const/4 v4, -0x1

    const/4 v3, -0x2

    const/4 v5, 0x0

    .line 197
    const-string v0, "start connecting"

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

    .line 198
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getParam()Lcom/iflytek/thirdparty/ad;

    move-result-object v0

    const-string v1, "engine_type"

    invoke-virtual {v0, v1}, Lcom/iflytek/thirdparty/ad;->e(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v0

    .line 199
    const-string v1, "cloud"

    invoke-virtual {v1, v0}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z

    move-result v0

    if-eqz v0, :cond_2c

    .line 200
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getAudioSource()I

    move-result v0

    if-eq v4, v0, :cond_27

    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getAudioSource()I

    move-result v0

    if-ne v3, v0, :cond_2c

    .line 201
    :cond_27
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mContext:Landroid/content/Context;

    invoke-static {v0}, Lcom/iflytek/cloud/msc/util/NetworkUtil;->checkNetwork(Landroid/content/Context;)V

    .line 203
    :cond_2c
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getParam()Lcom/iflytek/thirdparty/ad;

    move-result-object v0

    const-string v1, "record_read_rate"

    const/16 v2, 0x28

    invoke-virtual {v0, v1, v2}, Lcom/iflytek/thirdparty/ad;->a(Ljava/lang/String;I)I

    move-result v0

    .line 205
    iget v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAudioSource:I

    if-ne v4, v1, :cond_a1

    .line 206
    invoke-static {}, Lcom/iflytek/cloud/msc/ist/AudioAccessor;->createBufferAccessor()Lcom/iflytek/cloud/msc/ist/AudioAccessor;

    move-result-object v1

    iput-object v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAccesser:Lcom/iflytek/cloud/msc/ist/AudioAccessor;

    .line 222
    :cond_42
    :goto_42
    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAccesser:Lcom/iflytek/cloud/msc/ist/AudioAccessor;

    invoke-virtual {v1}, Lcom/iflytek/cloud/msc/ist/AudioAccessor;->getBufferLength()I

    move-result v1

    new-array v1, v1, [B

    iput-object v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mBuffer:[B

    .line 225
    iget v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAudioSource:I

    if-ltz v1, :cond_92

    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->isRunning()Z

    move-result v1

    if-eqz v1, :cond_92

    .line 226
    const-string v1, "start  record"

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

    .line 227
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getParam()Lcom/iflytek/thirdparty/ad;

    move-result-object v1

    const-string v2, "bluetooth"

    iget-boolean v3, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mUseBluetooth:Z

    invoke-virtual {v1, v2, v3}, Lcom/iflytek/thirdparty/ad;->a(Ljava/lang/String;Z)Z

    move-result v1

    iput-boolean v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mUseBluetooth:Z

    .line 228
    iget-boolean v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mUseBluetooth:Z

    if-eqz v1, :cond_70

    .line 229
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->startBluetooth()V

    .line 232
    :cond_70
    new-instance v1, Lcom/iflytek/cloud/record/PcmRecorder;

    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getSampleRate()I

    move-result v2

    iget v3, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAudioSource:I

    invoke-direct {v1, v2, v0, v3}, Lcom/iflytek/cloud/record/PcmRecorder;-><init>(III)V

    iput-object v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mRecorder:Lcom/iflytek/cloud/record/PcmRecorder;

    .line 233
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mPerflog:Lcom/iflytek/thirdparty/u;

    const-string v1, "rec_open"

    invoke-virtual {v0, v1}, Lcom/iflytek/thirdparty/u;->a(Ljava/lang/String;)V

    .line 234
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mRecorder:Lcom/iflytek/cloud/record/PcmRecorder;

    invoke-virtual {v0, p0}, Lcom/iflytek/cloud/record/PcmRecorder;->startRecording(Lcom/iflytek/cloud/record/PcmRecorder$PcmRecordListener;)V

    .line 236
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    if-eqz v0, :cond_92

    .line 237
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    invoke-interface {v0}, Lcom/iflytek/cloud/TranscripterListener;->onBeginOfSpeech()V

    .line 241
    :cond_92
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mPerflog:Lcom/iflytek/thirdparty/u;

    const-string v1, "app_ssb"

    invoke-virtual {v0, v1}, Lcom/iflytek/thirdparty/u;->a(Ljava/lang/String;)V

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

    invoke-virtual {p0, v6, v0, v5, v5}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->sendMsg(ILcom/iflytek/thirdparty/s$a;ZI)V

    .line 244
    iput-boolean v6, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mIsRecording:Z

    .line 245
    return-void

    .line 207
    :cond_a1
    iget v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAudioSource:I

    if-ne v3, v1, :cond_bf

    .line 208
    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mFilePath:Ljava/lang/String;

    invoke-static {v1}, Lcom/iflytek/cloud/msc/ist/AudioAccessor;->createReadOnlyAccessor(Ljava/lang/String;)Lcom/iflytek/cloud/msc/ist/AudioAccessor;

    move-result-object v1

    iput-object v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAccesser:Lcom/iflytek/cloud/msc/ist/AudioAccessor;

    .line 210
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getParam()Lcom/iflytek/thirdparty/ad;

    move-result-object v1

    const-string v2, "sample_rate"

    iget-object v3, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAccesser:Lcom/iflytek/cloud/msc/ist/AudioAccessor;

    sget-object v4, Lcom/iflytek/cloud/msc/ist/AudioAccessor$AudioKeys;->RATE:Lcom/iflytek/cloud/msc/ist/AudioAccessor$AudioKeys;

    .line 211
    invoke-virtual {v3, v4}, Lcom/iflytek/cloud/msc/ist/AudioAccessor;->getAudioInfo(Lcom/iflytek/cloud/msc/ist/AudioAccessor$AudioKeys;)Ljava/lang/String;

    move-result-object v3

    .line 210
    invoke-virtual {v1, v2, v3, v5}, Lcom/iflytek/thirdparty/ad;->a(Ljava/lang/String;Ljava/lang/String;Z)V

    goto :goto_42

    .line 214
    :cond_bf
    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mFilePath:Ljava/lang/String;

    iget v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSampleRate:I

    invoke-static {v1, v2}, Lcom/iflytek/cloud/msc/ist/AudioAccessor;->createWriteReadAccessor(Ljava/lang/String;I)Lcom/iflytek/cloud/msc/ist/AudioAccessor;

    move-result-object v1

    iput-object v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAccesser:Lcom/iflytek/cloud/msc/ist/AudioAccessor;

    .line 216
    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    if-eqz v1, :cond_42

    .line 217
    new-instance v1, Landroid/os/Bundle;

    invoke-direct {v1}, Landroid/os/Bundle;-><init>()V

    .line 218
    const-string v2, "ist_audio_path"

    iget-object v3, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mAccesser:Lcom/iflytek/cloud/msc/ist/AudioAccessor;

    invoke-virtual {v3}, Lcom/iflytek/cloud/msc/ist/AudioAccessor;->getFilePath()Ljava/lang/String;

    move-result-object v3

    invoke-virtual {v1, v2, v3}, Landroid/os/Bundle;->putString(Ljava/lang/String;Ljava/lang/String;)V

    .line 219
    iget-object v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    const/16 v3, 0x2714

    invoke-interface {v2, v3, v5, v5, v1}, Lcom/iflytek/cloud/TranscripterListener;->onEvent(IIILandroid/os/Bundle;)V

    goto/16 :goto_42
.end method

.method protected proc_Msg_Wait_Result()V
    .registers 6
    .annotation system Ldalvik/annotation/Throws;
        value = {
            Ljava/lang/Exception;
        }
    .end annotation

    .prologue
    const/4 v4, 0x0

    .line 933
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->updateUploadBytes()V

    .line 934
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->updateSessionID()V

    .line 935
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->updateSyncID()V

    .line 937
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSession:Lcom/iflytek/cloud/msc/ist/IstSession;

    sget-object v1, Lcom/iflytek/thirdparty/ae;->a:Ljava/lang/String;

    const/4 v2, -0x1

    invoke-virtual {v0, v1, v2}, Lcom/iflytek/cloud/msc/ist/IstSession;->getIntValue(Ljava/lang/String;I)I

    move-result v0

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

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

    const-string v2, "onWaiting msc waitTime="

    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;->LogD(Ljava/lang/String;)V

    .line 939
    if-ltz v0, :cond_45

    iget v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mResultSecondLeft:I

    if-eq v0, v1, :cond_45

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

    move-result-wide v2

    iput-wide v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mStatusBegin:J

    .line 941
    iput v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mResultSecondLeft:I

    .line 942
    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    if-eqz v1, :cond_45

    .line 943
    iget-object v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    const/16 v2, 0x2718

    div-int/lit16 v0, v0, 0x3e8

    const/4 v3, 0x0

    invoke-interface {v1, v2, v0, v4, v3}, Lcom/iflytek/cloud/TranscripterListener;->onEvent(IIILandroid/os/Bundle;)V

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

    .line 950
    :try_start_47
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->requestResult()Lcom/iflytek/thirdparty/t$a;
    :try_end_4a
    .catch Lcom/iflytek/cloud/SpeechError; {:try_start_47 .. :try_end_4a} :catch_68

    move-result-object v0

    .line 959
    :goto_4b
    iget v1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mResultSecondLeft:I

    if-gez v1, :cond_53

    sget-object v1, Lcom/iflytek/thirdparty/t$a;->c:Lcom/iflytek/thirdparty/t$a;

    if-eq v1, v0, :cond_5d

    .line 961
    :cond_53
    iget-wide v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mStatusBegin:J

    iget v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mResultSecondLeft:I

    iget v3, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mNetTimeOut:I

    add-int/2addr v2, v3

    invoke-static {v0, v1, v2}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->timeOutCheck(JI)V

    .line 964
    :cond_5d
    const v0, 0x8016

    sget-object v1, Lcom/iflytek/thirdparty/s$a;->a:Lcom/iflytek/thirdparty/s$a;

    const/16 v2, 0x1f4

    invoke-virtual {p0, v0, v1, v4, v2}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->sendMsg(ILcom/iflytek/thirdparty/s$a;ZI)V

    .line 966
    return-void

    .line 951
    :catch_68
    move-exception v1

    .line 952
    const/16 v2, 0x2782

    invoke-virtual {v1}, Lcom/iflytek/cloud/SpeechError;->getErrorCode()I

    move-result v3

    if-ne v2, v3, :cond_75

    .line 953
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->restartSession()V

    goto :goto_4b

    .line 955
    :cond_75
    throw v1
.end method

.method protected requestResult()Lcom/iflytek/thirdparty/t$a;
    .registers 7
    .annotation system Ldalvik/annotation/Throws;
        value = {
            Lcom/iflytek/cloud/SpeechError;,
            Ljava/io/UnsupportedEncodingException;
        }
    .end annotation

    .prologue
    const/4 v5, 0x4

    const/4 v4, 0x0

    .line 970
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSession:Lcom/iflytek/cloud/msc/ist/IstSession;

    invoke-virtual {v0}, Lcom/iflytek/cloud/msc/ist/IstSession;->getStatus()Lcom/iflytek/thirdparty/t$a;

    move-result-object v1

    .line 972
    const/4 v0, 0x0

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

    if-eq v2, v1, :cond_31

    .line 974
    iget-object v2, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSession:Lcom/iflytek/cloud/msc/ist/IstSession;

    invoke-virtual {v2}, Lcom/iflytek/cloud/msc/ist/IstSession;->getResultData()[B

    move-result-object v2

    if-eqz v2, :cond_31

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

    invoke-virtual {v2}, Lcom/iflytek/cloud/msc/ist/IstSession;->getResultData()[B

    move-result-object v2

    array-length v2, v2

    if-lez v2, :cond_31

    .line 975
    new-instance v0, Ljava/lang/String;

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

    invoke-virtual {v2}, Lcom/iflytek/cloud/msc/ist/IstSession;->getResultData()[B

    move-result-object v2

    const-string v3, "gb2312"

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

    .line 976
    const-string v2, "utf-8"

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

    move-result-object v0

    .line 979
    :cond_31
    new-instance v2, Ljava/lang/StringBuilder;

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

    const-string v3, "result:"

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

    move-result-object v2

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

    move-result-object v2

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

    move-result-object v2

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

    .line 981
    invoke-virtual {v1}, Lcom/iflytek/thirdparty/t$a;->ordinal()I

    move-result v2

    invoke-virtual {p0, v5, v2, v4, v0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->obtainMessage(IIILjava/lang/Object;)Landroid/os/Message;

    move-result-object v0

    .line 984
    invoke-virtual {p0, v5}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->hasMessages(I)Z

    move-result v2

    if-eqz v2, :cond_5b

    .line 985
    sget-object v2, Lcom/iflytek/thirdparty/s$a;->b:Lcom/iflytek/thirdparty/s$a;

    invoke-virtual {p0, v0, v2, v4, v4}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->sendMsg(Landroid/os/Message;Lcom/iflytek/thirdparty/s$a;ZI)V

    .line 989
    :goto_5a
    return-object v1

    .line 987
    :cond_5b
    sget-object v2, Lcom/iflytek/thirdparty/s$a;->a:Lcom/iflytek/thirdparty/s$a;

    invoke-virtual {p0, v0, v2, v4, v4}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->sendMsg(Landroid/os/Message;Lcom/iflytek/thirdparty/s$a;ZI)V

    goto :goto_5a
.end method

.method protected start()V
    .registers 3

    .prologue
    .line 149
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mPerflog:Lcom/iflytek/thirdparty/u;

    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getParam()Lcom/iflytek/thirdparty/ad;

    move-result-object v1

    invoke-virtual {v0, v1}, Lcom/iflytek/thirdparty/u;->a(Lcom/iflytek/thirdparty/ad;)V

    .line 150
    invoke-super {p0}, Lcom/iflytek/thirdparty/s;->start()V

    .line 151
    return-void
.end method

.method public declared-synchronized startTranscripting(Lcom/iflytek/cloud/TranscripterListener;)V
    .registers 3

    .prologue
    .line 140
    monitor-enter p0

    :try_start_1
    iput-object p1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mListener:Lcom/iflytek/cloud/TranscripterListener;

    .line 142
    const-string v0, "startTranscripting called"

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

    .line 144
    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->start()V
    :try_end_b
    .catchall {:try_start_1 .. :try_end_b} :catchall_d

    .line 145
    monitor-exit p0

    return-void

    .line 140
    :catchall_d
    move-exception v0

    monitor-exit p0

    throw v0
.end method

.method public declared-synchronized stopTranscripting(Z)Z
    .registers 4

    .prologue
    .line 355
    monitor-enter p0

    :try_start_1
    new-instance v0, Ljava/lang/StringBuilder;

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

    const-string v1, "stopTranscript, current status is :"

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

    move-result-object v0

    invoke-virtual {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->getStatus()Lcom/iflytek/thirdparty/s$b;

    move-result-object v1

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

    move-result-object v0

    const-string v1, " usercancel : "

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

    move-result-object v0

    invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Z)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 356
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mPerflog:Lcom/iflytek/thirdparty/u;

    const-string v1, "app_stop"

    invoke-virtual {v0, v1}, Lcom/iflytek/thirdparty/u;->a(Ljava/lang/String;)V

    .line 357
    invoke-direct {p0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->releaseRecord()V

    .line 359
    iput-boolean p1, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mUstopRecord:Z

    .line 360
    const/4 v0, 0x3

    invoke-virtual {p0, v0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->sendMsg(I)V
    :try_end_35
    .catchall {:try_start_1 .. :try_end_35} :catchall_38

    .line 361
    const/4 v0, 0x1

    monitor-exit p0

    return v0

    .line 355
    :catchall_38
    move-exception v0

    monitor-exit p0

    throw v0
.end method

.method protected uploadData([BIZ)V
    .registers 7
    .annotation system Ldalvik/annotation/Throws;
        value = {
            Lcom/iflytek/cloud/SpeechError;
        }
    .end annotation

    .prologue
    .line 654
    iget-boolean v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mFirstDataWrite:Z

    if-nez v0, :cond_e

    .line 655
    const/4 v0, 0x1

    iput-boolean v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mFirstDataWrite:Z

    .line 656
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mPerflog:Lcom/iflytek/thirdparty/u;

    const-string v1, "app_fau"

    invoke-virtual {v0, v1}, Lcom/iflytek/thirdparty/u;->a(Ljava/lang/String;)V

    .line 659
    :cond_e
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSession:Lcom/iflytek/cloud/msc/ist/IstSession;

    invoke-virtual {v0, p1, p2}, Lcom/iflytek/cloud/msc/ist/IstSession;->pushAudioData([BI)V

    .line 661
    if-eqz p3, :cond_34

    .line 662
    iget-object v0, p0, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->mSession:Lcom/iflytek/cloud/msc/ist/IstSession;

    invoke-virtual {v0}, Lcom/iflytek/cloud/msc/ist/IstSession;->getAudioVolume()I

    move-result v0

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

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

    const-string v2, "QISRAudioWrite volume:"

    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;->LogI(Ljava/lang/String;)V

    .line 664
    invoke-virtual {p0, p1, v0}, Lcom/iflytek/cloud/msc/ist/MscTranscripter;->callbackVolume([BI)V

    .line 666
    :cond_34
    return-void
.end method