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