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 TAG:Ljava/lang/String; = "LoadTask"
# instance fields
.field private final 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 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 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
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Landroid/os/Looper;",
"TT;",
"Lcom/google/android/exoplayer2/upstream/Loader$Callback<",
"TT;>;IJ)V"
}
.end annotation
.line 243
iput-object p1, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->this$0:Lcom/google/android/exoplayer2/upstream/Loader;
.line 244
invoke-direct {p0, p2}, Landroid/os/Handler;-><init>(Landroid/os/Looper;)V
.line 245
iput-object p3, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->loadable:Lcom/google/android/exoplayer2/upstream/Loader$Loadable;
.line 246
iput-object p4, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->callback:Lcom/google/android/exoplayer2/upstream/Loader$Callback;
.line 247
iput p5, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->defaultMinRetryCount:I
.line 248
iput-wide p6, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->startTimeMs:J
return-void
.end method
.method private finish()V
.registers 3
.line 376
iget-object v0, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->this$0:Lcom/google/android/exoplayer2/upstream/Loader;
const/4 v1, 0x0
# setter for: Lcom/google/android/exoplayer2/upstream/Loader;->currentTask:Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;
invoke-static {v0, v1}, Lcom/google/android/exoplayer2/upstream/Loader;->access$002(Lcom/google/android/exoplayer2/upstream/Loader;Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;)Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;
return-void
.end method
.method private getRetryDelayMillis()J
.registers 3
.line 380
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
.method private submitToExecutor()V
.registers 3
const/4 v0, 0x0
.line 371
iput-object v0, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->currentError:Ljava/io/IOException;
.line 372
iget-object v0, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->this$0:Lcom/google/android/exoplayer2/upstream/Loader;
# getter for: Lcom/google/android/exoplayer2/upstream/Loader;->downloadExecutorService:Ljava/util/concurrent/ExecutorService;
invoke-static {v0}, Lcom/google/android/exoplayer2/upstream/Loader;->access$200(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;
# getter for: Lcom/google/android/exoplayer2/upstream/Loader;->currentTask:Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;
invoke-static {v1}, Lcom/google/android/exoplayer2/upstream/Loader;->access$000(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;->submit(Ljava/lang/Runnable;)Ljava/util/concurrent/Future;
return-void
.end method
# virtual methods
.method public cancel(Z)V
.registers 10
.line 268
iput-boolean p1, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->released:Z
const/4 v0, 0x0
.line 269
iput-object v0, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->currentError:Ljava/io/IOException;
const/4 v0, 0x0
.line 270
invoke-virtual {p0, v0}, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->hasMessages(I)Z
move-result v1
if-eqz v1, :cond_16
.line 271
invoke-virtual {p0, v0}, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->removeMessages(I)V
if-nez p1, :cond_24
const/4 v0, 0x1
.line 273
invoke-virtual {p0, v0}, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->sendEmptyMessage(I)Z
goto :goto_24
.line 276
:cond_16
iget-object v0, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->loadable:Lcom/google/android/exoplayer2/upstream/Loader$Loadable;
invoke-interface {v0}, Lcom/google/android/exoplayer2/upstream/Loader$Loadable;->cancelLoad()V
.line 277
iget-object v0, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->executorThread:Ljava/lang/Thread;
if-eqz v0, :cond_24
.line 278
iget-object v0, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->executorThread:Ljava/lang/Thread;
invoke-virtual {v0}, Ljava/lang/Thread;->interrupt()V
:cond_24
:goto_24
if-eqz p1, :cond_39
.line 282
invoke-direct {p0}, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->finish()V
.line 283
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v3
.line 284
iget-object v1, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->callback:Lcom/google/android/exoplayer2/upstream/Loader$Callback;
iget-object v2, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->loadable:Lcom/google/android/exoplayer2/upstream/Loader$Loadable;
iget-wide v5, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->startTimeMs:J
sub-long v5, v3, v5
const/4 v7, 0x1
invoke-interface/range {v1 .. v7}, Lcom/google/android/exoplayer2/upstream/Loader$Callback;->onLoadCanceled(Lcom/google/android/exoplayer2/upstream/Loader$Loadable;JJZ)V
:cond_39
return-void
.end method
.method public handleMessage(Landroid/os/Message;)V
.registers 13
.line 333
iget-boolean v0, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->released:Z
if-eqz v0, :cond_5
return-void
.line 336
:cond_5
iget v0, p1, Landroid/os/Message;->what:I
if-nez v0, :cond_d
.line 337
invoke-direct {p0}, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->submitToExecutor()V
return-void
.line 340
:cond_d
iget v0, p1, Landroid/os/Message;->what:I
const/4 v1, 0x4
if-eq v0, v1, :cond_76
.line 343
invoke-direct {p0}, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->finish()V
.line 344
invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J
move-result-wide v4
.line 345
iget-wide v0, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->startTimeMs:J
sub-long v6, v4, v0
.line 346
iget-object v0, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->loadable:Lcom/google/android/exoplayer2/upstream/Loader$Loadable;
invoke-interface {v0}, Lcom/google/android/exoplayer2/upstream/Loader$Loadable;->isLoadCanceled()Z
move-result v0
if-eqz v0, :cond_2e
.line 347
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;
const/4 v8, 0x0
invoke-interface/range {v2 .. v8}, Lcom/google/android/exoplayer2/upstream/Loader$Callback;->onLoadCanceled(Lcom/google/android/exoplayer2/upstream/Loader$Loadable;JJZ)V
return-void
.line 350
:cond_2e
iget v0, p1, Landroid/os/Message;->what:I
const/4 v1, 0x1
if-eq v0, v1, :cond_6d
const/4 v9, 0x2
if-eq v0, v9, :cond_65
const/4 v10, 0x3
if-eq v0, v10, :cond_3a
goto :goto_75
.line 358
:cond_3a
iget-object p1, p1, Landroid/os/Message;->obj:Ljava/lang/Object;
move-object v8, p1
check-cast v8, Ljava/io/IOException;
iput-object v8, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->currentError:Ljava/io/IOException;
.line 359
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;
invoke-interface/range {v2 .. v8}, Lcom/google/android/exoplayer2/upstream/Loader$Callback;->onLoadError(Lcom/google/android/exoplayer2/upstream/Loader$Loadable;JJLjava/io/IOException;)I
move-result p1
if-ne p1, v10, :cond_53
.line 361
iget-object p1, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->this$0:Lcom/google/android/exoplayer2/upstream/Loader;
iget-object v0, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->currentError:Ljava/io/IOException;
# setter for: Lcom/google/android/exoplayer2/upstream/Loader;->fatalError:Ljava/io/IOException;
invoke-static {p1, v0}, Lcom/google/android/exoplayer2/upstream/Loader;->access$102(Lcom/google/android/exoplayer2/upstream/Loader;Ljava/io/IOException;)Ljava/io/IOException;
goto :goto_75
:cond_53
if-eq p1, v9, :cond_75
if-ne p1, v1, :cond_58
goto :goto_5b
.line 363
:cond_58
iget p1, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->errorCount:I
add-int/2addr v1, p1
:goto_5b
iput v1, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->errorCount:I
.line 364
invoke-direct {p0}, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->getRetryDelayMillis()J
move-result-wide v0
invoke-virtual {p0, v0, v1}, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->start(J)V
goto :goto_75
.line 355
:cond_65
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;
invoke-interface/range {v2 .. v7}, Lcom/google/android/exoplayer2/upstream/Loader$Callback;->onLoadCompleted(Lcom/google/android/exoplayer2/upstream/Loader$Loadable;JJ)V
goto :goto_75
.line 352
:cond_6d
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;
const/4 v8, 0x0
invoke-interface/range {v2 .. v8}, Lcom/google/android/exoplayer2/upstream/Loader$Callback;->onLoadCanceled(Lcom/google/android/exoplayer2/upstream/Loader$Loadable;JJZ)V
:cond_75
:goto_75
return-void
.line 341
:cond_76
iget-object p1, p1, Landroid/os/Message;->obj:Ljava/lang/Object;
check-cast p1, Ljava/lang/Error;
throw p1
.end method
.method public maybeThrowError(I)V
.registers 4
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 252
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 253
:cond_9
throw v0
:cond_a
:goto_a
return-void
.end method
.method public run()V
.registers 6
const-string v0, "LoadTask"
const/4 v1, 0x2
const/4 v2, 0x3
.line 291
: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 292
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;->isLoadCanceled()Z
move-result v3
if-nez v3, :cond_3e
.line 293
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_30
.catch Ljava/io/IOException; {:try_start_4 .. :try_end_30} :catch_82
.catch Ljava/lang/InterruptedException; {:try_start_4 .. :try_end_30} :catch_70
.catch Ljava/lang/Exception; {:try_start_4 .. :try_end_30} :catch_59
.catch Ljava/lang/Error; {:try_start_4 .. :try_end_30} :catch_46
.line 295
:try_start_30
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_35
.catchall {:try_start_30 .. :try_end_35} :catchall_39
.line 297
:try_start_35
invoke-static {}, Lcom/google/android/exoplayer2/util/TraceUtil;->endSection()V
goto :goto_3e
:catchall_39
move-exception v3
invoke-static {}, Lcom/google/android/exoplayer2/util/TraceUtil;->endSection()V
throw v3
.line 300
:cond_3e
:goto_3e
iget-boolean v3, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->released:Z
if-nez v3, :cond_8e
.line 301
invoke-virtual {p0, v1}, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->sendEmptyMessage(I)Z
:try_end_45
.catch Ljava/io/IOException; {:try_start_35 .. :try_end_45} :catch_82
.catch Ljava/lang/InterruptedException; {:try_start_35 .. :try_end_45} :catch_70
.catch Ljava/lang/Exception; {:try_start_35 .. :try_end_45} :catch_59
.catch Ljava/lang/Error; {:try_start_35 .. :try_end_45} :catch_46
goto :goto_8e
:catch_46
move-exception v1
const-string v2, "Unexpected error loading stream"
.line 323
invoke-static {v0, v2, v1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
.line 324
iget-boolean v0, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->released:Z
if-nez v0, :cond_58
const/4 v0, 0x4
.line 325
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 327
:cond_58
throw v1
:catch_59
move-exception v1
const-string v3, "Unexpected exception loading stream"
.line 315
invoke-static {v0, v3, v1}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
.line 316
iget-boolean v0, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->released:Z
if-nez v0, :cond_8e
.line 317
new-instance v0, Lcom/google/android/exoplayer2/upstream/Loader$UnexpectedLoaderException;
invoke-direct {v0, v1}, Lcom/google/android/exoplayer2/upstream/Loader$UnexpectedLoaderException;-><init>(Ljava/lang/Exception;)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_8e
:catch_70
nop
.line 309
iget-object v0, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->loadable:Lcom/google/android/exoplayer2/upstream/Loader$Loadable;
invoke-interface {v0}, Lcom/google/android/exoplayer2/upstream/Loader$Loadable;->isLoadCanceled()Z
move-result v0
invoke-static {v0}, Lcom/google/android/exoplayer2/util/Assertions;->checkState(Z)V
.line 310
iget-boolean v0, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->released:Z
if-nez v0, :cond_8e
.line 311
invoke-virtual {p0, v1}, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->sendEmptyMessage(I)Z
goto :goto_8e
:catch_82
move-exception v0
.line 304
iget-boolean v1, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->released:Z
if-nez v1, :cond_8e
.line 305
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
:cond_8e
:goto_8e
return-void
.end method
.method public start(J)V
.registers 7
.line 258
iget-object v0, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->this$0:Lcom/google/android/exoplayer2/upstream/Loader;
# getter for: Lcom/google/android/exoplayer2/upstream/Loader;->currentTask:Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;
invoke-static {v0}, Lcom/google/android/exoplayer2/upstream/Loader;->access$000(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 259
iget-object v0, p0, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->this$0:Lcom/google/android/exoplayer2/upstream/Loader;
# setter for: Lcom/google/android/exoplayer2/upstream/Loader;->currentTask:Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;
invoke-static {v0, p0}, Lcom/google/android/exoplayer2/upstream/Loader;->access$002(Lcom/google/android/exoplayer2/upstream/Loader;Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;)Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;
const-wide/16 v2, 0x0
cmp-long v0, p1, v2
if-lez v0, :cond_1e
.line 261
invoke-virtual {p0, v1, p1, p2}, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->sendEmptyMessageDelayed(IJ)Z
goto :goto_21
.line 263
:cond_1e
invoke-direct {p0}, Lcom/google/android/exoplayer2/upstream/Loader$LoadTask;->submitToExecutor()V
:goto_21
return-void
.end method