Loader$LoadTask.smali
.class final Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;
.super Landroid/os/Handler;
.source "Loader.java"
# interfaces
.implements Ljava/lang/Runnable;
# annotations
.annotation system Ldalvik/annotation/EnclosingClass;
value = Lcom/google/android/exoplayer2/upstream/Loader;
.end annotation
.annotation system Ldalvik/annotation/InnerClass;
accessFlags = 0x12
name = "LoadTask"
.end annotation
.annotation system Ldalvik/annotation/Signature;
value = {
"<T::",
"Lcom/google/android/exoplayer2/upstream/Loader$Loadable;",
">",
"Landroid/os/Handler;",
"Ljava/lang/Runnable;"
}
.end annotation
# static fields
.field private static final MSG_CANCEL:I
.field private static final MSG_END_OF_SOURCE:I
.field private static final MSG_FATAL_ERROR:I
.field private static final MSG_IO_EXCEPTION:I
.field private static final MSG_START:I
.field private static final TAG:Ljava/lang/String; = "LoadTask"
# instance fields
.field private callback:Lcom/google/android/exoplayer2/upstream/Loader$Callback;
.annotation system Ldalvik/annotation/Signature;
value = {
"Lcom/google/android/exoplayer2/upstream/Loader$Callback<",
"TT;>;"
}
.end annotation
.end field
.field private volatile canceled:Z
.field private currentError:Ljava/io/IOException;
.field public final defaultMinRetryCount:I
.field private errorCount:I
.field private volatile executorThread:Ljava/lang/Thread;
.field private final loadable:Lcom/google/android/exoplayer2/upstream/Loader$Loadable;
.annotation system Ldalvik/annotation/Signature;
value = {
"TT;"
}
.end annotation
.end field
.field private volatile released:Z
.field private final startTimeMs:J
.field final synthetic this$0:Lcom/google/android/exoplayer2/upstream/Loader;
# direct methods
.method static constructor <clinit>()V
.registers 1
const v0, 0x156e
invoke-static {v0}, Lnp/NPFog;->d(I)I
move-result v0
sput v0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->MSG_CANCEL:I
const v0, 0x156d
invoke-static {v0}, Lnp/NPFog;->d(I)I
move-result v0
sput v0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->MSG_END_OF_SOURCE:I
const v0, 0x156b
invoke-static {v0}, Lnp/NPFog;->d(I)I
move-result v0
sput v0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->MSG_FATAL_ERROR:I
const v0, 0x156c
invoke-static {v0}, Lnp/NPFog;->d(I)I
move-result v0
sput v0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->MSG_IO_EXCEPTION:I
const v0, 0x156f
invoke-static {v0}, Lnp/NPFog;->d(I)I
move-result v0
sput v0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->MSG_START:I
return-void
.end method
.method public constructor <init>(Lcom/google/android/exoplayer2/upstream/Loader;Landroid/os/Looper;Lcom/google/android/exoplayer2/upstream/Loader$Loadable;Lcom/google/android/exoplayer2/upstream/Loader$Callback;IJ)V
.registers 8
.param p2, "looper" # Landroid/os/Looper;
.param p5, "defaultMinRetryCount" # I
.param p6, "startTimeMs" # J
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Landroid/os/Looper;",
"TT;",
"Lcom/google/android/exoplayer2/upstream/Loader$Callback<",
"TT;>;IJ)V"
}
.end annotation
.line 323
.local p0, "this":Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;, "Lcom/google/android/exoplayer2/upstream/Loader$LoadTask<TT;>;"
.local p3, "loadable":Lcom/google/android/exoplayer2/upstream/Loader$Loadable;, "TT;"
.local p4, "callback":Lcom/google/android/exoplayer2/upstream/Loader$Callback;, "Lcom/google/android/exoplayer2/upstream/Loader$Callback<TT;>;"
iput-object p1, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->this$0:Lcom/google/android/exoplayer2/upstream/Loader;
.line 324
invoke-direct {p0, p2}, Landroid/os/Handler;-><init>(Landroid/os/Looper;)V
.line 325
iput-object p3, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->loadable:Lcom/google/android/exoplayer2/upstream/Loader$Loadable;
.line 326
iput-object p4, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->callback:Lcom/google/android/exoplayer2/upstream/Loader$Callback;
.line 327
iput p5, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->defaultMinRetryCount:I
.line 328
iput-wide p6, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->startTimeMs:J
.line 329
return-void
.end method
.method private execute()V
.registers 3
.line 481
.local p0, "this":Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;, "Lcom/google/android/exoplayer2/upstream/Loader$LoadTask<TT;>;"
const/4 v0, 0x0
iput-object v0, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->currentError:Ljava/io/IOException;
.line 482
iget-object v0, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->this$0:Lcom/google/android/exoplayer2/upstream/Loader;
invoke-static {v0}, Lcom/google/android/exoplayer2/upstream/Loader;->access$500(Lcom/google/android/exoplayer2/upstream/Loader;)Ljava/util/concurrent/ExecutorService;
move-result-object v0
iget-object v1, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->this$0:Lcom/google/android/exoplayer2/upstream/Loader;
invoke-static {v1}, Lcom/google/android/exoplayer2/upstream/Loader;->access$100(Lcom/google/android/exoplayer2/upstream/Loader;)Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;
move-result-object v1
invoke-interface {v0, v1}, Ljava/util/concurrent/ExecutorService;->execute(Ljava/lang/Runnable;)V
.line 483
return-void
.end method
.method private finish()V
.registers 3
.line 486
.local p0, "this":Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;, "Lcom/google/android/exoplayer2/upstream/Loader$LoadTask<TT;>;"
iget-object v0, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->this$0:Lcom/google/android/exoplayer2/upstream/Loader;
const/4 v1, 0x0
invoke-static {v0, v1}, Lcom/google/android/exoplayer2/upstream/Loader;->access$102(Lcom/google/android/exoplayer2/upstream/Loader;Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;)Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;
.line 487
return-void
.end method
.method private getRetryDelayMillis()J
.registers 3
.line 490
.local p0, "this":Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;, "Lcom/google/android/exoplayer2/upstream/Loader$LoadTask<TT;>;"
iget v0, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->errorCount:I
add-int/lit8 v0, v0, -0x1
mul-int/lit16 v0, v0, 0x3e8
const/16 v1, 0x1388
invoke-static {v0, v1}, Ljava/lang/Math;->min(II)I
move-result v0
int-to-long v0, v0
return-wide v0
.end method
# virtual methods
.method public cancel(Z)V
.registers 13
.param p1, "released" # Z
.line 348
.local p0, "this":Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;, "Lcom/google/android/exoplayer2/upstream/Loader$LoadTask<TT;>;"
iput-boolean p1, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->released:Z
.line 349
const/4 v0, 0x0
iput-object v0, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->currentError:Ljava/io/IOException;
.line 350
const/4 v1, 0x0
invoke-virtual {p0, v1}, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->hasMessages(I)Z
move-result v2
const/4 v3, 0x1
if-eqz v2, :cond_16
.line 351
invoke-virtual {p0, v1}, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->removeMessages(I)V
.line 352
if-nez p1, :cond_26
.line 353
invoke-virtual {p0, v3}, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->sendEmptyMessage(I)Z
goto :goto_26
.line 356
:cond_16
iput-boolean v3, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->canceled:Z
.line 357
iget-object v1, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->loadable:Lcom/google/android/exoplayer2/upstream/Loader$Loadable;
invoke-interface {v1}, Lcom/google/android/exoplayer2/upstream/Loader$Loadable;->cancelLoad()V
.line 358
iget-object v1, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->executorThread:Ljava/lang/Thread;
if-eqz v1, :cond_26
.line 359
iget-object v1, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->executorThread:Ljava/lang/Thread;
invoke-virtual {v1}, Ljava/lang/Thread;->interrupt()V
.line 362
:cond_26
:goto_26
if-eqz p1, :cond_3e
.line 363
invoke-direct {p0}, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->finish()V
.line 364
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v9
.line 365
.local v9, "nowMs":J
iget-object v2, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->callback:Lcom/google/android/exoplayer2/upstream/Loader$Callback;
iget-object v3, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->loadable:Lcom/google/android/exoplayer2/upstream/Loader$Loadable;
iget-wide v4, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->startTimeMs:J
sub-long v6, v9, v4
const/4 v8, 0x1
move-wide v4, v9
invoke-interface/range {v2 .. v8}, Lcom/google/android/exoplayer2/upstream/Loader$Callback;->onLoadCanceled(Lcom/google/android/exoplayer2/upstream/Loader$Loadable;JJZ)V
.line 370
iput-object v0, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->callback:Lcom/google/android/exoplayer2/upstream/Loader$Callback;
.line 372
.end local v9 # "nowMs":J
:cond_3e
return-void
.end method
.method public handleMessage(Landroid/os/Message;)V
.registers 19
.param p1, "msg" # Landroid/os/Message;
.line 427
.local p0, "this":Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;, "Lcom/google/android/exoplayer2/upstream/Loader$LoadTask<TT;>;"
move-object/from16 v1, p0
move-object/from16 v2, p1
iget-boolean v0, v1, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->released:Z
if-eqz v0, :cond_9
.line 428
return-void
.line 430
:cond_9
iget v0, v2, Landroid/os/Message;->what:I
if-nez v0, :cond_11
.line 431
invoke-direct/range {p0 .. p0}, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->execute()V
.line 432
return-void
.line 434
:cond_11
iget v0, v2, Landroid/os/Message;->what:I
const/4 v3, 0x4
if-eq v0, v3, :cond_bb
.line 437
invoke-direct/range {p0 .. p0}, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->finish()V
.line 438
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v12
.line 439
.local v12, "nowMs":J
iget-wide v3, v1, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->startTimeMs:J
sub-long v14, v12, v3
.line 440
.local v14, "durationMs":J
iget-boolean v0, v1, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->canceled:Z
if-eqz v0, :cond_30
.line 441
iget-object v4, v1, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->callback:Lcom/google/android/exoplayer2/upstream/Loader$Callback;
iget-object v5, v1, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->loadable:Lcom/google/android/exoplayer2/upstream/Loader$Loadable;
const/4 v10, 0x0
move-wide v6, v12
move-wide v8, v14
invoke-interface/range {v4 .. v10}, Lcom/google/android/exoplayer2/upstream/Loader$Callback;->onLoadCanceled(Lcom/google/android/exoplayer2/upstream/Loader$Loadable;JJZ)V
.line 442
return-void
.line 444
:cond_30
iget v0, v2, Landroid/os/Message;->what:I
const/4 v3, 0x1
if-eq v0, v3, :cond_af
const/4 v11, 0x2
if-eq v0, v11, :cond_92
const/4 v10, 0x3
if-eq v0, v10, :cond_3d
goto/16 :goto_ba
.line 458
:cond_3d
iget-object v0, v2, Landroid/os/Message;->obj:Ljava/lang/Object;
check-cast v0, Ljava/io/IOException;
iput-object v0, v1, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->currentError:Ljava/io/IOException;
.line 459
iget v4, v1, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->errorCount:I
add-int/lit8 v8, v4, 0x1
iput v8, v1, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->errorCount:I
.line 460
iget-object v4, v1, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->callback:Lcom/google/android/exoplayer2/upstream/Loader$Callback;
iget-object v5, v1, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->loadable:Lcom/google/android/exoplayer2/upstream/Loader$Loadable;
.line 461
move-wide v6, v12
move/from16 v16, v8
move-wide v8, v14
const/4 v3, 0x3
move-object v10, v0
const/4 v0, 0x2
move/from16 v11, v16
invoke-interface/range {v4 .. v11}, Lcom/google/android/exoplayer2/upstream/Loader$Callback;->onLoadError(Lcom/google/android/exoplayer2/upstream/Loader$Loadable;JJLjava/io/IOException;I)Lcom/google/android/exoplayer2/upstream/Loader$LoadErrorAction;
move-result-object v4
.line 462
.local v4, "action":Lcom/google/android/exoplayer2/upstream/Loader$LoadErrorAction;
# getter for: Lcom/google/android/exoplayer2/upstream/Loader$LoadErrorAction;->type:I
invoke-static {v4}, Lcom/google/android/exoplayer2/upstream/Loader$LoadErrorAction;->access$300(Lcom/google/android/exoplayer2/upstream/Loader$LoadErrorAction;)I
move-result v5
if-ne v5, v3, :cond_68
.line 463
iget-object v0, v1, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->this$0:Lcom/google/android/exoplayer2/upstream/Loader;
iget-object v3, v1, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->currentError:Ljava/io/IOException;
invoke-static {v0, v3}, Lcom/google/android/exoplayer2/upstream/Loader;->access$202(Lcom/google/android/exoplayer2/upstream/Loader;Ljava/io/IOException;)Ljava/io/IOException;
goto :goto_ba
.line 464
:cond_68
# getter for: Lcom/google/android/exoplayer2/upstream/Loader$LoadErrorAction;->type:I
invoke-static {v4}, Lcom/google/android/exoplayer2/upstream/Loader$LoadErrorAction;->access$300(Lcom/google/android/exoplayer2/upstream/Loader$LoadErrorAction;)I
move-result v3
if-eq v3, v0, :cond_ba
.line 465
# getter for: Lcom/google/android/exoplayer2/upstream/Loader$LoadErrorAction;->type:I
invoke-static {v4}, Lcom/google/android/exoplayer2/upstream/Loader$LoadErrorAction;->access$300(Lcom/google/android/exoplayer2/upstream/Loader$LoadErrorAction;)I
move-result v0
const/4 v3, 0x1
if-ne v0, v3, :cond_77
.line 466
iput v3, v1, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->errorCount:I
.line 468
:cond_77
nop
.line 469
# getter for: Lcom/google/android/exoplayer2/upstream/Loader$LoadErrorAction;->retryDelayMillis:J
invoke-static {v4}, Lcom/google/android/exoplayer2/upstream/Loader$LoadErrorAction;->access$400(Lcom/google/android/exoplayer2/upstream/Loader$LoadErrorAction;)J
move-result-wide v5
const-wide v7, -0x7fffffffffffffffL # -4.9E-324
cmp-long v0, v5, v7
if-eqz v0, :cond_8a
.line 470
# getter for: Lcom/google/android/exoplayer2/upstream/Loader$LoadErrorAction;->retryDelayMillis:J
invoke-static {v4}, Lcom/google/android/exoplayer2/upstream/Loader$LoadErrorAction;->access$400(Lcom/google/android/exoplayer2/upstream/Loader$LoadErrorAction;)J
move-result-wide v5
goto :goto_8e
.line 471
:cond_8a
invoke-direct/range {p0 .. p0}, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->getRetryDelayMillis()J
move-result-wide v5
.line 468
:goto_8e
invoke-virtual {v1, v5, v6}, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->start(J)V
goto :goto_ba
.line 450
.end local v4 # "action":Lcom/google/android/exoplayer2/upstream/Loader$LoadErrorAction;
:cond_92
:try_start_92
iget-object v4, v1, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->callback:Lcom/google/android/exoplayer2/upstream/Loader$Callback;
iget-object v5, v1, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->loadable:Lcom/google/android/exoplayer2/upstream/Loader$Loadable;
move-wide v6, v12
move-wide v8, v14
invoke-interface/range {v4 .. v9}, Lcom/google/android/exoplayer2/upstream/Loader$Callback;->onLoadCompleted(Lcom/google/android/exoplayer2/upstream/Loader$Loadable;JJ)V
:try_end_9b
.catch Ljava/lang/RuntimeException; {:try_start_92 .. :try_end_9b} :catch_9c
.line 455
goto :goto_ba
.line 451
:catch_9c
move-exception v0
.line 453
.local v0, "e":Ljava/lang/RuntimeException;
const-string v3, "LoadTask"
const-string v4, "Unexpected exception handling load completed"
invoke-static {v3, v4, v0}, Lcom/google/android/exoplayer2/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 454
iget-object v3, v1, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->this$0:Lcom/google/android/exoplayer2/upstream/Loader;
new-instance v4, Lcom/google/android/exoplayer2/upstream/Loader$UnexpectedLoaderException;
invoke-direct {v4, v0}, Lcom/google/android/exoplayer2/upstream/Loader$UnexpectedLoaderException;-><init>(Ljava/lang/Throwable;)V
invoke-static {v3, v4}, Lcom/google/android/exoplayer2/upstream/Loader;->access$202(Lcom/google/android/exoplayer2/upstream/Loader;Ljava/io/IOException;)Ljava/io/IOException;
.line 456
.end local v0 # "e":Ljava/lang/RuntimeException;
goto :goto_ba
.line 446
:cond_af
iget-object v4, v1, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->callback:Lcom/google/android/exoplayer2/upstream/Loader$Callback;
iget-object v5, v1, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->loadable:Lcom/google/android/exoplayer2/upstream/Loader$Loadable;
const/4 v10, 0x0
move-wide v6, v12
move-wide v8, v14
invoke-interface/range {v4 .. v10}, Lcom/google/android/exoplayer2/upstream/Loader$Callback;->onLoadCanceled(Lcom/google/android/exoplayer2/upstream/Loader$Loadable;JJZ)V
.line 447
nop
.line 478
:cond_ba
:goto_ba
return-void
.line 435
.end local v12 # "nowMs":J
.end local v14 # "durationMs":J
:cond_bb
iget-object v0, v2, Landroid/os/Message;->obj:Ljava/lang/Object;
check-cast v0, Ljava/lang/Error;
throw v0
.end method
.method public maybeThrowError(I)V
.registers 4
.param p1, "minRetryCount" # I
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 332
.local p0, "this":Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;, "Lcom/google/android/exoplayer2/upstream/Loader$LoadTask<TT;>;"
iget-object v0, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->currentError:Ljava/io/IOException;
if-eqz v0, :cond_a
iget v1, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->errorCount:I
if-gt v1, p1, :cond_9
goto :goto_a
.line 333
:cond_9
throw v0
.line 335
:cond_a
:goto_a
return-void
.end method
.method public run()V
.registers 6
.line 377
.local p0, "this":Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;, "Lcom/google/android/exoplayer2/upstream/Loader$LoadTask<TT;>;"
const-string v0, "LoadTask"
const/4 v1, 0x2
const/4 v2, 0x3
:try_start_4
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object v3
iput-object v3, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->executorThread:Ljava/lang/Thread;
.line 378
iget-boolean v3, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->canceled:Z
if-nez v3, :cond_3a
.line 379
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "load:"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v4, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->loadable:Lcom/google/android/exoplayer2/upstream/Loader$Loadable;
invoke-virtual {v4}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
move-result-object v4
invoke-virtual {v4}, Ljava/lang/Class;->getSimpleName()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 {v3}, Lcom/google/android/exoplayer2/util/TraceUtil;->beginSection(Ljava/lang/String;)V
:try_end_2c
.catch Ljava/io/IOException; {:try_start_4 .. :try_end_2c} :catch_91
.catch Ljava/lang/InterruptedException; {:try_start_4 .. :try_end_2c} :catch_83
.catch Ljava/lang/Exception; {:try_start_4 .. :try_end_2c} :catch_6c
.catch Ljava/lang/OutOfMemoryError; {:try_start_4 .. :try_end_2c} :catch_55
.catch Ljava/lang/Error; {:try_start_4 .. :try_end_2c} :catch_42
.line 381
:try_start_2c
iget-object v3, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->loadable:Lcom/google/android/exoplayer2/upstream/Loader$Loadable;
invoke-interface {v3}, Lcom/google/android/exoplayer2/upstream/Loader$Loadable;->load()V
:try_end_31
.catchall {:try_start_2c .. :try_end_31} :catchall_35
.line 383
:try_start_31
invoke-static {}, Lcom/google/android/exoplayer2/util/TraceUtil;->endSection()V
.line 384
goto :goto_3a
.line 383
:catchall_35
move-exception v3
invoke-static {}, Lcom/google/android/exoplayer2/util/TraceUtil;->endSection()V
.line 384
throw v3
.line 386
:cond_3a
:goto_3a
iget-boolean v3, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->released:Z
if-nez v3, :cond_9d
.line 387
invoke-virtual {p0, v1}, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->sendEmptyMessage(I)Z
:try_end_41
.catch Ljava/io/IOException; {:try_start_31 .. :try_end_41} :catch_91
.catch Ljava/lang/InterruptedException; {:try_start_31 .. :try_end_41} :catch_83
.catch Ljava/lang/Exception; {:try_start_31 .. :try_end_41} :catch_6c
.catch Ljava/lang/OutOfMemoryError; {:try_start_31 .. :try_end_41} :catch_55
.catch Ljava/lang/Error; {:try_start_31 .. :try_end_41} :catch_42
goto :goto_9d
.line 413
:catch_42
move-exception v1
.line 417
.local v1, "e":Ljava/lang/Error;
const-string v2, "Unexpected error loading stream"
invoke-static {v0, v2, v1}, Lcom/google/android/exoplayer2/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 418
iget-boolean v0, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->released:Z
if-nez v0, :cond_54
.line 419
const/4 v0, 0x4
invoke-virtual {p0, v0, v1}, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->obtainMessage(ILjava/lang/Object;)Landroid/os/Message;
move-result-object v0
invoke-virtual {v0}, Landroid/os/Message;->sendToTarget()V
.line 421
:cond_54
throw v1
.line 405
.end local v1 # "e":Ljava/lang/Error;
:catch_55
move-exception v1
.line 409
.local v1, "e":Ljava/lang/OutOfMemoryError;
const-string v3, "OutOfMemory error loading stream"
invoke-static {v0, v3, v1}, Lcom/google/android/exoplayer2/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 410
iget-boolean v0, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->released:Z
if-nez v0, :cond_9d
.line 411
new-instance v0, Lcom/google/android/exoplayer2/upstream/Loader$UnexpectedLoaderException;
invoke-direct {v0, v1}, Lcom/google/android/exoplayer2/upstream/Loader$UnexpectedLoaderException;-><init>(Ljava/lang/Throwable;)V
invoke-virtual {p0, v2, v0}, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->obtainMessage(ILjava/lang/Object;)Landroid/os/Message;
move-result-object v0
invoke-virtual {v0}, Landroid/os/Message;->sendToTarget()V
goto :goto_9d
.line 399
.end local v1 # "e":Ljava/lang/OutOfMemoryError;
:catch_6c
move-exception v1
.line 401
.local v1, "e":Ljava/lang/Exception;
const-string v3, "Unexpected exception loading stream"
invoke-static {v0, v3, v1}, Lcom/google/android/exoplayer2/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V
.line 402
iget-boolean v0, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->released:Z
if-nez v0, :cond_9d
.line 403
new-instance v0, Lcom/google/android/exoplayer2/upstream/Loader$UnexpectedLoaderException;
invoke-direct {v0, v1}, Lcom/google/android/exoplayer2/upstream/Loader$UnexpectedLoaderException;-><init>(Ljava/lang/Throwable;)V
invoke-virtual {p0, v2, v0}, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->obtainMessage(ILjava/lang/Object;)Landroid/os/Message;
move-result-object v0
invoke-virtual {v0}, Landroid/os/Message;->sendToTarget()V
goto :goto_9d
.line 393
.end local v1 # "e":Ljava/lang/Exception;
:catch_83
move-exception v0
.line 395
.local v0, "e":Ljava/lang/InterruptedException;
iget-boolean v2, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->canceled:Z
invoke-static {v2}, Lcom/google/android/exoplayer2/util/Assertions;->checkState(Z)V
.line 396
iget-boolean v2, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->released:Z
if-nez v2, :cond_9d
.line 397
invoke-virtual {p0, v1}, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->sendEmptyMessage(I)Z
goto :goto_9d
.line 389
.end local v0 # "e":Ljava/lang/InterruptedException;
:catch_91
move-exception v0
.line 390
.local v0, "e":Ljava/io/IOException;
iget-boolean v1, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->released:Z
if-nez v1, :cond_9d
.line 391
invoke-virtual {p0, v2, v0}, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->obtainMessage(ILjava/lang/Object;)Landroid/os/Message;
move-result-object v1
invoke-virtual {v1}, Landroid/os/Message;->sendToTarget()V
.line 422
.end local v0 # "e":Ljava/io/IOException;
:cond_9d
:goto_9d
nop
.line 423
return-void
.end method
.method public start(J)V
.registers 7
.param p1, "delayMillis" # J
.line 338
.local p0, "this":Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;, "Lcom/google/android/exoplayer2/upstream/Loader$LoadTask<TT;>;"
iget-object v0, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->this$0:Lcom/google/android/exoplayer2/upstream/Loader;
invoke-static {v0}, Lcom/google/android/exoplayer2/upstream/Loader;->access$100(Lcom/google/android/exoplayer2/upstream/Loader;)Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;
move-result-object v0
const/4 v1, 0x0
if-nez v0, :cond_b
const/4 v0, 0x1
goto :goto_c
:cond_b
const/4 v0, 0x0
:goto_c
invoke-static {v0}, Lcom/google/android/exoplayer2/util/Assertions;->checkState(Z)V
.line 339
iget-object v0, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->this$0:Lcom/google/android/exoplayer2/upstream/Loader;
invoke-static {v0, p0}, Lcom/google/android/exoplayer2/upstream/Loader;->access$102(Lcom/google/android/exoplayer2/upstream/Loader;Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;)Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;
.line 340
const-wide/16 v2, 0x0
cmp-long v0, p1, v2
if-lez v0, :cond_1e
.line 341
invoke-virtual {p0, v1, p1, p2}, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->sendEmptyMessageDelayed(IJ)Z
goto :goto_21
.line 343
:cond_1e
invoke-direct {p0}, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->execute()V
.line 345
:goto_21
return-void
.end method