ExoCacheIO.smali

.class public final Lcom/mmc/player/videocache/exocache/ExoCacheIO;
.super Ljava/lang/Object;
.source "SourceFile"

# interfaces
.implements Ljava/lang/Runnable;
.implements Lcom/google/android/exoplayer2/upstream/r0;


# annotations
.annotation system Ldalvik/annotation/MemberClasses;
    value = {
        Lcom/mmc/player/videocache/exocache/ExoCacheIO$ExoCacheIOHandler;,
        Lcom/mmc/player/videocache/exocache/ExoCacheIO$ExoCacheHandlerThread;,
        Lcom/mmc/player/videocache/exocache/ExoCacheIO$CacheIORet;
    }
.end annotation


# static fields
.field public static final ERR_EXO_IO_EXCEPTION:I = -0x4

.field public static final ERR_EXO_NULL_DATASOURCE:I = -0x3

.field public static final ERR_NETWORK:I = -0x2

.field private static final TAG:Ljava/lang/String; = "MMCExoCacheIO"


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

.field private final MSG_MAIN:I

.field private final MSG_OPEN:I

.field private final MSG_SEEK:I

.field private QUEUE_SIZE:I

.field private final READ_LENGTH:I

.field private READ_TIMEOUT_MS:I

.field private SLEEP_TIME_WHEN_QUEUE_FULL:I

.field private bufferQueue:Ljava/util/concurrent/ArrayBlockingQueue;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/concurrent/ArrayBlockingQueue<",
            "[B>;"
        }
    .end annotation
.end field

.field private bytesRead:J

.field private cacheKey:Ljava/lang/String;

.field private closed:Z

.field private dataSource:Lcom/google/android/exoplayer2/upstream/l;

.field private volatile datasourceEndOfInput:Z

.field private disableEOFFix:Z

.field private disableV2Function:Z

.field private enableHandlerThread:Z

.field private final eofByteArray:[B

.field private errMsg:Ljava/lang/String;

.field private firstByteTime:J

.field private handler:Landroid/os/Handler;

.field private handlerThread:Landroid/os/HandlerThread;

.field private final lock:Ljava/lang/Object;

.field private openRetForHandler:Lcom/mmc/player/videocache/exocache/ExoCacheIO$CacheIORet;

.field private plusInterval:I

.field private readErrorMsg:Ljava/lang/String;

.field public readMMSErrCode:I

.field private recreateDatasourceMax:I

.field private recreateDatasourceTime:I

.field private seekRet:J

.field private seekWaitTimeMs:I

.field private streamSize:J

.field private thread:Ljava/lang/Thread;

.field private url:Ljava/lang/String;


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

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

    const-wide/16 v0, 0x0

    .line 2
    iput-wide v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->streamSize:J

    const/16 v2, 0x1f4

    .line 3
    iput v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->QUEUE_SIZE:I

    const/4 v2, 0x0

    .line 4
    iput-object v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->handlerThread:Landroid/os/HandlerThread;

    const/4 v3, 0x0

    .line 5
    iput-boolean v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->disableV2Function:Z

    const/4 v4, 0x1

    new-array v5, v4, [B

    const/16 v6, 0x30

    aput-byte v6, v5, v3

    .line 6
    iput-object v5, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->eofByteArray:[B

    .line 7
    iput-boolean v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->closed:Z

    const/16 v5, 0x1388

    .line 8
    iput v5, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->READ_TIMEOUT_MS:I

    const-string v6, ""

    .line 9
    iput-object v6, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

    .line 10
    iput-object v6, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->cacheKey:Ljava/lang/String;

    .line 11
    iput-object v6, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->errMsg:Ljava/lang/String;

    const/16 v7, 0x3e8

    .line 12
    iput v7, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->SLEEP_TIME_WHEN_QUEUE_FULL:I

    .line 13
    iput-wide v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bytesRead:J

    const/4 v7, 0x5

    .line 14
    iput v7, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->recreateDatasourceMax:I

    .line 15
    iput v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->recreateDatasourceTime:I

    .line 16
    iput-object v6, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->readErrorMsg:Ljava/lang/String;

    const-wide/16 v6, -0x1

    .line 17
    iput-wide v6, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->firstByteTime:J

    .line 18
    iput v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->MSG_OPEN:I

    .line 19
    iput v4, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->MSG_MAIN:I

    const/4 v4, 0x2

    .line 20
    iput v4, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->MSG_SEEK:I

    const v4, 0x8000

    .line 21
    iput v4, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->READ_LENGTH:I

    .line 22
    iput-boolean v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->enableHandlerThread:Z

    .line 23
    iput-object v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->thread:Ljava/lang/Thread;

    .line 24
    iput-wide v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->seekRet:J

    .line 25
    new-instance v0, Ljava/lang/Object;

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

    iput-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->lock:Ljava/lang/Object;

    .line 26
    iput-boolean v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->datasourceEndOfInput:Z

    .line 27
    new-instance v0, Lcom/mmc/player/videocache/exocache/ExoCacheIO$CacheIORet;

    invoke-direct {v0}, Lcom/mmc/player/videocache/exocache/ExoCacheIO$CacheIORet;-><init>()V

    iput-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->openRetForHandler:Lcom/mmc/player/videocache/exocache/ExoCacheIO$CacheIORet;

    .line 28
    iput v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->readMMSErrCode:I

    const-string v0, "mmc_android_disable_exo_cache_v2functions"

    .line 29
    invoke-static {v0}, Lcom/mmc/player/config/MMCConfigManager;->getBooleanForKey(Ljava/lang/String;)Z

    move-result v0

    iput-boolean v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->disableV2Function:Z

    const-string v0, "android_disable_cache_eof_fix"

    .line 30
    invoke-static {v0}, Lcom/mmc/player/config/MMCConfigManager;->getBooleanForKey(Ljava/lang/String;)Z

    move-result v0

    iput-boolean v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->disableEOFFix:Z

    .line 31
    iget-boolean v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->disableV2Function:Z

    const-string v1, "MMCExoCacheIO"

    if-nez v0, :cond_100

    const-string v0, "mmc_android_exocache_queue_size"

    .line 32
    invoke-static {v0}, Lcom/mmc/player/config/MMCConfigManager;->getIntegerForKey(Ljava/lang/String;)I

    move-result v0

    if-gtz v0, :cond_7d

    .line 33
    iget v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->QUEUE_SIZE:I

    :cond_7d
    iput v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->QUEUE_SIZE:I

    const-string v0, "mmc_android_exocache_read_timeout"

    .line 34
    invoke-static {v0}, Lcom/mmc/player/config/MMCConfigManager;->getIntegerForKey(Ljava/lang/String;)I

    move-result v0

    if-gtz v0, :cond_89

    .line 35
    iget v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->READ_TIMEOUT_MS:I

    :cond_89
    iput v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->READ_TIMEOUT_MS:I

    const-string v0, "mmc_android_exocache_queue_full_sleep_us"

    .line 36
    invoke-static {v0}, Lcom/mmc/player/config/MMCConfigManager;->getIntegerForKey(Ljava/lang/String;)I

    move-result v0

    if-gtz v0, :cond_95

    .line 37
    iget v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->SLEEP_TIME_WHEN_QUEUE_FULL:I

    :cond_95
    iput v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->SLEEP_TIME_WHEN_QUEUE_FULL:I

    .line 38
    new-instance v0, Ljava/util/concurrent/ArrayBlockingQueue;

    iget v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->QUEUE_SIZE:I

    invoke-direct {v0, v2}, Ljava/util/concurrent/ArrayBlockingQueue;-><init>(I)V

    iput-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bufferQueue:Ljava/util/concurrent/ArrayBlockingQueue;

    const-string v0, "android_cache_plus_interval_ms"

    .line 39
    invoke-static {v0}, Lcom/mmc/player/config/MMCConfigManager;->getIntegerForKey(Ljava/lang/String;)I

    move-result v0

    iput v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->plusInterval:I

    const-string v0, "debug.mmcplayer.plusinterval"

    .line 40
    invoke-static {v0}, Lcom/mmc/player/utils/SystemUtils;->readPropInt(Ljava/lang/String;)I

    move-result v0

    if-lez v0, :cond_b2

    .line 41
    iput v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->plusInterval:I

    .line 42
    :cond_b2
    iget-boolean v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->disableV2Function:Z

    if-nez v0, :cond_100

    const-string v0, "android_cache_seek_wait_time_ms"

    .line 43
    invoke-static {v0}, Lcom/mmc/player/config/MMCConfigManager;->getIntegerForKey(Ljava/lang/String;)I

    move-result v0

    if-lez v0, :cond_bf

    move v5, v0

    .line 44
    :cond_bf
    iput v5, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->seekWaitTimeMs:I

    const-string v0, "android_enable_cache_handlerthread"

    .line 45
    invoke-static {v0}, Lcom/mmc/player/config/MMCConfigManager;->getBooleanForKey(Ljava/lang/String;)Z

    move-result v0

    iput-boolean v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->enableHandlerThread:Z

    if-nez v0, :cond_d3

    .line 46
    new-instance v0, Ljava/lang/Thread;

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

    iput-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->thread:Ljava/lang/Thread;

    goto :goto_e4

    .line 47
    :cond_d3
    new-instance v0, Lcom/mmc/player/videocache/exocache/ExoCacheIO$ExoCacheHandlerThread;

    const-string v2, "CacheRead"

    .line 48
    invoke-static {v2}, Landroid/support/v4/media/c;->c(Ljava/lang/String;)Ljava/lang/StringBuilder;

    move-result-object v2

    .line 49
    invoke-static {v2}, Landroidx/biometric/f0;->g(Ljava/lang/StringBuilder;)Ljava/lang/String;

    move-result-object v2

    .line 50
    invoke-direct {v0, p0, v2}, Lcom/mmc/player/videocache/exocache/ExoCacheIO$ExoCacheHandlerThread;-><init>(Lcom/mmc/player/videocache/exocache/ExoCacheIO;Ljava/lang/String;)V

    iput-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->handlerThread:Landroid/os/HandlerThread;

    :goto_e4
    const-string v0, "[config]seekwaittime:"

    .line 51
    invoke-static {v0}, Landroid/support/v4/media/c;->c(Ljava/lang/String;)Ljava/lang/StringBuilder;

    move-result-object v0

    .line 52
    iget v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->seekWaitTimeMs:I

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

    const-string v2, ", enableHandlerThread:"

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

    iget-boolean v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->enableHandlerThread:Z

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

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

    move-result-object v0

    invoke-static {v1, v0}, Lcom/mmc/player/log/MMCLogDelegate;->i(Ljava/lang/String;Ljava/lang/String;)V

    :cond_100
    const-string v0, "android_recreate_datasource_max"

    .line 53
    invoke-static {v0}, Lcom/mmc/player/config/MMCConfigManager;->getIntegerForKey(Ljava/lang/String;)I

    move-result v0

    if-gtz v0, :cond_10a

    .line 54
    iget v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->recreateDatasourceMax:I

    :cond_10a
    iput v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->recreateDatasourceMax:I

    const-string v0, "[config]disableV2Funtion:"

    .line 55
    invoke-static {v0}, Landroid/support/v4/media/c;->c(Ljava/lang/String;)Ljava/lang/StringBuilder;

    move-result-object v0

    .line 56
    iget-boolean v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->disableV2Function:Z

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

    const-string v2, ", queue size:"

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

    iget v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->QUEUE_SIZE:I

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

    const-string v2, ", read_timeout_ms: "

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

    iget v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->READ_TIMEOUT_MS:I

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

    const-string v2, ", recreateDatasourceMax:"

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

    iget v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->recreateDatasourceMax:I

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

    const-string v2, ", plusInterval:"

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

    iget v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->plusInterval:I

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

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

    move-result-object v0

    invoke-static {v1, v0}, Lcom/mmc/player/log/MMCLogDelegate;->i(Ljava/lang/String;Ljava/lang/String;)V

    return-void
.end method

.method public static INVOKEVIRTUAL_com_mmc_player_videocache_exocache_ExoCacheIO_com_shopee_app_asm_fix_androidx_ThreadFixer_start(Landroid/os/HandlerThread;)V
    .registers 3

    .line 1
    :try_start_0
    invoke-static {}, Lcom/shopee/app/asm/fix/androidx/b;->b()Z

    move-result v0

    if-eqz v0, :cond_12

    .line 2
    invoke-static {p0}, Lcom/shopee/app/asm/fix/androidx/b;->a(Ljava/lang/Thread;)V
    :try_end_9
    .catchall {:try_start_0 .. :try_end_9} :catchall_a

    goto :goto_12

    :catchall_a
    move-exception v0

    .line 3
    invoke-static {}, Lcom/shopee/app/apm/c;->d()Lcom/shopee/app/apm/nonfatal/a;

    move-result-object v1

    invoke-virtual {v1, v0}, Lcom/shopee/app/apm/nonfatal/a;->c(Ljava/lang/Throwable;)V

    .line 4
    :cond_12
    :goto_12
    invoke-virtual {p0}, Ljava/lang/Thread;->start()V

    return-void
.end method

.method public static INVOKEVIRTUAL_com_mmc_player_videocache_exocache_ExoCacheIO_com_shopee_app_asm_fix_androidx_ThreadFixer_start(Ljava/lang/Thread;)V
    .registers 3

    .line 5
    :try_start_0
    invoke-static {}, Lcom/shopee/app/asm/fix/androidx/b;->b()Z

    move-result v0

    if-eqz v0, :cond_12

    .line 6
    invoke-static {p0}, Lcom/shopee/app/asm/fix/androidx/b;->a(Ljava/lang/Thread;)V
    :try_end_9
    .catchall {:try_start_0 .. :try_end_9} :catchall_a

    goto :goto_12

    :catchall_a
    move-exception v0

    .line 7
    invoke-static {}, Lcom/shopee/app/apm/c;->d()Lcom/shopee/app/apm/nonfatal/a;

    move-result-object v1

    invoke-virtual {v1, v0}, Lcom/shopee/app/apm/nonfatal/a;->c(Ljava/lang/Throwable;)V

    .line 8
    :cond_12
    :goto_12
    invoke-virtual {p0}, Ljava/lang/Thread;->start()V

    return-void
.end method

.method public static INVOKEVIRTUAL_com_mmc_player_videocache_exocache_ExoCacheIO_com_shopee_app_asm_fix_printstack_PrintStackTraceShieldFix_printStackTrace(Lcom/shopee/sz/loadtask/exception/d;)V
    .registers 1

    return-void
.end method

.method public static INVOKEVIRTUAL_com_mmc_player_videocache_exocache_ExoCacheIO_com_shopee_app_asm_fix_printstack_PrintStackTraceShieldFix_printStackTrace(Ljava/io/IOException;)V
    .registers 1

    return-void
.end method

.method public static INVOKEVIRTUAL_com_mmc_player_videocache_exocache_ExoCacheIO_com_shopee_app_asm_fix_printstack_PrintStackTraceShieldFix_printStackTrace(Ljava/io/InterruptedIOException;)V
    .registers 1

    return-void
.end method

.method public static INVOKEVIRTUAL_com_mmc_player_videocache_exocache_ExoCacheIO_com_shopee_app_asm_fix_printstack_PrintStackTraceShieldFix_printStackTrace(Ljava/lang/IllegalThreadStateException;)V
    .registers 1

    return-void
.end method

.method public static INVOKEVIRTUAL_com_mmc_player_videocache_exocache_ExoCacheIO_com_shopee_app_asm_fix_printstack_PrintStackTraceShieldFix_printStackTrace(Ljava/lang/InterruptedException;)V
    .registers 1

    return-void
.end method

.method public static synthetic a(Lcom/mmc/player/videocache/exocache/ExoCacheIO;)V
    .registers 1

    invoke-direct {p0}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->lambda$closeUsingHandlerThread$0()V

    return-void
.end method

.method public static synthetic access$000(Lcom/mmc/player/videocache/exocache/ExoCacheIO;)Ljava/lang/String;
    .registers 1

    iget-object p0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

    return-object p0
.end method

.method public static synthetic access$100(Lcom/mmc/player/videocache/exocache/ExoCacheIO;)Lcom/mmc/player/videocache/exocache/ExoCacheIO$CacheIORet;
    .registers 1

    iget-object p0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->openRetForHandler:Lcom/mmc/player/videocache/exocache/ExoCacheIO$CacheIORet;

    return-object p0
.end method

.method public static synthetic access$102(Lcom/mmc/player/videocache/exocache/ExoCacheIO;Lcom/mmc/player/videocache/exocache/ExoCacheIO$CacheIORet;)Lcom/mmc/player/videocache/exocache/ExoCacheIO$CacheIORet;
    .registers 2

    iput-object p1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->openRetForHandler:Lcom/mmc/player/videocache/exocache/ExoCacheIO$CacheIORet;

    return-object p1
.end method

.method public static synthetic access$200(Lcom/mmc/player/videocache/exocache/ExoCacheIO;)Lcom/mmc/player/videocache/exocache/ExoCacheIO$CacheIORet;
    .registers 1

    invoke-direct {p0}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->openInternal()Lcom/mmc/player/videocache/exocache/ExoCacheIO$CacheIORet;

    move-result-object p0

    return-object p0
.end method

.method public static synthetic access$300(Lcom/mmc/player/videocache/exocache/ExoCacheIO;)Ljava/lang/Object;
    .registers 1

    iget-object p0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->lock:Ljava/lang/Object;

    return-object p0
.end method

.method public static synthetic access$400(Lcom/mmc/player/videocache/exocache/ExoCacheIO;)Landroid/os/Handler;
    .registers 1

    iget-object p0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->handler:Landroid/os/Handler;

    return-object p0
.end method

.method public static synthetic access$500(Lcom/mmc/player/videocache/exocache/ExoCacheIO;)J
    .registers 3

    invoke-direct {p0}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->main()J

    move-result-wide v0

    return-wide v0
.end method

.method public static synthetic access$600(Lcom/mmc/player/videocache/exocache/ExoCacheIO;)I
    .registers 1

    iget p0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->plusInterval:I

    return p0
.end method

.method public static synthetic access$700(Lcom/mmc/player/videocache/exocache/ExoCacheIO;J)J
    .registers 3

    invoke-direct {p0, p1, p2}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->seekInternal(J)J

    move-result-wide p0

    return-wide p0
.end method

.method public static synthetic access$802(Lcom/mmc/player/videocache/exocache/ExoCacheIO;J)J
    .registers 3

    iput-wide p1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->seekRet:J

    return-wide p1
.end method

.method private closeQuietly()V
    .registers 4

    .line 1
    :try_start_0
    iget-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->dataSource:Lcom/google/android/exoplayer2/upstream/l;

    invoke-interface {v0}, Lcom/google/android/exoplayer2/upstream/l;->close()V
    :try_end_5
    .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_5} :catch_6

    goto :goto_26

    :catch_6
    move-exception v0

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

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

    iget-object v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v2, "close quietly with unexpected error....:"

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

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

    move-result-object v0

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

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

    move-result-object v0

    const-string v1, "MMCExoCacheIO"

    invoke-static {v1, v0}, Lcom/mmc/player/log/MMCLogDelegate;->e(Ljava/lang/String;Ljava/lang/String;)V

    :goto_26
    return-void
.end method

.method private closeUsingHandlerThread()I
    .registers 6

    .line 1
    iget-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->handlerThread:Landroid/os/HandlerThread;

    const/4 v1, 0x0

    if-eqz v0, :cond_49

    iget-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->handler:Landroid/os/Handler;

    if-eqz v0, :cond_49

    const/4 v2, 0x0

    .line 2
    invoke-virtual {v0, v2}, Landroid/os/Handler;->removeCallbacksAndMessages(Ljava/lang/Object;)V

    .line 3
    iget-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->handler:Landroid/os/Handler;

    new-instance v3, Lcom/mmc/player/videocache/exocache/a;

    invoke-direct {v3, p0, v1}, Lcom/mmc/player/videocache/exocache/a;-><init>(Ljava/lang/Object;I)V

    invoke-virtual {v0, v3}, Landroid/os/Handler;->post(Ljava/lang/Runnable;)Z

    :try_start_17
    const-string v0, "MMCExoCacheIO"

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

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

    const-string v4, "closeV2: current thread state:"

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

    iget-object v4, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->handlerThread:Landroid/os/HandlerThread;

    invoke-virtual {v4}, Ljava/lang/Thread;->getState()Ljava/lang/Thread$State;

    move-result-object v4

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

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

    move-result-object v3

    invoke-static {v0, v3}, Lcom/mmc/player/log/MMCLogDelegate;->i(Ljava/lang/String;Ljava/lang/String;)V

    .line 5
    iget-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->handlerThread:Landroid/os/HandlerThread;

    invoke-virtual {v0}, Ljava/lang/Thread;->getState()Ljava/lang/Thread$State;

    move-result-object v0

    sget-object v3, Ljava/lang/Thread$State;->TERMINATED:Ljava/lang/Thread$State;

    if-eq v0, v3, :cond_42

    .line 6
    iget-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->handlerThread:Landroid/os/HandlerThread;

    invoke-virtual {v0}, Ljava/lang/Thread;->join()V

    .line 7
    :cond_42
    iput-object v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->handlerThread:Landroid/os/HandlerThread;
    :try_end_44
    .catch Ljava/lang/InterruptedException; {:try_start_17 .. :try_end_44} :catch_45

    goto :goto_49

    :catch_45
    move-exception v0

    .line 8
    invoke-static {v0}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->INVOKEVIRTUAL_com_mmc_player_videocache_exocache_ExoCacheIO_com_shopee_app_asm_fix_printstack_PrintStackTraceShieldFix_printStackTrace(Ljava/lang/InterruptedException;)V

    :cond_49
    :goto_49
    return v1
.end method

.method private closeV2()I
    .registers 8

    .line 1
    iget-boolean v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->enableHandlerThread:Z

    if-eqz v0, :cond_9

    .line 2
    invoke-direct {p0}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->closeUsingHandlerThread()I

    move-result v0

    return v0

    :cond_9
    const/4 v0, 0x0

    const-wide/16 v1, 0x0

    const/4 v3, 0x0

    .line 3
    :try_start_d
    iget-object v4, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bufferQueue:Ljava/util/concurrent/ArrayBlockingQueue;

    monitor-enter v4
    :try_end_10
    .catch Ljava/lang/InterruptedException; {:try_start_d .. :try_end_10} :catch_4f
    .catchall {:try_start_d .. :try_end_10} :catchall_4d

    .line 4
    :try_start_10
    iput-boolean v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->datasourceEndOfInput:Z

    .line 5
    monitor-exit v4
    :try_end_13
    .catchall {:try_start_10 .. :try_end_13} :catchall_4a

    .line 6
    :try_start_13
    iget-object v4, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->thread:Ljava/lang/Thread;

    if-eqz v4, :cond_27

    invoke-virtual {v4}, Ljava/lang/Thread;->isAlive()Z

    move-result v4

    if-eqz v4, :cond_27

    .line 7
    iget-object v4, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->thread:Ljava/lang/Thread;

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

    .line 8
    iget-object v4, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->thread:Ljava/lang/Thread;

    invoke-virtual {v4}, Ljava/lang/Thread;->join()V

    :cond_27
    const-string v4, "MMCExoCacheIO"

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

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

    iget-object v6, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v6, "thread join complete"

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

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

    move-result-object v5

    invoke-static {v4, v5}, Lcom/mmc/player/log/MMCLogDelegate;->d(Ljava/lang/String;Ljava/lang/String;)V

    .line 10
    iput-object v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->thread:Ljava/lang/Thread;

    .line 11
    iget-object v4, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bufferQueue:Ljava/util/concurrent/ArrayBlockingQueue;

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

    .line 12
    invoke-direct {p0}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->closeQuietly()V
    :try_end_49
    .catch Ljava/lang/InterruptedException; {:try_start_13 .. :try_end_49} :catch_4f
    .catchall {:try_start_13 .. :try_end_49} :catchall_4d

    goto :goto_53

    :catchall_4a
    move-exception v5

    .line 13
    :try_start_4b
    monitor-exit v4
    :try_end_4c
    .catchall {:try_start_4b .. :try_end_4c} :catchall_4a

    :try_start_4c
    throw v5
    :try_end_4d
    .catch Ljava/lang/InterruptedException; {:try_start_4c .. :try_end_4d} :catch_4f
    .catchall {:try_start_4c .. :try_end_4d} :catchall_4d

    :catchall_4d
    move-exception v0

    goto :goto_58

    :catch_4f
    move-exception v4

    .line 14
    :try_start_50
    invoke-static {v4}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->INVOKEVIRTUAL_com_mmc_player_videocache_exocache_ExoCacheIO_com_shopee_app_asm_fix_printstack_PrintStackTraceShieldFix_printStackTrace(Ljava/lang/InterruptedException;)V
    :try_end_53
    .catchall {:try_start_50 .. :try_end_53} :catchall_4d

    .line 15
    :goto_53
    iput-object v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->dataSource:Lcom/google/android/exoplayer2/upstream/l;

    .line 16
    iput-wide v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bytesRead:J

    return v0

    .line 17
    :goto_58
    iput-object v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->dataSource:Lcom/google/android/exoplayer2/upstream/l;

    .line 18
    iput-wide v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bytesRead:J

    .line 19
    throw v0
.end method

.method private extractMMSErrorCode(Ljava/io/IOException;)I
    .registers 3

    .line 1
    instance-of v0, p1, Lcom/google/android/exoplayer2/upstream/m;

    if-eqz v0, :cond_15

    invoke-virtual {p1}, Ljava/lang/Throwable;->getCause()Ljava/lang/Throwable;

    move-result-object v0

    instance-of v0, v0, Lcom/google/android/exoplayer2/upstream/m;

    if-eqz v0, :cond_15

    .line 2
    invoke-virtual {p1}, Ljava/lang/Throwable;->getCause()Ljava/lang/Throwable;

    move-result-object p1

    check-cast p1, Lcom/google/android/exoplayer2/upstream/m;

    iget p1, p1, Lcom/google/android/exoplayer2/upstream/m;->a:I

    return p1

    :cond_15
    const/4 p1, 0x0

    return p1
.end method

.method private extractMMSErrorMsg(Ljava/io/IOException;)Ljava/lang/String;
    .registers 3

    .line 1
    instance-of v0, p1, Lcom/google/android/exoplayer2/upstream/m;

    if-eqz v0, :cond_17

    invoke-virtual {p1}, Ljava/lang/Throwable;->getCause()Ljava/lang/Throwable;

    move-result-object v0

    instance-of v0, v0, Lcom/google/android/exoplayer2/upstream/m;

    if-eqz v0, :cond_17

    .line 2
    invoke-virtual {p1}, Ljava/lang/Throwable;->getCause()Ljava/lang/Throwable;

    move-result-object p1

    check-cast p1, Lcom/google/android/exoplayer2/upstream/m;

    invoke-virtual {p1}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;

    move-result-object p1

    return-object p1

    :cond_17
    if-eqz p1, :cond_1e

    .line 3
    invoke-virtual {p1}, Ljava/lang/Object;->toString()Ljava/lang/String;

    move-result-object p1

    goto :goto_20

    :cond_1e
    const-string p1, ""

    :goto_20
    return-object p1
.end method

.method private synthetic lambda$closeUsingHandlerThread$0()V
    .registers 3

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

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

    iget-object v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v1, "closeV2 on read thread"

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

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

    move-result-object v0

    const-string v1, "MMCExoCacheIO"

    invoke-static {v1, v0}, Lcom/mmc/player/log/MMCLogDelegate;->i(Ljava/lang/String;Ljava/lang/String;)V

    .line 2
    iget-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->handler:Landroid/os/Handler;

    const/4 v1, 0x0

    invoke-virtual {v0, v1}, Landroid/os/Handler;->removeCallbacksAndMessages(Ljava/lang/Object;)V

    .line 3
    iget-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->handlerThread:Landroid/os/HandlerThread;

    invoke-virtual {v0}, Landroid/os/HandlerThread;->quitSafely()Z

    .line 4
    iget-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bufferQueue:Ljava/util/concurrent/ArrayBlockingQueue;

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

    .line 5
    invoke-direct {p0}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->closeQuietly()V

    .line 6
    iput-object v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->dataSource:Lcom/google/android/exoplayer2/upstream/l;

    .line 7
    iput-object v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->handler:Landroid/os/Handler;

    return-void
.end method

.method private main()J
    .registers 13

    const-string v0, "MMCExoCacheIO"

    const/4 v1, 0x0

    const v2, 0x8000

    const-wide/16 v3, -0x1

    :try_start_8
    new-array v5, v2, [B

    .line 1
    iget-object v6, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bufferQueue:Ljava/util/concurrent/ArrayBlockingQueue;

    invoke-virtual {v6}, Ljava/util/concurrent/ArrayBlockingQueue;->size()I

    move-result v6

    iget v7, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->QUEUE_SIZE:I

    if-lt v6, v7, :cond_1a

    .line 2
    iget v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->SLEEP_TIME_WHEN_QUEUE_FULL:I

    div-int/lit16 v2, v2, 0x3e8

    int-to-long v0, v2

    return-wide v0

    .line 3
    :cond_1a
    new-instance v6, Ljava/lang/StringBuilder;

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

    iget-object v7, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v7, "start to read"

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

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

    move-result-object v6

    invoke-static {v0, v6}, Lcom/mmc/player/log/MMCLogDelegate;->v(Ljava/lang/String;Ljava/lang/String;)V

    .line 4
    iget-object v6, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->dataSource:Lcom/google/android/exoplayer2/upstream/l;

    invoke-interface {v6, v5, v1, v2}, Lcom/google/android/exoplayer2/upstream/i;->read([BII)I

    move-result v6

    if-lez v6, :cond_47

    .line 5
    iget-wide v7, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->firstByteTime:J

    cmp-long v9, v7, v3

    if-nez v9, :cond_47

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

    move-result-wide v7

    const-wide/16 v9, 0x3e8

    div-long/2addr v7, v9

    iput-wide v7, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->firstByteTime:J

    .line 7
    :cond_47
    new-instance v7, Ljava/lang/StringBuilder;

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

    iget-object v8, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v8, "read result:"

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

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

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

    move-result-object v7

    invoke-static {v0, v7}, Lcom/mmc/player/log/MMCLogDelegate;->v(Ljava/lang/String;Ljava/lang/String;)V

    if-ltz v6, :cond_75

    if-eq v6, v2, :cond_68

    .line 8
    invoke-static {v5, v6}, Ljava/util/Arrays;->copyOf([BI)[B

    move-result-object v5

    .line 9
    :cond_68
    iget-object v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bufferQueue:Ljava/util/concurrent/ArrayBlockingQueue;

    invoke-virtual {v2, v5}, Ljava/util/concurrent/ArrayBlockingQueue;->put(Ljava/lang/Object;)V

    .line 10
    iget-wide v7, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bytesRead:J

    int-to-long v5, v6

    add-long/2addr v7, v5

    iput-wide v7, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bytesRead:J

    goto/16 :goto_18c

    :cond_75
    const/4 v2, -0x1

    if-ne v6, v2, :cond_18c

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

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

    iget-object v5, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v5, "datasource reach end"

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

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

    move-result-object v2

    invoke-static {v0, v2}, Lcom/mmc/player/log/MMCLogDelegate;->i(Ljava/lang/String;Ljava/lang/String;)V

    .line 12
    iget-object v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bufferQueue:Ljava/util/concurrent/ArrayBlockingQueue;

    iget-object v5, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->eofByteArray:[B

    invoke-virtual {v2, v5}, Ljava/util/concurrent/ArrayBlockingQueue;->put(Ljava/lang/Object;)V

    const-wide/16 v5, 0x0

    .line 13
    iput-wide v5, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bytesRead:J

    .line 14
    iget-object v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->dataSource:Lcom/google/android/exoplayer2/upstream/l;

    invoke-interface {v2}, Lcom/google/android/exoplayer2/upstream/l;->close()V
    :try_end_9e
    .catch Ljava/io/IOException; {:try_start_8 .. :try_end_9e} :catch_be
    .catchall {:try_start_8 .. :try_end_9e} :catchall_9f

    return-wide v3

    :catchall_9f
    move-exception v1

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

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

    iget-object v5, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v5, "unexpected error, "

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

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

    move-result-object v1

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

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

    move-result-object v1

    invoke-static {v0, v1}, Lcom/mmc/player/log/MMCLogDelegate;->e(Ljava/lang/String;Ljava/lang/String;)V

    return-wide v3

    :catch_be
    move-exception v2

    .line 16
    invoke-static {v2}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->INVOKEVIRTUAL_com_mmc_player_videocache_exocache_ExoCacheIO_com_shopee_app_asm_fix_printstack_PrintStackTraceShieldFix_printStackTrace(Ljava/io/IOException;)V

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

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

    iget-object v6, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v6, "datasource has IOException in read thread, "

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

    invoke-direct {p0, v2}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->extractMMSErrorMsg(Ljava/io/IOException;)Ljava/lang/String;

    move-result-object v6

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

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

    move-result-object v5

    invoke-static {v0, v5}, Lcom/mmc/player/log/MMCLogDelegate;->w(Ljava/lang/String;Ljava/lang/String;)V

    .line 18
    iget v5, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->recreateDatasourceTime:I

    iget v6, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->recreateDatasourceMax:I

    if-lt v5, v6, :cond_ee

    .line 19
    invoke-direct {p0, v2}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->extractMMSErrorMsg(Ljava/io/IOException;)Ljava/lang/String;

    move-result-object v0

    iput-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->readErrorMsg:Ljava/lang/String;

    .line 20
    iput v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->recreateDatasourceTime:I

    return-wide v3

    .line 21
    :cond_ee
    invoke-static {}, Lcom/mmc/player/videocache/exocache/ExoCacheConfig;->getInstance()Lcom/mmc/player/videocache/exocache/ExoCacheConfig;

    move-result-object v5

    invoke-virtual {v5}, Lcom/mmc/player/videocache/exocache/ExoCacheConfig;->createCacheDataSource()Lcom/google/android/exoplayer2/upstream/l;

    move-result-object v5

    if-nez v5, :cond_11e

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

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

    iget-object v6, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v6, "create null datasource "

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

    invoke-direct {p0, v2}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->extractMMSErrorMsg(Ljava/io/IOException;)Ljava/lang/String;

    move-result-object v6

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

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

    move-result-object v5

    invoke-static {v0, v5}, Lcom/mmc/player/log/MMCLogDelegate;->w(Ljava/lang/String;Ljava/lang/String;)V

    .line 23
    invoke-direct {p0, v2}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->extractMMSErrorMsg(Ljava/io/IOException;)Ljava/lang/String;

    move-result-object v0

    iput-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->readErrorMsg:Ljava/lang/String;

    .line 24
    iput v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->recreateDatasourceTime:I

    return-wide v3

    .line 25
    :cond_11e
    invoke-direct {p0}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->closeQuietly()V

    .line 26
    iput-object v5, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->dataSource:Lcom/google/android/exoplayer2/upstream/l;

    .line 27
    invoke-interface {v5, p0}, Lcom/google/android/exoplayer2/upstream/l;->b(Lcom/google/android/exoplayer2/upstream/r0;)V

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

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

    iget-object v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v2, "create new datasource to reopen, recreateDatasourceTime:"

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

    iget v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->recreateDatasourceTime:I

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

    const-string v2, " bytesread:"

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

    iget-wide v5, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bytesRead:J

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

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

    move-result-object v1

    invoke-static {v0, v1}, Lcom/mmc/player/log/MMCLogDelegate;->i(Ljava/lang/String;Ljava/lang/String;)V

    .line 29
    :try_start_14b
    iget-object v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->dataSource:Lcom/google/android/exoplayer2/upstream/l;

    new-instance v2, Lcom/google/android/exoplayer2/upstream/o;

    iget-object v5, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->url:Ljava/lang/String;

    invoke-static {v5}, Landroid/net/Uri;->parse(Ljava/lang/String;)Landroid/net/Uri;

    move-result-object v6

    iget-wide v7, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bytesRead:J

    const-wide/16 v9, -0x1

    iget-object v11, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->cacheKey:Ljava/lang/String;

    move-object v5, v2

    invoke-direct/range {v5 .. v11}, Lcom/google/android/exoplayer2/upstream/o;-><init>(Landroid/net/Uri;JJLjava/lang/String;)V

    invoke-interface {v1, v2}, Lcom/google/android/exoplayer2/upstream/l;->c(Lcom/google/android/exoplayer2/upstream/o;)J

    move-result-wide v1

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

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

    iget-object v6, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v6, "new datasource open ret:"

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

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

    const-string v1, " stream size:"

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

    iget-wide v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->streamSize:J

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

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

    move-result-object v1

    invoke-static {v0, v1}, Lcom/mmc/player/log/MMCLogDelegate;->i(Ljava/lang/String;Ljava/lang/String;)V
    :try_end_186
    .catch Ljava/io/IOException; {:try_start_14b .. :try_end_186} :catch_18f

    .line 31
    iget v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->recreateDatasourceTime:I

    add-int/lit8 v0, v0, 0x1

    iput v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->recreateDatasourceTime:I

    :cond_18c
    :goto_18c
    const-wide/16 v0, 0x1

    return-wide v0

    :catch_18f
    move-exception v1

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

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

    iget-object v5, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v5, "retry open new datasource fail again! "

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

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

    move-result-object v5

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

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

    move-result-object v2

    invoke-static {v0, v2}, Lcom/mmc/player/log/MMCLogDelegate;->w(Ljava/lang/String;Ljava/lang/String;)V

    .line 33
    invoke-virtual {v1}, Ljava/lang/Object;->toString()Ljava/lang/String;

    move-result-object v0

    iput-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->readErrorMsg:Ljava/lang/String;

    return-wide v3
.end method

.method private openInternal()Lcom/mmc/player/videocache/exocache/ExoCacheIO$CacheIORet;
    .registers 10

    const-string v0, "MMCExoCacheIO"

    .line 1
    :try_start_2
    new-instance v1, Ljava/lang/StringBuilder;

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

    iget-object v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v2, "open datasource "

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

    iget-object v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->dataSource:Lcom/google/android/exoplayer2/upstream/l;

    invoke-virtual {v2}, Ljava/lang/Object;->hashCode()I

    move-result v2

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

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

    move-result-object v1

    invoke-static {v0, v1}, Lcom/mmc/player/log/MMCLogDelegate;->i(Ljava/lang/String;Ljava/lang/String;)V

    .line 2
    iget-object v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->dataSource:Lcom/google/android/exoplayer2/upstream/l;

    invoke-interface {v1, p0}, Lcom/google/android/exoplayer2/upstream/l;->b(Lcom/google/android/exoplayer2/upstream/r0;)V

    .line 3
    new-instance v1, Lcom/google/android/exoplayer2/upstream/o;

    iget-object v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->url:Ljava/lang/String;

    invoke-static {v2}, Landroid/net/Uri;->parse(Ljava/lang/String;)Landroid/net/Uri;

    move-result-object v3

    const-wide/16 v4, 0x0

    const-wide/16 v6, -0x1

    iget-object v8, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->cacheKey:Ljava/lang/String;

    move-object v2, v1

    invoke-direct/range {v2 .. v8}, Lcom/google/android/exoplayer2/upstream/o;-><init>(Landroid/net/Uri;JJLjava/lang/String;)V

    .line 4
    iget-object v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->dataSource:Lcom/google/android/exoplayer2/upstream/l;

    invoke-interface {v2, v1}, Lcom/google/android/exoplayer2/upstream/l;->c(Lcom/google/android/exoplayer2/upstream/o;)J

    move-result-wide v1

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

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

    iget-object v4, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v4, "open result: "

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

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

    const-string v4, " streamSize: "

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

    iget-wide v4, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->streamSize:J

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

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

    move-result-object v3

    invoke-static {v0, v3}, Lcom/mmc/player/log/MMCLogDelegate;->i(Ljava/lang/String;Ljava/lang/String;)V

    const-wide/16 v3, 0x0

    cmp-long v5, v1, v3

    if-lez v5, :cond_69

    .line 6
    iput-wide v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->streamSize:J

    .line 7
    :cond_69
    new-instance v1, Lcom/mmc/player/videocache/exocache/ExoCacheIO$CacheIORet;

    iget-wide v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->streamSize:J

    long-to-int v3, v2

    invoke-direct {v1, v3}, Lcom/mmc/player/videocache/exocache/ExoCacheIO$CacheIORet;-><init>(I)V
    :try_end_71
    .catch Ljava/io/IOException; {:try_start_2 .. :try_end_71} :catch_b3
    .catch Ljava/lang/IllegalThreadStateException; {:try_start_2 .. :try_end_71} :catch_72

    return-object v1

    :catch_72
    move-exception v1

    .line 8
    invoke-static {v1}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->INVOKEVIRTUAL_com_mmc_player_videocache_exocache_ExoCacheIO_com_shopee_app_asm_fix_printstack_PrintStackTraceShieldFix_printStackTrace(Ljava/lang/IllegalThreadStateException;)V

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

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

    const-string v2, "unexcepted thread state"

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

    iget-object v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->thread:Ljava/lang/Thread;

    invoke-virtual {v2}, Ljava/lang/Thread;->getState()Ljava/lang/Thread$State;

    move-result-object v2

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

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

    move-result-object v1

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

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

    iget-object v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

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

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

    move-result-object v2

    invoke-static {v0, v2}, Lcom/mmc/player/log/MMCLogDelegate;->w(Ljava/lang/String;Ljava/lang/String;)V

    .line 11
    new-instance v0, Lcom/mmc/player/videocache/exocache/ExoCacheIO$CacheIORet;

    const/4 v2, -0x2

    new-instance v3, Ljava/lang/StringBuilder;

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

    iget-object v4, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

    .line 12
    invoke-static {v3, v4, v1}, Landroid/support/v4/media/session/b;->d(Ljava/lang/StringBuilder;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;

    move-result-object v1

    .line 13
    invoke-direct {v0, v2, v1}, Lcom/mmc/player/videocache/exocache/ExoCacheIO$CacheIORet;-><init>(ILjava/lang/String;)V

    return-object v0

    :catch_b3
    move-exception v1

    .line 14
    invoke-static {v1}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->INVOKEVIRTUAL_com_mmc_player_videocache_exocache_ExoCacheIO_com_shopee_app_asm_fix_printstack_PrintStackTraceShieldFix_printStackTrace(Ljava/io/IOException;)V

    .line 15
    instance-of v2, v1, Lcom/google/android/exoplayer2/upstream/d0;

    if-eqz v2, :cond_da

    .line 16
    move-object v2, v1

    check-cast v2, Lcom/google/android/exoplayer2/upstream/d0;

    const-string v3, "response code :"

    .line 17
    invoke-static {v3}, Landroid/support/v4/media/c;->c(Ljava/lang/String;)Ljava/lang/StringBuilder;

    move-result-object v3

    .line 18
    iget v4, v2, Lcom/google/android/exoplayer2/upstream/d0;->d:I

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

    const-string v4, " "

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

    iget-object v2, v2, Lcom/google/android/exoplayer2/upstream/d0;->e:Ljava/lang/String;

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

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

    move-result-object v2

    iput-object v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->errMsg:Ljava/lang/String;

    goto :goto_e0

    .line 19
    :cond_da
    invoke-direct {p0, v1}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->extractMMSErrorMsg(Ljava/io/IOException;)Ljava/lang/String;

    move-result-object v2

    iput-object v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->errMsg:Ljava/lang/String;

    .line 20
    :goto_e0
    invoke-direct {p0, v1}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->extractMMSErrorCode(Ljava/io/IOException;)I

    move-result v1

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

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

    iget-object v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v3, "open error, reason: "

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

    iget-object v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->errMsg:Ljava/lang/String;

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

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

    move-result-object v2

    invoke-static {v0, v2}, Lcom/mmc/player/log/MMCLogDelegate;->e(Ljava/lang/String;Ljava/lang/String;)V

    .line 22
    new-instance v0, Lcom/mmc/player/videocache/exocache/ExoCacheIO$CacheIORet;

    const/4 v2, -0x4

    iget-object v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->errMsg:Ljava/lang/String;

    invoke-direct {v0, v2, v1, v3}, Lcom/mmc/player/videocache/exocache/ExoCacheIO$CacheIORet;-><init>(IILjava/lang/String;)V

    return-object v0
.end method

.method private readV2([BI)I
    .registers 12

    const-string v0, "MMCExoCacheIO"

    const/4 v1, -0x1

    .line 1
    :try_start_3
    iget-object v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->handlerThread:Landroid/os/HandlerThread;

    const/4 v3, 0x0

    if-eqz v2, :cond_e

    invoke-virtual {v2}, Ljava/lang/Thread;->isAlive()Z

    move-result v2

    if-nez v2, :cond_18

    :cond_e
    iget-object v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->thread:Ljava/lang/Thread;

    if-eqz v2, :cond_d9

    .line 2
    invoke-virtual {v2}, Ljava/lang/Thread;->isAlive()Z

    move-result v2

    if-eqz v2, :cond_d9

    .line 3
    :cond_18
    new-instance v2, Ljava/lang/StringBuilder;

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

    const-string v4, "take start, bufferQueue size:"

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

    iget-object v4, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bufferQueue:Ljava/util/concurrent/ArrayBlockingQueue;

    invoke-virtual {v4}, Ljava/util/concurrent/ArrayBlockingQueue;->size()I

    move-result v4

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

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

    move-result-object v2

    invoke-static {v0, v2}, Lcom/mmc/player/log/MMCLogDelegate;->v(Ljava/lang/String;Ljava/lang/String;)V

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

    move-result-wide v4

    .line 5
    iget-object v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bufferQueue:Ljava/util/concurrent/ArrayBlockingQueue;

    iget v6, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->READ_TIMEOUT_MS:I

    int-to-long v6, v6

    sget-object v8, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;

    invoke-virtual {v2, v6, v7, v8}, Ljava/util/concurrent/ArrayBlockingQueue;->poll(JLjava/util/concurrent/TimeUnit;)Ljava/lang/Object;

    move-result-object v2

    check-cast v2, [B

    if-nez v2, :cond_7d

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

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

    iget-object p2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string p2, "read time out"

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

    iget-object p2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->readErrorMsg:Ljava/lang/String;

    invoke-virtual {p2}, Ljava/lang/String;->isEmpty()Z

    move-result p2

    if-eqz p2, :cond_5f

    const-string p2, ""

    goto :goto_72

    :cond_5f
    new-instance p2, Ljava/lang/StringBuilder;

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

    const-string v2, ", see error: "

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

    iget-object v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->readErrorMsg:Ljava/lang/String;

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

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

    move-result-object p2

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

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

    move-result-object p1

    invoke-static {v0, p1}, Lcom/mmc/player/log/MMCLogDelegate;->i(Ljava/lang/String;Ljava/lang/String;)V

    return v3

    .line 7
    :cond_7d
    iget-object v6, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->eofByteArray:[B

    invoke-static {v2, v6}, Ljava/util/Arrays;->equals([B[B)Z

    move-result v6

    if-eqz v6, :cond_a7

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

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

    iget-object p2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string p2, "read end"

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

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

    move-result-object p1

    invoke-static {v0, p1}, Lcom/mmc/player/log/MMCLogDelegate;->i(Ljava/lang/String;Ljava/lang/String;)V

    .line 9
    iget-boolean p1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->disableEOFFix:Z

    if-nez p1, :cond_a6

    .line 10
    iget-object p1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bufferQueue:Ljava/util/concurrent/ArrayBlockingQueue;

    iget-object p2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->eofByteArray:[B

    invoke-virtual {p1, p2}, Ljava/util/concurrent/ArrayBlockingQueue;->put(Ljava/lang/Object;)V

    :cond_a6
    return v1

    .line 11
    :cond_a7
    array-length v6, v2

    invoke-static {v6, p2}, Ljava/lang/Math;->min(II)I

    move-result p2

    .line 12
    invoke-static {v2, v3, p1, v3, p2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V

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

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

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

    const-string v2, "read size: "

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

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

    const-string v2, ", cost:"

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

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

    move-result-wide v2

    sub-long/2addr v2, v4

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

    const-string v2, "ns"

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

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

    move-result-object p1

    invoke-static {v0, p1}, Lcom/mmc/player/log/MMCLogDelegate;->v(Ljava/lang/String;Ljava/lang/String;)V
    :try_end_d8
    .catch Ljava/lang/InterruptedException; {:try_start_3 .. :try_end_d8} :catch_da

    move v3, p2

    :cond_d9
    return v3

    :catch_da
    move-exception p1

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

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

    iget-object v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v2, "readV2 Interrupted"

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

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

    move-result-object p2

    invoke-static {v0, p2}, Lcom/mmc/player/log/MMCLogDelegate;->e(Ljava/lang/String;Ljava/lang/String;)V

    .line 15
    invoke-static {p1}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->INVOKEVIRTUAL_com_mmc_player_videocache_exocache_ExoCacheIO_com_shopee_app_asm_fix_printstack_PrintStackTraceShieldFix_printStackTrace(Ljava/lang/InterruptedException;)V

    return v1
.end method

.method private seekInternal(J)J
    .registers 12

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

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

    iget-object v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

    const-string v2, "seekV2 seekto:"

    .line 2
    invoke-static {v0, v1, v2, p1, p2}, Landroidx/appcompat/p;->b(Ljava/lang/StringBuilder;Ljava/lang/String;Ljava/lang/String;J)Ljava/lang/String;

    move-result-object v0

    const-string v1, "MMCExoCacheIO"

    .line 3
    invoke-static {v1, v0}, Lcom/mmc/player/log/MMCLogDelegate;->i(Ljava/lang/String;Ljava/lang/String;)V

    .line 4
    new-instance v0, Lcom/google/android/exoplayer2/upstream/o;

    iget-object v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->url:Ljava/lang/String;

    invoke-static {v2}, Landroid/net/Uri;->parse(Ljava/lang/String;)Landroid/net/Uri;

    move-result-object v3

    iget-object v8, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->cacheKey:Ljava/lang/String;

    const-wide/16 v6, -0x1

    move-object v2, v0

    move-wide v4, p1

    invoke-direct/range {v2 .. v8}, Lcom/google/android/exoplayer2/upstream/o;-><init>(Landroid/net/Uri;JJLjava/lang/String;)V

    .line 5
    iget-object v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->dataSource:Lcom/google/android/exoplayer2/upstream/l;

    if-eqz v2, :cond_7b

    const-wide/16 p1, -0x1

    .line 6
    :try_start_29
    invoke-direct {p0}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->closeQuietly()V

    .line 7
    iget-object v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->dataSource:Lcom/google/android/exoplayer2/upstream/l;

    invoke-interface {v2, v0}, Lcom/google/android/exoplayer2/upstream/l;->c(Lcom/google/android/exoplayer2/upstream/o;)J

    move-result-wide p1
    :try_end_32
    .catch Ljava/io/IOException; {:try_start_29 .. :try_end_32} :catch_5c
    .catchall {:try_start_29 .. :try_end_32} :catchall_3d

    const-wide/16 v0, 0x0

    cmp-long v2, p1, v0

    if-gez v2, :cond_39

    goto :goto_3a

    :cond_39
    move-wide v0, p1

    .line 8
    :goto_3a
    iput-wide v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bytesRead:J

    goto :goto_7b

    :catchall_3d
    move-exception v0

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

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

    iget-object v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v3, "seekV2 with unexpected error...."

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

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

    move-result-object v0

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

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

    move-result-object v0

    invoke-static {v1, v0}, Lcom/mmc/player/log/MMCLogDelegate;->e(Ljava/lang/String;Ljava/lang/String;)V

    return-wide p1

    :catch_5c
    move-exception v0

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

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

    iget-object v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v3, "seekV2 error, datasource may open fail, "

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

    invoke-direct {p0, v0}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->extractMMSErrorMsg(Ljava/io/IOException;)Ljava/lang/String;

    move-result-object v0

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

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

    move-result-object v0

    invoke-static {v1, v0}, Lcom/mmc/player/log/MMCLogDelegate;->e(Ljava/lang/String;Ljava/lang/String;)V

    return-wide p1

    .line 11
    :cond_7b
    :goto_7b
    iget-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bufferQueue:Ljava/util/concurrent/ArrayBlockingQueue;

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

    return-wide p1
.end method

.method private seekUsingHandlerThread(J)J
    .registers 9

    .line 1
    iget-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->handlerThread:Landroid/os/HandlerThread;

    if-eqz v0, :cond_5c

    iget-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->handler:Landroid/os/Handler;

    if-nez v0, :cond_9

    goto :goto_5c

    :cond_9
    const-wide/16 v0, 0x0

    .line 2
    invoke-static {}, Landroid/os/Message;->obtain()Landroid/os/Message;

    move-result-object v2

    const/4 v3, 0x2

    .line 3
    iput v3, v2, Landroid/os/Message;->what:I

    .line 4
    invoke-static {p1, p2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;

    move-result-object v4

    iput-object v4, v2, Landroid/os/Message;->obj:Ljava/lang/Object;

    .line 5
    iget-object v4, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->handler:Landroid/os/Handler;

    invoke-virtual {v4, v3}, Landroid/os/Handler;->removeMessages(I)V

    .line 6
    iget-object v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->handler:Landroid/os/Handler;

    invoke-virtual {v3, v2}, Landroid/os/Handler;->sendMessage(Landroid/os/Message;)Z

    .line 7
    iget-object v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->lock:Ljava/lang/Object;

    monitor-enter v2

    .line 8
    :try_start_25
    iget-object v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->lock:Ljava/lang/Object;

    iget v4, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->seekWaitTimeMs:I

    int-to-long v4, v4

    invoke-virtual {v3, v4, v5}, Ljava/lang/Object;->wait(J)V

    .line 9
    iget-wide v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->seekRet:J
    :try_end_2f
    .catch Ljava/lang/InterruptedException; {:try_start_25 .. :try_end_2f} :catch_32
    .catchall {:try_start_25 .. :try_end_2f} :catchall_30

    goto :goto_36

    :catchall_30
    move-exception p1

    goto :goto_5a

    :catch_32
    move-exception v3

    .line 10
    :try_start_33
    invoke-static {v3}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->INVOKEVIRTUAL_com_mmc_player_videocache_exocache_ExoCacheIO_com_shopee_app_asm_fix_printstack_PrintStackTraceShieldFix_printStackTrace(Ljava/lang/InterruptedException;)V

    .line 11
    :goto_36
    monitor-exit v2
    :try_end_37
    .catchall {:try_start_33 .. :try_end_37} :catchall_30

    const-string v2, "MMCExoCacheIO"

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

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

    iget-object v4, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

    const-string v5, "seekV2 seekpos:"

    .line 13
    invoke-static {v3, v4, v5, p1, p2}, Landroidx/appcompat/view/g;->h(Ljava/lang/StringBuilder;Ljava/lang/String;Ljava/lang/String;J)V

    const-string v4, ",datasource open ret:"

    const-string v5, ", result:"

    .line 14
    invoke-static {v3, v4, v0, v1, v5}, Landroidx/appcompat/k;->i(Ljava/lang/StringBuilder;Ljava/lang/String;JLjava/lang/String;)V

    .line 15
    iget-wide v4, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->streamSize:J

    sub-long/2addr v4, v0

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

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

    move-result-object v0

    invoke-static {v2, v0}, Lcom/mmc/player/log/MMCLogDelegate;->i(Ljava/lang/String;Ljava/lang/String;)V

    return-wide p1

    .line 16
    :goto_5a
    :try_start_5a
    monitor-exit v2
    :try_end_5b
    .catchall {:try_start_5a .. :try_end_5b} :catchall_30

    throw p1

    :cond_5c
    :goto_5c
    const-wide/16 p1, -0x1

    return-wide p1
.end method

.method private seekV2(J)J
    .registers 16

    .line 1
    iget-boolean v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->enableHandlerThread:Z

    if-eqz v0, :cond_9

    .line 2
    invoke-direct {p0, p1, p2}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->seekUsingHandlerThread(J)J

    move-result-wide p1

    return-wide p1

    :cond_9
    const-wide/16 v0, 0x0

    const-wide/16 v2, -0x1

    .line 3
    :try_start_d
    iget-object v4, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bufferQueue:Ljava/util/concurrent/ArrayBlockingQueue;

    monitor-enter v4
    :try_end_10
    .catch Ljava/io/IOException; {:try_start_d .. :try_end_10} :catch_91
    .catchall {:try_start_d .. :try_end_10} :catchall_70

    .line 4
    :try_start_10
    new-instance v12, Lcom/google/android/exoplayer2/upstream/o;

    iget-object v5, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->url:Ljava/lang/String;

    invoke-static {v5}, Landroid/net/Uri;->parse(Ljava/lang/String;)Landroid/net/Uri;

    move-result-object v6

    const-wide/16 v9, -0x1

    iget-object v11, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->cacheKey:Ljava/lang/String;

    move-object v5, v12

    move-wide v7, p1

    invoke-direct/range {v5 .. v11}, Lcom/google/android/exoplayer2/upstream/o;-><init>(Landroid/net/Uri;JJLjava/lang/String;)V

    .line 5
    iget-object v5, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->dataSource:Lcom/google/android/exoplayer2/upstream/l;

    if-eqz v5, :cond_30

    .line 6
    invoke-interface {v5}, Lcom/google/android/exoplayer2/upstream/l;->close()V

    .line 7
    iget-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->dataSource:Lcom/google/android/exoplayer2/upstream/l;

    invoke-interface {v0, v12}, Lcom/google/android/exoplayer2/upstream/l;->c(Lcom/google/android/exoplayer2/upstream/o;)J

    move-result-wide v0

    .line 8
    iput-wide p1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bytesRead:J

    .line 9
    :cond_30
    iget-object v5, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bufferQueue:Ljava/util/concurrent/ArrayBlockingQueue;

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

    const/4 v5, 0x0

    .line 10
    iput-boolean v5, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->datasourceEndOfInput:Z

    .line 11
    iget-object v5, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bufferQueue:Ljava/util/concurrent/ArrayBlockingQueue;

    invoke-virtual {v5}, Ljava/lang/Object;->notifyAll()V

    .line 12
    monitor-exit v4
    :try_end_3e
    .catchall {:try_start_10 .. :try_end_3e} :catchall_6d

    :try_start_3e
    const-string v4, "MMCExoCacheIO"

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

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

    iget-object v6, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v6, "seekV2 seekpos:"

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

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

    const-string v6, ",datasource open ret:"

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

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

    const-string v6, ", result:"

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

    iget-wide v6, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->streamSize:J

    sub-long/2addr v6, v0

    invoke-virtual {v5, v6, v7}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

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

    move-result-object v0

    invoke-static {v4, v0}, Lcom/mmc/player/log/MMCLogDelegate;->i(Ljava/lang/String;Ljava/lang/String;)V
    :try_end_6c
    .catch Ljava/io/IOException; {:try_start_3e .. :try_end_6c} :catch_91
    .catchall {:try_start_3e .. :try_end_6c} :catchall_70

    return-wide p1

    :catchall_6d
    move-exception p1

    .line 14
    :try_start_6e
    monitor-exit v4
    :try_end_6f
    .catchall {:try_start_6e .. :try_end_6f} :catchall_6d

    :try_start_6f
    throw p1
    :try_end_70
    .catch Ljava/io/IOException; {:try_start_6f .. :try_end_70} :catch_91
    .catchall {:try_start_6f .. :try_end_70} :catchall_70

    :catchall_70
    move-exception p1

    const-string p2, "MMCExoCacheIO"

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

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

    iget-object v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v1, "seekV2 with unexpected error...."

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

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

    move-result-object p1

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

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

    move-result-object p1

    invoke-static {p2, p1}, Lcom/mmc/player/log/MMCLogDelegate;->e(Ljava/lang/String;Ljava/lang/String;)V

    return-wide v2

    :catch_91
    move-exception p1

    const-string p2, "MMCExoCacheIO"

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

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

    iget-object v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v1, "seekV2 error, datasource may open fail, "

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

    invoke-direct {p0, p1}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->extractMMSErrorMsg(Ljava/io/IOException;)Ljava/lang/String;

    move-result-object p1

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

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

    move-result-object p1

    invoke-static {p2, p1}, Lcom/mmc/player/log/MMCLogDelegate;->e(Ljava/lang/String;Ljava/lang/String;)V

    return-wide v2
.end method


# virtual methods
.method public closeIO()I
    .registers 3

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

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

    iget-object v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v1, "closeIO"

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

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

    move-result-object v0

    const-string v1, "MMCExoCacheIO"

    invoke-static {v1, v0}, Lcom/mmc/player/log/MMCLogDelegate;->i(Ljava/lang/String;Ljava/lang/String;)V

    .line 2
    iget-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->dataSource:Lcom/google/android/exoplayer2/upstream/l;

    if-nez v0, :cond_1e

    const/4 v0, -0x1

    return v0

    :cond_1e
    const/4 v0, 0x1

    .line 3
    iput-boolean v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->closed:Z

    .line 4
    iget-boolean v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->disableV2Function:Z

    if-nez v0, :cond_2a

    .line 5
    invoke-direct {p0}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->closeV2()I

    move-result v0

    return v0

    .line 6
    :cond_2a
    invoke-direct {p0}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->closeQuietly()V

    const/4 v0, 0x0

    .line 7
    iput-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->dataSource:Lcom/google/android/exoplayer2/upstream/l;

    const/4 v0, 0x0

    return v0
.end method

.method public getFirstByteTime()J
    .registers 3

    iget-wide v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->firstByteTime:J

    return-wide v0
.end method

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

    iget-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->readErrorMsg:Ljava/lang/String;

    return-object v0
.end method

.method public getReadMMSErrCode()I
    .registers 3

    .line 1
    iget v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->readMMSErrCode:I

    const/4 v1, 0x0

    .line 2
    iput v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->readMMSErrCode:I

    return v0
.end method

.method public onBytesTransferred(Lcom/google/android/exoplayer2/upstream/l;Lcom/google/android/exoplayer2/upstream/o;ZI)V
    .registers 5

    return-void
.end method

.method public onTransferEnd(Lcom/google/android/exoplayer2/upstream/l;Lcom/google/android/exoplayer2/upstream/o;Z)V
    .registers 4

    return-void
.end method

.method public onTransferInitializing(Lcom/google/android/exoplayer2/upstream/l;Lcom/google/android/exoplayer2/upstream/o;Z)V
    .registers 4

    return-void
.end method

.method public onTransferStart(Lcom/google/android/exoplayer2/upstream/l;Lcom/google/android/exoplayer2/upstream/o;Z)V
    .registers 4

    return-void
.end method

.method public openIO(Ljava/lang/String;J)Lcom/mmc/player/videocache/exocache/ExoCacheIO$CacheIORet;
    .registers 13

    const-wide/16 v0, 0x0

    .line 1
    iput-wide v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bytesRead:J

    const-string v2, "[0x"

    .line 2
    invoke-static {v2}, Landroid/support/v4/media/c;->c(Ljava/lang/String;)Ljava/lang/StringBuilder;

    move-result-object v2

    .line 3
    invoke-static {p2, p3}, Ljava/lang/Long;->toHexString(J)Ljava/lang/String;

    move-result-object p2

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

    const-string p2, "]"

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

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

    move-result-object p2

    iput-object p2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

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

    iget-object p3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string p3, "openIO, url:"

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

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

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

    move-result-object p2

    const-string p3, "MMCExoCacheIO"

    invoke-static {p3, p2}, Lcom/mmc/player/log/MMCLogDelegate;->i(Ljava/lang/String;Ljava/lang/String;)V

    .line 5
    iput-object p1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->url:Ljava/lang/String;

    .line 6
    iget-object p2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->dataSource:Lcom/google/android/exoplayer2/upstream/l;

    if-nez p2, :cond_81

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

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

    iget-object v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v2, "datasource is null, try to create one"

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

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

    move-result-object p2

    invoke-static {p3, p2}, Lcom/mmc/player/log/MMCLogDelegate;->w(Ljava/lang/String;Ljava/lang/String;)V

    .line 8
    invoke-static {}, Lcom/mmc/player/videocache/exocache/ExoCacheConfig;->getInstance()Lcom/mmc/player/videocache/exocache/ExoCacheConfig;

    move-result-object p2

    invoke-virtual {p2}, Lcom/mmc/player/videocache/exocache/ExoCacheConfig;->createCacheDataSource()Lcom/google/android/exoplayer2/upstream/l;

    move-result-object p2

    iput-object p2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->dataSource:Lcom/google/android/exoplayer2/upstream/l;

    if-nez p2, :cond_7e

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

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

    iget-object p2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string p2, "create null new datasource "

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

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

    move-result-object p1

    invoke-static {p3, p1}, Lcom/mmc/player/log/MMCLogDelegate;->w(Ljava/lang/String;Ljava/lang/String;)V

    .line 10
    new-instance p1, Lcom/mmc/player/videocache/exocache/ExoCacheIO$CacheIORet;

    const/4 p2, -0x3

    const-string p3, "create new datasource fail"

    invoke-direct {p1, p2, p3}, Lcom/mmc/player/videocache/exocache/ExoCacheIO$CacheIORet;-><init>(ILjava/lang/String;)V

    return-object p1

    .line 11
    :cond_7e
    invoke-interface {p2, p0}, Lcom/google/android/exoplayer2/upstream/l;->b(Lcom/google/android/exoplayer2/upstream/r0;)V

    .line 12
    :cond_81
    iget-boolean p2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->disableV2Function:Z

    if-nez p2, :cond_8e

    iget-boolean p2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->enableHandlerThread:Z

    if-eqz p2, :cond_8e

    .line 13
    invoke-virtual {p0}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->openIOUsingHandlerThread()Lcom/mmc/player/videocache/exocache/ExoCacheIO$CacheIORet;

    move-result-object p1

    return-object p1

    :cond_8e
    const/4 p2, 0x0

    .line 14
    iput-boolean p2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->closed:Z

    .line 15
    :try_start_91
    new-instance p2, Ljava/lang/StringBuilder;

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

    iget-object v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v2, "open datasource "

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

    iget-object v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->dataSource:Lcom/google/android/exoplayer2/upstream/l;

    invoke-virtual {v2}, Ljava/lang/Object;->hashCode()I

    move-result v2

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

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

    move-result-object p2

    invoke-static {p3, p2}, Lcom/mmc/player/log/MMCLogDelegate;->i(Ljava/lang/String;Ljava/lang/String;)V

    .line 16
    iget-object p2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->dataSource:Lcom/google/android/exoplayer2/upstream/l;

    invoke-interface {p2, p0}, Lcom/google/android/exoplayer2/upstream/l;->b(Lcom/google/android/exoplayer2/upstream/r0;)V

    .line 17
    new-instance p2, Lcom/google/android/exoplayer2/upstream/o;

    invoke-static {p1}, Landroid/net/Uri;->parse(Ljava/lang/String;)Landroid/net/Uri;

    move-result-object v3

    const-wide/16 v4, 0x0

    const-wide/16 v6, -0x1

    iget-object v8, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->cacheKey:Ljava/lang/String;

    move-object v2, p2

    invoke-direct/range {v2 .. v8}, Lcom/google/android/exoplayer2/upstream/o;-><init>(Landroid/net/Uri;JJLjava/lang/String;)V

    .line 18
    iget-object p1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->dataSource:Lcom/google/android/exoplayer2/upstream/l;

    invoke-interface {p1, p2}, Lcom/google/android/exoplayer2/upstream/l;->c(Lcom/google/android/exoplayer2/upstream/o;)J

    move-result-wide p1

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

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

    iget-object v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v3, "open result: "

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

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

    const-string v3, " streamSize: "

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

    iget-wide v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->streamSize:J

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

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

    move-result-object v2

    invoke-static {p3, v2}, Lcom/mmc/player/log/MMCLogDelegate;->i(Ljava/lang/String;Ljava/lang/String;)V

    cmp-long v2, p1, v0

    if-lez v2, :cond_f4

    .line 20
    iput-wide p1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->streamSize:J

    .line 21
    :cond_f4
    iget-boolean p1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->disableV2Function:Z

    if-nez p1, :cond_108

    .line 22
    iget-object p1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->thread:Ljava/lang/Thread;

    if-nez p1, :cond_103

    .line 23
    new-instance p1, Ljava/lang/Thread;

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

    iput-object p1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->thread:Ljava/lang/Thread;

    .line 24
    :cond_103
    iget-object p1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->thread:Ljava/lang/Thread;

    invoke-static {p1}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->INVOKEVIRTUAL_com_mmc_player_videocache_exocache_ExoCacheIO_com_shopee_app_asm_fix_androidx_ThreadFixer_start(Ljava/lang/Thread;)V

    .line 25
    :cond_108
    new-instance p1, Lcom/mmc/player/videocache/exocache/ExoCacheIO$CacheIORet;

    iget-wide v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->streamSize:J

    long-to-int p2, v0

    invoke-direct {p1, p2}, Lcom/mmc/player/videocache/exocache/ExoCacheIO$CacheIORet;-><init>(I)V
    :try_end_110
    .catch Ljava/io/IOException; {:try_start_91 .. :try_end_110} :catch_152
    .catch Ljava/lang/IllegalThreadStateException; {:try_start_91 .. :try_end_110} :catch_111

    return-object p1

    :catch_111
    move-exception p1

    .line 26
    invoke-static {p1}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->INVOKEVIRTUAL_com_mmc_player_videocache_exocache_ExoCacheIO_com_shopee_app_asm_fix_printstack_PrintStackTraceShieldFix_printStackTrace(Ljava/lang/IllegalThreadStateException;)V

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

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

    const-string p2, "unexcepted thread state"

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

    iget-object p2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->thread:Ljava/lang/Thread;

    invoke-virtual {p2}, Ljava/lang/Thread;->getState()Ljava/lang/Thread$State;

    move-result-object p2

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

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

    move-result-object p1

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

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

    iget-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

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

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

    move-result-object p2

    invoke-static {p3, p2}, Lcom/mmc/player/log/MMCLogDelegate;->w(Ljava/lang/String;Ljava/lang/String;)V

    .line 29
    new-instance p2, Lcom/mmc/player/videocache/exocache/ExoCacheIO$CacheIORet;

    const/4 p3, -0x2

    new-instance v0, Ljava/lang/StringBuilder;

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

    iget-object v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

    .line 30
    invoke-static {v0, v1, p1}, Landroid/support/v4/media/session/b;->d(Ljava/lang/StringBuilder;Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;

    move-result-object p1

    .line 31
    invoke-direct {p2, p3, p1}, Lcom/mmc/player/videocache/exocache/ExoCacheIO$CacheIORet;-><init>(ILjava/lang/String;)V

    return-object p2

    :catch_152
    move-exception p1

    .line 32
    invoke-static {p1}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->INVOKEVIRTUAL_com_mmc_player_videocache_exocache_ExoCacheIO_com_shopee_app_asm_fix_printstack_PrintStackTraceShieldFix_printStackTrace(Ljava/io/IOException;)V

    .line 33
    instance-of p2, p1, Lcom/google/android/exoplayer2/upstream/d0;

    if-eqz p2, :cond_179

    .line 34
    move-object p2, p1

    check-cast p2, Lcom/google/android/exoplayer2/upstream/d0;

    const-string v0, "response code :"

    .line 35
    invoke-static {v0}, Landroid/support/v4/media/c;->c(Ljava/lang/String;)Ljava/lang/StringBuilder;

    move-result-object v0

    .line 36
    iget v1, p2, Lcom/google/android/exoplayer2/upstream/d0;->d:I

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

    const-string v1, " "

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

    iget-object p2, p2, Lcom/google/android/exoplayer2/upstream/d0;->e:Ljava/lang/String;

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

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

    move-result-object p2

    iput-object p2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->errMsg:Ljava/lang/String;

    goto :goto_17f

    .line 37
    :cond_179
    invoke-direct {p0, p1}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->extractMMSErrorMsg(Ljava/io/IOException;)Ljava/lang/String;

    move-result-object p2

    iput-object p2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->errMsg:Ljava/lang/String;

    .line 38
    :goto_17f
    invoke-direct {p0, p1}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->extractMMSErrorCode(Ljava/io/IOException;)I

    move-result p1

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

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

    iget-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v0, "open error, reason: "

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

    iget-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->errMsg:Ljava/lang/String;

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

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

    move-result-object p2

    invoke-static {p3, p2}, Lcom/mmc/player/log/MMCLogDelegate;->e(Ljava/lang/String;Ljava/lang/String;)V

    .line 40
    new-instance p2, Lcom/mmc/player/videocache/exocache/ExoCacheIO$CacheIORet;

    const/4 p3, -0x4

    iget-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->errMsg:Ljava/lang/String;

    invoke-direct {p2, p3, p1, v0}, Lcom/mmc/player/videocache/exocache/ExoCacheIO$CacheIORet;-><init>(IILjava/lang/String;)V

    return-object p2
.end method

.method public openIOUsingHandlerThread()Lcom/mmc/player/videocache/exocache/ExoCacheIO$CacheIORet;
    .registers 5

    .line 1
    iget-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->handlerThread:Landroid/os/HandlerThread;

    if-nez v0, :cond_d

    .line 2
    new-instance v0, Landroid/os/HandlerThread;

    const-string v1, "CacheRead"

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

    iput-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->handlerThread:Landroid/os/HandlerThread;

    .line 3
    :cond_d
    iget-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->handlerThread:Landroid/os/HandlerThread;

    invoke-static {v0}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->INVOKEVIRTUAL_com_mmc_player_videocache_exocache_ExoCacheIO_com_shopee_app_asm_fix_androidx_ThreadFixer_start(Landroid/os/HandlerThread;)V

    .line 4
    new-instance v0, Lcom/mmc/player/videocache/exocache/ExoCacheIO$ExoCacheIOHandler;

    iget-object v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->handlerThread:Landroid/os/HandlerThread;

    invoke-virtual {v1}, Landroid/os/HandlerThread;->getLooper()Landroid/os/Looper;

    move-result-object v1

    invoke-direct {v0, p0, v1}, Lcom/mmc/player/videocache/exocache/ExoCacheIO$ExoCacheIOHandler;-><init>(Lcom/mmc/player/videocache/exocache/ExoCacheIO;Landroid/os/Looper;)V

    iput-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->handler:Landroid/os/Handler;

    const/4 v1, 0x0

    .line 5
    invoke-virtual {v0, v1}, Landroid/os/Handler;->sendEmptyMessage(I)Z

    .line 6
    iget-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->lock:Ljava/lang/Object;

    monitor-enter v0

    .line 7
    :try_start_26
    iget-object v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->lock:Ljava/lang/Object;

    invoke-virtual {v2}, Ljava/lang/Object;->wait()V
    :try_end_2b
    .catch Ljava/lang/InterruptedException; {:try_start_26 .. :try_end_2b} :catch_33
    .catchall {:try_start_26 .. :try_end_2b} :catchall_31

    .line 8
    :try_start_2b
    monitor-exit v0
    :try_end_2c
    .catchall {:try_start_2b .. :try_end_2c} :catchall_31

    .line 9
    iput-boolean v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->closed:Z

    .line 10
    iget-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->openRetForHandler:Lcom/mmc/player/videocache/exocache/ExoCacheIO$CacheIORet;

    return-object v0

    :catchall_31
    move-exception v1

    goto :goto_53

    :catch_33
    :try_start_33
    const-string v1, "MMCExoCacheIO"

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

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

    iget-object v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v3, "open is interrupted"

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

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

    move-result-object v2

    invoke-static {v1, v2}, Lcom/mmc/player/log/MMCLogDelegate;->w(Ljava/lang/String;Ljava/lang/String;)V

    .line 12
    new-instance v1, Lcom/mmc/player/videocache/exocache/ExoCacheIO$CacheIORet;

    const/4 v2, -0x1

    invoke-direct {v1, v2}, Lcom/mmc/player/videocache/exocache/ExoCacheIO$CacheIORet;-><init>(I)V

    monitor-exit v0

    return-object v1

    .line 13
    :goto_53
    monitor-exit v0
    :try_end_54
    .catchall {:try_start_33 .. :try_end_54} :catchall_31

    throw v1
.end method

.method public readIO([BI)I
    .registers 10

    const-string v0, "MMCExoCacheIO"

    .line 1
    iget-object v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->dataSource:Lcom/google/android/exoplayer2/upstream/l;

    const/4 v2, -0x1

    if-nez v1, :cond_8

    return v2

    .line 2
    :cond_8
    iget-boolean v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->disableV2Function:Z

    if-nez v3, :cond_11

    .line 3
    invoke-direct {p0, p1, p2}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->readV2([BI)I

    move-result p1

    return p1

    :cond_11
    const/4 v3, 0x0

    .line 4
    :try_start_12
    invoke-interface {v1, p1, v3, p2}, Lcom/google/android/exoplayer2/upstream/i;->read([BII)I

    move-result p1

    if-lez p1, :cond_29

    .line 5
    iget-wide v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->firstByteTime:J

    const-wide/16 v5, -0x1

    cmp-long p2, v3, v5

    if-nez p2, :cond_29

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

    move-result-wide v3

    const-wide/16 v5, 0x3e8

    div-long/2addr v3, v5

    iput-wide v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->firstByteTime:J
    :try_end_29
    .catch Ljava/io/IOException; {:try_start_12 .. :try_end_29} :catch_49
    .catchall {:try_start_12 .. :try_end_29} :catchall_2a

    :cond_29
    return p1

    :catchall_2a
    move-exception p1

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

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

    iget-object v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v1, "unexpected error, "

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

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

    move-result-object p1

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

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

    move-result-object p1

    invoke-static {v0, p1}, Lcom/mmc/player/log/MMCLogDelegate;->e(Ljava/lang/String;Ljava/lang/String;)V

    return v2

    :catch_49
    move-exception p1

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

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

    iget-object v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v1, "readIO exception, "

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

    invoke-direct {p0, p1}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->extractMMSErrorMsg(Ljava/io/IOException;)Ljava/lang/String;

    move-result-object v1

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

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

    move-result-object p2

    invoke-static {v0, p2}, Lcom/mmc/player/log/MMCLogDelegate;->e(Ljava/lang/String;Ljava/lang/String;)V

    .line 9
    invoke-direct {p0, p1}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->extractMMSErrorMsg(Ljava/io/IOException;)Ljava/lang/String;

    move-result-object p1

    iput-object p1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->readErrorMsg:Ljava/lang/String;

    return v2
.end method

.method public release()V
    .registers 3

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

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

    iget-object v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v1, "release"

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

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

    move-result-object v0

    const-string v1, "MMCExoCacheIO"

    invoke-static {v1, v0}, Lcom/mmc/player/log/MMCLogDelegate;->i(Ljava/lang/String;Ljava/lang/String;)V

    .line 2
    iget-boolean v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->closed:Z

    if-nez v0, :cond_22

    const/4 v0, 0x1

    .line 3
    iput-boolean v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->closed:Z

    .line 4
    invoke-virtual {p0}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->closeIO()I

    :cond_22
    return-void
.end method

.method public run()V
    .registers 15

    invoke-static {}, Landroid/os/Looper;->getMainLooper()Landroid/os/Looper;

    move-result-object v0

    invoke-static {}, Landroid/os/Looper;->myLooper()Landroid/os/Looper;

    move-result-object v1

    const/4 v2, 0x1

    const/4 v3, 0x0

    if-ne v0, v1, :cond_e

    const/4 v0, 0x1

    goto :goto_f

    :cond_e
    const/4 v0, 0x0

    :goto_f
    if-eqz v0, :cond_1a

    const-string v1, "run"

    const-string v4, "com/mmc/player/videocache/exocache/ExoCacheIO"

    const-string v5, "runnable"

    invoke-static {v1, v4, v5}, Lcom/shopee/monitor/trace/c;->a(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V

    :cond_1a
    const-string v1, "MMCExoCacheIO"

    .line 1
    new-instance v4, Ljava/lang/StringBuilder;

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

    iget-object v5, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v5, "read thread begin"

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

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

    move-result-object v4

    invoke-static {v1, v4}, Lcom/mmc/player/log/MMCLogDelegate;->i(Ljava/lang/String;Ljava/lang/String;)V

    .line 2
    iget-object v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->thread:Ljava/lang/Thread;

    const-string v4, "CacheRead"

    .line 3
    invoke-static {v4}, Landroid/support/v4/media/c;->c(Ljava/lang/String;)Ljava/lang/StringBuilder;

    move-result-object v4

    .line 4
    invoke-static {}, Landroid/os/Process;->myTid()I

    move-result v5

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

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

    move-result-object v4

    invoke-virtual {v1, v4}, Ljava/lang/Thread;->setName(Ljava/lang/String;)V

    .line 5
    :goto_48
    invoke-static {}, Ljava/lang/Thread;->interrupted()Z

    move-result v1

    if-nez v1, :cond_324

    const v1, 0x8000

    :try_start_51
    new-array v4, v1, [B

    .line 6
    iget-object v5, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bufferQueue:Ljava/util/concurrent/ArrayBlockingQueue;

    invoke-virtual {v5}, Ljava/util/concurrent/ArrayBlockingQueue;->size()I

    move-result v5

    iget v6, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->QUEUE_SIZE:I

    if-lt v5, v6, :cond_64

    .line 7
    iget v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->SLEEP_TIME_WHEN_QUEUE_FULL:I

    int-to-long v4, v1

    invoke-static {v4, v5}, Ljava/lang/Thread;->sleep(J)V

    goto :goto_48

    .line 8
    :cond_64
    iget-object v5, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bufferQueue:Ljava/util/concurrent/ArrayBlockingQueue;

    monitor-enter v5
    :try_end_67
    .catch Ljava/io/InterruptedIOException; {:try_start_51 .. :try_end_67} :catch_308
    .catch Lcom/shopee/sz/loadtask/exception/d; {:try_start_51 .. :try_end_67} :catch_2eb
    .catch Ljava/io/IOException; {:try_start_51 .. :try_end_67} :catch_18e
    .catch Ljava/lang/InterruptedException; {:try_start_51 .. :try_end_67} :catch_170
    .catchall {:try_start_51 .. :try_end_67} :catchall_14e

    .line 9
    :try_start_67
    iget-boolean v6, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->closed:Z

    if-eqz v6, :cond_86

    const-string v1, "MMCExoCacheIO"

    .line 10
    new-instance v4, Ljava/lang/StringBuilder;

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

    iget-object v6, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v6, "already closed"

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

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

    move-result-object v4

    invoke-static {v1, v4}, Lcom/mmc/player/log/MMCLogDelegate;->d(Ljava/lang/String;Ljava/lang/String;)V

    .line 11
    monitor-exit v5

    goto/16 :goto_324

    :cond_86
    const-string v6, "MMCExoCacheIO"

    .line 12
    new-instance v7, Ljava/lang/StringBuilder;

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

    iget-object v8, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v8, "start to read"

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

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

    move-result-object v7

    invoke-static {v6, v7}, Lcom/mmc/player/log/MMCLogDelegate;->v(Ljava/lang/String;Ljava/lang/String;)V

    .line 13
    iget-object v6, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->dataSource:Lcom/google/android/exoplayer2/upstream/l;

    invoke-interface {v6, v4, v3, v1}, Lcom/google/android/exoplayer2/upstream/i;->read([BII)I

    move-result v6

    const-wide/16 v7, 0x3e8

    if-lez v6, :cond_b7

    .line 14
    iget-wide v9, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->firstByteTime:J

    const-wide/16 v11, -0x1

    cmp-long v13, v9, v11

    if-nez v13, :cond_b7

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

    move-result-wide v9

    div-long/2addr v9, v7

    iput-wide v9, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->firstByteTime:J

    :cond_b7
    const-string v9, "MMCExoCacheIO"

    .line 16
    new-instance v10, Ljava/lang/StringBuilder;

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

    iget-object v11, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v11, "read result:"

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

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

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

    move-result-object v10

    invoke-static {v9, v10}, Lcom/mmc/player/log/MMCLogDelegate;->v(Ljava/lang/String;Ljava/lang/String;)V

    if-ltz v6, :cond_e6

    if-eq v6, v1, :cond_da

    .line 17
    invoke-static {v4, v6}, Ljava/util/Arrays;->copyOf([BI)[B

    move-result-object v4

    .line 18
    :cond_da
    iget-object v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bufferQueue:Ljava/util/concurrent/ArrayBlockingQueue;

    invoke-virtual {v1, v4}, Ljava/util/concurrent/ArrayBlockingQueue;->put(Ljava/lang/Object;)V

    .line 19
    iget-wide v7, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bytesRead:J

    int-to-long v9, v6

    add-long/2addr v7, v9

    iput-wide v7, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bytesRead:J

    goto :goto_135

    :cond_e6
    const/4 v1, -0x1

    if-ne v6, v1, :cond_135

    const-string v1, "MMCExoCacheIO"

    .line 20
    new-instance v4, Ljava/lang/StringBuilder;

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

    iget-object v6, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v6, "datasource reach end"

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

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

    move-result-object v4

    invoke-static {v1, v4}, Lcom/mmc/player/log/MMCLogDelegate;->i(Ljava/lang/String;Ljava/lang/String;)V

    .line 21
    iget-object v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bufferQueue:Ljava/util/concurrent/ArrayBlockingQueue;

    iget-object v4, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->eofByteArray:[B

    invoke-virtual {v1, v4}, Ljava/util/concurrent/ArrayBlockingQueue;->put(Ljava/lang/Object;)V

    const-wide/16 v9, 0x0

    .line 22
    iput-wide v9, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bytesRead:J

    .line 23
    iput-boolean v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->datasourceEndOfInput:Z

    .line 24
    iget-object v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->dataSource:Lcom/google/android/exoplayer2/upstream/l;

    invoke-interface {v1}, Lcom/google/android/exoplayer2/upstream/l;->close()V

    .line 25
    :goto_113
    iget-boolean v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->datasourceEndOfInput:Z

    if-eqz v1, :cond_11d

    .line 26
    iget-object v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bufferQueue:Ljava/util/concurrent/ArrayBlockingQueue;

    invoke-virtual {v1, v7, v8}, Ljava/lang/Object;->wait(J)V

    goto :goto_113

    :cond_11d
    const-string v1, "MMCExoCacheIO"

    .line 27
    new-instance v4, Ljava/lang/StringBuilder;

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

    iget-object v6, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v6, "datasource reach end, wait condition is notified"

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

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

    move-result-object v4

    invoke-static {v1, v4}, Lcom/mmc/player/log/MMCLogDelegate;->d(Ljava/lang/String;Ljava/lang/String;)V

    .line 28
    :cond_135
    :goto_135
    monitor-exit v5
    :try_end_136
    .catchall {:try_start_67 .. :try_end_136} :catchall_140

    .line 29
    :try_start_136
    iget v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->plusInterval:I

    int-to-long v4, v1

    const/16 v1, 0xa

    invoke-static {v4, v5, v1}, Ljava/lang/Thread;->sleep(JI)V
    :try_end_13e
    .catch Ljava/io/InterruptedIOException; {:try_start_136 .. :try_end_13e} :catch_308
    .catch Lcom/shopee/sz/loadtask/exception/d; {:try_start_136 .. :try_end_13e} :catch_2eb
    .catch Ljava/io/IOException; {:try_start_136 .. :try_end_13e} :catch_18e
    .catch Ljava/lang/InterruptedException; {:try_start_136 .. :try_end_13e} :catch_170
    .catchall {:try_start_136 .. :try_end_13e} :catchall_14e

    goto/16 :goto_48

    :catchall_140
    move-exception v1

    .line 30
    :try_start_141
    monitor-exit v5
    :try_end_142
    .catchall {:try_start_141 .. :try_end_142} :catchall_140

    if-eqz v0, :cond_14d

    :try_start_144
    const-string v4, "run"

    const-string v5, "com/mmc/player/videocache/exocache/ExoCacheIO"

    const-string v6, "runnable"

    invoke-static {v4, v5, v6}, Lcom/shopee/monitor/trace/c;->b(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V

    :cond_14d
    throw v1
    :try_end_14e
    .catch Ljava/io/InterruptedIOException; {:try_start_144 .. :try_end_14e} :catch_308
    .catch Lcom/shopee/sz/loadtask/exception/d; {:try_start_144 .. :try_end_14e} :catch_2eb
    .catch Ljava/io/IOException; {:try_start_144 .. :try_end_14e} :catch_18e
    .catch Ljava/lang/InterruptedException; {:try_start_144 .. :try_end_14e} :catch_170
    .catchall {:try_start_144 .. :try_end_14e} :catchall_14e

    :catchall_14e
    move-exception v1

    const-string v2, "MMCExoCacheIO"

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

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

    iget-object v4, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v4, "unexpected error, "

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

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

    move-result-object v1

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

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

    move-result-object v1

    invoke-static {v2, v1}, Lcom/mmc/player/log/MMCLogDelegate;->e(Ljava/lang/String;Ljava/lang/String;)V

    goto/16 :goto_324

    :catch_170
    move-exception v1

    .line 32
    invoke-static {v1}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->INVOKEVIRTUAL_com_mmc_player_videocache_exocache_ExoCacheIO_com_shopee_app_asm_fix_printstack_PrintStackTraceShieldFix_printStackTrace(Ljava/lang/InterruptedException;)V

    const-string v1, "MMCExoCacheIO"

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

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

    iget-object v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v3, "datasource read has InterruptedException in read thread"

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

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

    move-result-object v2

    invoke-static {v1, v2}, Lcom/mmc/player/log/MMCLogDelegate;->w(Ljava/lang/String;Ljava/lang/String;)V

    goto/16 :goto_324

    :catch_18e
    move-exception v1

    .line 34
    invoke-static {v1}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->INVOKEVIRTUAL_com_mmc_player_videocache_exocache_ExoCacheIO_com_shopee_app_asm_fix_printstack_PrintStackTraceShieldFix_printStackTrace(Ljava/io/IOException;)V

    const-string v4, "MMCExoCacheIO"

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

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

    iget-object v6, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v6, "datasource has IOException in read thread, "

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

    invoke-direct {p0, v1}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->extractMMSErrorMsg(Ljava/io/IOException;)Ljava/lang/String;

    move-result-object v6

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

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

    move-result-object v5

    invoke-static {v4, v5}, Lcom/mmc/player/log/MMCLogDelegate;->w(Ljava/lang/String;Ljava/lang/String;)V

    .line 36
    iget v4, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->recreateDatasourceTime:I

    iget v5, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->recreateDatasourceMax:I

    if-lt v4, v5, :cond_1c7

    .line 37
    invoke-direct {p0, v1}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->extractMMSErrorMsg(Ljava/io/IOException;)Ljava/lang/String;

    move-result-object v2

    iput-object v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->readErrorMsg:Ljava/lang/String;

    .line 38
    invoke-direct {p0, v1}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->extractMMSErrorCode(Ljava/io/IOException;)I

    move-result v1

    iput v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->readMMSErrCode:I

    .line 39
    iput v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->recreateDatasourceTime:I

    goto/16 :goto_324

    .line 40
    :cond_1c7
    invoke-static {}, Lcom/mmc/player/videocache/exocache/ExoCacheConfig;->getInstance()Lcom/mmc/player/videocache/exocache/ExoCacheConfig;

    move-result-object v4

    invoke-virtual {v4}, Lcom/mmc/player/videocache/exocache/ExoCacheConfig;->createCacheDataSource()Lcom/google/android/exoplayer2/upstream/l;

    move-result-object v4

    if-nez v4, :cond_200

    const-string v2, "MMCExoCacheIO"

    .line 41
    new-instance v4, Ljava/lang/StringBuilder;

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

    iget-object v5, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v5, "create null datasource "

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

    invoke-direct {p0, v1}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->extractMMSErrorMsg(Ljava/io/IOException;)Ljava/lang/String;

    move-result-object v5

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

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

    move-result-object v4

    invoke-static {v2, v4}, Lcom/mmc/player/log/MMCLogDelegate;->w(Ljava/lang/String;Ljava/lang/String;)V

    .line 42
    invoke-direct {p0, v1}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->extractMMSErrorMsg(Ljava/io/IOException;)Ljava/lang/String;

    move-result-object v2

    iput-object v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->readErrorMsg:Ljava/lang/String;

    .line 43
    invoke-direct {p0, v1}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->extractMMSErrorCode(Ljava/io/IOException;)I

    move-result v1

    iput v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->readMMSErrCode:I

    .line 44
    iput v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->recreateDatasourceTime:I

    goto/16 :goto_324

    .line 45
    :cond_200
    iget-object v5, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bufferQueue:Ljava/util/concurrent/ArrayBlockingQueue;

    monitor-enter v5

    .line 46
    :try_start_203
    invoke-direct {p0}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->closeQuietly()V

    .line 47
    iput-object v4, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->dataSource:Lcom/google/android/exoplayer2/upstream/l;

    .line 48
    invoke-interface {v4, p0}, Lcom/google/android/exoplayer2/upstream/l;->b(Lcom/google/android/exoplayer2/upstream/r0;)V

    const-string v4, "MMCExoCacheIO"

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

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

    iget-object v7, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v7, "create new datasource to reopen, recreateDatasourceTime:"

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

    iget v7, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->recreateDatasourceTime:I

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

    const-string v7, " bytesread:"

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

    iget-wide v7, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bytesRead:J

    invoke-virtual {v6, v7, v8}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

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

    move-result-object v6

    invoke-static {v4, v6}, Lcom/mmc/player/log/MMCLogDelegate;->i(Ljava/lang/String;Ljava/lang/String;)V
    :try_end_232
    .catchall {:try_start_203 .. :try_end_232} :catchall_2dd

    .line 50
    :try_start_232
    iget-object v4, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->dataSource:Lcom/google/android/exoplayer2/upstream/l;

    new-instance v13, Lcom/google/android/exoplayer2/upstream/o;

    iget-object v6, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->url:Ljava/lang/String;

    invoke-static {v6}, Landroid/net/Uri;->parse(Ljava/lang/String;)Landroid/net/Uri;

    move-result-object v7

    iget-wide v8, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->bytesRead:J

    const-wide/16 v10, -0x1

    iget-object v12, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->cacheKey:Ljava/lang/String;

    move-object v6, v13

    invoke-direct/range {v6 .. v12}, Lcom/google/android/exoplayer2/upstream/o;-><init>(Landroid/net/Uri;JJLjava/lang/String;)V

    invoke-interface {v4, v13}, Lcom/google/android/exoplayer2/upstream/l;->c(Lcom/google/android/exoplayer2/upstream/o;)J

    move-result-wide v6

    const-string v4, "MMCExoCacheIO"

    .line 51
    new-instance v8, Ljava/lang/StringBuilder;

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

    iget-object v9, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v9, "new datasource open ret:"

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

    invoke-virtual {v8, v6, v7}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

    const-string v6, " stream size:"

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

    iget-wide v6, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->streamSize:J

    invoke-virtual {v8, v6, v7}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

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

    move-result-object v6

    invoke-static {v4, v6}, Lcom/mmc/player/log/MMCLogDelegate;->i(Ljava/lang/String;Ljava/lang/String;)V
    :try_end_26f
    .catch Lcom/shopee/sz/loadtask/exception/d; {:try_start_232 .. :try_end_26f} :catch_2c0
    .catch Ljava/io/InterruptedIOException; {:try_start_232 .. :try_end_26f} :catch_2a6
    .catch Ljava/io/IOException; {:try_start_232 .. :try_end_26f} :catch_277
    .catchall {:try_start_232 .. :try_end_26f} :catchall_2dd

    .line 52
    :try_start_26f
    monitor-exit v5
    :try_end_270
    .catchall {:try_start_26f .. :try_end_270} :catchall_2dd

    .line 53
    iget v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->recreateDatasourceTime:I

    add-int/2addr v1, v2

    iput v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->recreateDatasourceTime:I

    goto/16 :goto_48

    :catch_277
    move-exception v1

    :try_start_278
    const-string v2, "MMCExoCacheIO"

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

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

    iget-object v4, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v4, "retry open new datasource fail again! "

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

    invoke-direct {p0, v1}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->extractMMSErrorMsg(Ljava/io/IOException;)Ljava/lang/String;

    move-result-object v4

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

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

    move-result-object v3

    invoke-static {v2, v3}, Lcom/mmc/player/log/MMCLogDelegate;->w(Ljava/lang/String;Ljava/lang/String;)V

    .line 55
    invoke-direct {p0, v1}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->extractMMSErrorMsg(Ljava/io/IOException;)Ljava/lang/String;

    move-result-object v2

    iput-object v2, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->readErrorMsg:Ljava/lang/String;

    .line 56
    invoke-direct {p0, v1}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->extractMMSErrorCode(Ljava/io/IOException;)I

    move-result v1

    iput v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->readMMSErrCode:I

    .line 57
    monitor-exit v5

    goto/16 :goto_324

    :catch_2a6
    const-string v1, "MMCExoCacheIO"

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

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

    iget-object v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v3, "InterruptedIOException, reopen datasource is interrupted"

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

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

    move-result-object v2

    invoke-static {v1, v2}, Lcom/mmc/player/log/MMCLogDelegate;->i(Ljava/lang/String;Ljava/lang/String;)V

    .line 59
    monitor-exit v5

    goto :goto_324

    .line 60
    :catch_2c0
    invoke-static {v1}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->INVOKEVIRTUAL_com_mmc_player_videocache_exocache_ExoCacheIO_com_shopee_app_asm_fix_printstack_PrintStackTraceShieldFix_printStackTrace(Ljava/io/IOException;)V

    const-string v1, "MMCExoCacheIO"

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

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

    iget-object v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v3, "TaskBlockInterruptException, reopen datasource is interrupted"

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

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

    move-result-object v2

    invoke-static {v1, v2}, Lcom/mmc/player/log/MMCLogDelegate;->i(Ljava/lang/String;Ljava/lang/String;)V

    .line 62
    monitor-exit v5

    goto :goto_324

    :catchall_2dd
    move-exception v1

    .line 63
    monitor-exit v5
    :try_end_2df
    .catchall {:try_start_278 .. :try_end_2df} :catchall_2dd

    if-eqz v0, :cond_2ea

    const-string v0, "run"

    const-string v2, "com/mmc/player/videocache/exocache/ExoCacheIO"

    const-string v3, "runnable"

    invoke-static {v0, v2, v3}, Lcom/shopee/monitor/trace/c;->b(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V

    :cond_2ea
    throw v1

    :catch_2eb
    move-exception v1

    .line 64
    invoke-static {v1}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->INVOKEVIRTUAL_com_mmc_player_videocache_exocache_ExoCacheIO_com_shopee_app_asm_fix_printstack_PrintStackTraceShieldFix_printStackTrace(Lcom/shopee/sz/loadtask/exception/d;)V

    const-string v1, "MMCExoCacheIO"

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

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

    iget-object v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v3, "datasource read has TaskBlockInterruptException in read thread"

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

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

    move-result-object v2

    invoke-static {v1, v2}, Lcom/mmc/player/log/MMCLogDelegate;->i(Ljava/lang/String;Ljava/lang/String;)V

    goto :goto_324

    :catch_308
    move-exception v1

    .line 66
    invoke-static {v1}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->INVOKEVIRTUAL_com_mmc_player_videocache_exocache_ExoCacheIO_com_shopee_app_asm_fix_printstack_PrintStackTraceShieldFix_printStackTrace(Ljava/io/InterruptedIOException;)V

    const-string v1, "MMCExoCacheIO"

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

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

    iget-object v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v3, "datasource read has InterruptedIOException in read thread"

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

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

    move-result-object v2

    invoke-static {v1, v2}, Lcom/mmc/player/log/MMCLogDelegate;->i(Ljava/lang/String;Ljava/lang/String;)V

    :cond_324
    :goto_324
    const-string v1, "MMCExoCacheIO"

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

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

    iget-object v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v3, "read thread end"

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

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

    move-result-object v2

    invoke-static {v1, v2}, Lcom/mmc/player/log/MMCLogDelegate;->i(Ljava/lang/String;Ljava/lang/String;)V

    if-eqz v0, :cond_347

    const-string v0, "run"

    const-string v1, "com/mmc/player/videocache/exocache/ExoCacheIO"

    const-string v2, "runnable"

    .line 69
    invoke-static {v0, v1, v2}, Lcom/shopee/monitor/trace/c;->b(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V

    :cond_347
    return-void
.end method

.method public seekIO(JI)J
    .registers 14

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

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

    iget-object v0, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v0, "seekIO"

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

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

    move-result-object p3

    const-string v0, "MMCExoCacheIO"

    invoke-static {v0, p3}, Lcom/mmc/player/log/MMCLogDelegate;->i(Ljava/lang/String;Ljava/lang/String;)V

    .line 2
    iget-object p3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->dataSource:Lcom/google/android/exoplayer2/upstream/l;

    const-wide/16 v1, -0x1

    if-nez p3, :cond_1f

    return-wide v1

    .line 3
    :cond_1f
    iget-boolean p3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->disableV2Function:Z

    if-nez p3, :cond_28

    .line 4
    invoke-direct {p0, p1, p2}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->seekV2(J)J

    move-result-wide p1

    return-wide p1

    .line 5
    :cond_28
    :try_start_28
    new-instance p3, Lcom/google/android/exoplayer2/upstream/o;

    iget-object v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->url:Ljava/lang/String;

    invoke-static {v3}, Landroid/net/Uri;->parse(Ljava/lang/String;)Landroid/net/Uri;

    move-result-object v4

    const-wide/16 v7, -0x1

    iget-object v9, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->cacheKey:Ljava/lang/String;

    move-object v3, p3

    move-wide v5, p1

    invoke-direct/range {v3 .. v9}, Lcom/google/android/exoplayer2/upstream/o;-><init>(Landroid/net/Uri;JJLjava/lang/String;)V

    .line 6
    iget-object v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->dataSource:Lcom/google/android/exoplayer2/upstream/l;

    invoke-interface {v3}, Lcom/google/android/exoplayer2/upstream/l;->close()V

    .line 7
    iget-object v3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->dataSource:Lcom/google/android/exoplayer2/upstream/l;

    invoke-interface {v3, p3}, Lcom/google/android/exoplayer2/upstream/l;->c(Lcom/google/android/exoplayer2/upstream/o;)J

    move-result-wide v3

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

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

    iget-object v5, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string v5, "seekpos:"

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

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

    const-string v5, ",datasource open ret:"

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

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

    const-string v5, ", result:"

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

    iget-wide v5, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->streamSize:J

    sub-long/2addr v5, v3

    invoke-virtual {p3, v5, v6}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

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

    move-result-object p3

    invoke-static {v0, p3}, Lcom/mmc/player/log/MMCLogDelegate;->i(Ljava/lang/String;Ljava/lang/String;)V
    :try_end_70
    .catch Ljava/io/IOException; {:try_start_28 .. :try_end_70} :catch_90
    .catchall {:try_start_28 .. :try_end_70} :catchall_71

    return-wide p1

    :catchall_71
    move-exception p1

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

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

    iget-object p3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string p3, "seek with unexpected error...."

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

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

    move-result-object p1

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

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

    move-result-object p1

    invoke-static {v0, p1}, Lcom/mmc/player/log/MMCLogDelegate;->e(Ljava/lang/String;Ljava/lang/String;)V

    return-wide v1

    :catch_90
    move-exception p1

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

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

    iget-object p3, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

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

    const-string p3, "seek error, datasource may open fail"

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

    invoke-direct {p0, p1}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->extractMMSErrorMsg(Ljava/io/IOException;)Ljava/lang/String;

    move-result-object p3

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

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

    move-result-object p2

    invoke-static {v0, p2}, Lcom/mmc/player/log/MMCLogDelegate;->e(Ljava/lang/String;Ljava/lang/String;)V

    .line 11
    invoke-static {p1}, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->INVOKEVIRTUAL_com_mmc_player_videocache_exocache_ExoCacheIO_com_shopee_app_asm_fix_printstack_PrintStackTraceShieldFix_printStackTrace(Ljava/io/IOException;)V

    return-wide v1
.end method

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

    iput-object p1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->cacheKey:Ljava/lang/String;

    return-void
.end method

.method public setDataSource(Lcom/google/android/exoplayer2/upstream/l;)V
    .registers 4

    const-string v0, "setExoDataSource["

    .line 1
    invoke-static {v0}, Landroid/support/v4/media/c;->c(Ljava/lang/String;)Ljava/lang/StringBuilder;

    move-result-object v0

    .line 2
    invoke-virtual {p1}, Ljava/lang/Object;->hashCode()I

    move-result v1

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

    const-string v1, "] "

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

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

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

    move-result-object v0

    const-string v1, "MMCExoCacheIO"

    invoke-static {v1, v0}, Lcom/mmc/player/log/MMCLogDelegate;->i(Ljava/lang/String;Ljava/lang/String;)V

    .line 3
    iput-object p1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->dataSource:Lcom/google/android/exoplayer2/upstream/l;

    return-void
.end method

.method public updateContentLength(J)V
    .registers 6

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

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

    iget-object v1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->LOG_PREFIX:Ljava/lang/String;

    const-string v2, "contentlength:"

    .line 2
    invoke-static {v0, v1, v2, p1, p2}, Landroidx/appcompat/p;->b(Ljava/lang/StringBuilder;Ljava/lang/String;Ljava/lang/String;J)Ljava/lang/String;

    move-result-object v0

    const-string v1, "MMCExoCacheIO"

    .line 3
    invoke-static {v1, v0}, Lcom/mmc/player/log/MMCLogDelegate;->i(Ljava/lang/String;Ljava/lang/String;)V

    .line 4
    iput-wide p1, p0, Lcom/mmc/player/videocache/exocache/ExoCacheIO;->streamSize:J

    return-void
.end method