JobConsumerExecutor$JobConsumer.smali
.class Lcom/path/android/jobqueue/executor/JobConsumerExecutor$JobConsumer;
.super Ljava/lang/Object;
.source "SourceFile"
# interfaces
.implements Ljava/lang/Runnable;
# annotations
.annotation system Ldalvik/annotation/EnclosingClass;
value = Lcom/path/android/jobqueue/executor/JobConsumerExecutor;
.end annotation
.annotation system Ldalvik/annotation/InnerClass;
accessFlags = 0x9
name = "JobConsumer"
.end annotation
# instance fields
.field private final contract:Lcom/path/android/jobqueue/executor/JobConsumerExecutor$Contract;
.field private didRunOnce:Z
.field private final executor:Lcom/path/android/jobqueue/executor/JobConsumerExecutor;
# direct methods
.method public constructor <init>(Lcom/path/android/jobqueue/executor/JobConsumerExecutor$Contract;Lcom/path/android/jobqueue/executor/JobConsumerExecutor;)V
.registers 4
.line 1
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
const/4 v0, 0x0
.line 2
iput-boolean v0, p0, Lcom/path/android/jobqueue/executor/JobConsumerExecutor$JobConsumer;->didRunOnce:Z
.line 3
iput-object p2, p0, Lcom/path/android/jobqueue/executor/JobConsumerExecutor$JobConsumer;->executor:Lcom/path/android/jobqueue/executor/JobConsumerExecutor;
.line 4
iput-object p1, p0, Lcom/path/android/jobqueue/executor/JobConsumerExecutor$JobConsumer;->contract:Lcom/path/android/jobqueue/executor/JobConsumerExecutor$Contract;
return-void
.end method
# virtual methods
.method public run()V
.registers 12
const-string v0, "finishing consumer %s"
const-string v1, "didn\'t allow me to die, re-running %s"
invoke-static {}, Landroid/os/Looper;->getMainLooper()Landroid/os/Looper;
move-result-object v2
invoke-static {}, Landroid/os/Looper;->myLooper()Landroid/os/Looper;
move-result-object v3
const/4 v4, 0x0
const/4 v5, 0x1
if-ne v2, v3, :cond_12
const/4 v2, 0x1
goto :goto_13
:cond_12
const/4 v2, 0x0
:goto_13
const-string v3, "runnable"
const-string v6, "com/path/android/jobqueue/executor/JobConsumerExecutor$JobConsumer"
const-string v7, "run"
if-eqz v2, :cond_1e
invoke-static {v7, v6, v3}, Lcom/shopee/monitor/trace/c;->a(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
.line 1
:cond_1e
:try_start_1e
invoke-static {}, Lcom/path/android/jobqueue/log/JqLog;->isDebugEnabled()Z
move-result v8
if-eqz v8, :cond_4d
.line 2
iget-boolean v8, p0, Lcom/path/android/jobqueue/executor/JobConsumerExecutor$JobConsumer;->didRunOnce:Z
if-nez v8, :cond_3c
const-string v8, "starting consumer %s"
new-array v9, v5, [Ljava/lang/Object;
.line 3
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object v10
invoke-virtual {v10}, Ljava/lang/Thread;->getName()Ljava/lang/String;
move-result-object v10
aput-object v10, v9, v4
invoke-static {v8, v9}, Lcom/path/android/jobqueue/log/JqLog;->d(Ljava/lang/String;[Ljava/lang/Object;)V
.line 4
iput-boolean v5, p0, Lcom/path/android/jobqueue/executor/JobConsumerExecutor$JobConsumer;->didRunOnce:Z
goto :goto_4d
:cond_3c
const-string v8, "re-running consumer %s"
new-array v9, v5, [Ljava/lang/Object;
.line 5
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object v10
invoke-virtual {v10}, Ljava/lang/Thread;->getName()Ljava/lang/String;
move-result-object v10
aput-object v10, v9, v4
invoke-static {v8, v9}, Lcom/path/android/jobqueue/log/JqLog;->d(Ljava/lang/String;[Ljava/lang/Object;)V
.line 6
:cond_4d
:goto_4d
iget-object v8, p0, Lcom/path/android/jobqueue/executor/JobConsumerExecutor$JobConsumer;->contract:Lcom/path/android/jobqueue/executor/JobConsumerExecutor$Contract;
invoke-interface {v8}, Lcom/path/android/jobqueue/executor/JobConsumerExecutor$Contract;->isRunning()Z
move-result v8
if-eqz v8, :cond_64
iget-object v8, p0, Lcom/path/android/jobqueue/executor/JobConsumerExecutor$JobConsumer;->contract:Lcom/path/android/jobqueue/executor/JobConsumerExecutor$Contract;
iget-object v9, p0, Lcom/path/android/jobqueue/executor/JobConsumerExecutor$JobConsumer;->executor:Lcom/path/android/jobqueue/executor/JobConsumerExecutor;
# getter for: Lcom/path/android/jobqueue/executor/JobConsumerExecutor;->keepAliveSeconds:I
invoke-static {v9}, Lcom/path/android/jobqueue/executor/JobConsumerExecutor;->access$000(Lcom/path/android/jobqueue/executor/JobConsumerExecutor;)I
move-result v9
sget-object v10, Ljava/util/concurrent/TimeUnit;->SECONDS:Ljava/util/concurrent/TimeUnit;
invoke-interface {v8, v9, v10}, Lcom/path/android/jobqueue/executor/JobConsumerExecutor$Contract;->getNextJob(ILjava/util/concurrent/TimeUnit;)Lcom/path/android/jobqueue/JobHolder;
move-result-object v8
goto :goto_65
:cond_64
const/4 v8, 0x0
:goto_65
if-eqz v8, :cond_a1
.line 7
iget-object v9, p0, Lcom/path/android/jobqueue/executor/JobConsumerExecutor$JobConsumer;->executor:Lcom/path/android/jobqueue/executor/JobConsumerExecutor;
# invokes: Lcom/path/android/jobqueue/executor/JobConsumerExecutor;->onBeforeRun(Lcom/path/android/jobqueue/JobHolder;)V
invoke-static {v9, v8}, Lcom/path/android/jobqueue/executor/JobConsumerExecutor;->access$100(Lcom/path/android/jobqueue/executor/JobConsumerExecutor;Lcom/path/android/jobqueue/JobHolder;)V
.line 8
invoke-virtual {v8}, Lcom/path/android/jobqueue/JobHolder;->getRunCount()I
move-result v9
invoke-virtual {v8, v9}, Lcom/path/android/jobqueue/JobHolder;->safeRun(I)I
move-result v9
if-eq v9, v5, :cond_94
const/4 v10, 0x2
if-eq v9, v10, :cond_8e
const/4 v10, 0x3
if-eq v9, v10, :cond_86
const/4 v10, 0x4
if-eq v9, v10, :cond_80
goto :goto_9c
.line 9
:cond_80
iget-object v9, p0, Lcom/path/android/jobqueue/executor/JobConsumerExecutor$JobConsumer;->contract:Lcom/path/android/jobqueue/executor/JobConsumerExecutor$Contract;
invoke-interface {v9, v8}, Lcom/path/android/jobqueue/executor/JobConsumerExecutor$Contract;->insertOrReplace(Lcom/path/android/jobqueue/JobHolder;)V
goto :goto_9c
:cond_86
const-string v9, "running job failed and cancelled, doing nothing. Will be removed after it\'s onCancel is called by the JobManager"
new-array v10, v4, [Ljava/lang/Object;
.line 10
invoke-static {v9, v10}, Lcom/path/android/jobqueue/log/JqLog;->d(Ljava/lang/String;[Ljava/lang/Object;)V
goto :goto_9c
.line 11
:cond_8e
iget-object v9, p0, Lcom/path/android/jobqueue/executor/JobConsumerExecutor$JobConsumer;->contract:Lcom/path/android/jobqueue/executor/JobConsumerExecutor$Contract;
invoke-interface {v9, v8}, Lcom/path/android/jobqueue/executor/JobConsumerExecutor$Contract;->removeJob(Lcom/path/android/jobqueue/JobHolder;)V
goto :goto_9c
.line 12
:cond_94
invoke-virtual {v8}, Lcom/path/android/jobqueue/JobHolder;->markAsSuccessful()V
.line 13
iget-object v9, p0, Lcom/path/android/jobqueue/executor/JobConsumerExecutor$JobConsumer;->contract:Lcom/path/android/jobqueue/executor/JobConsumerExecutor$Contract;
invoke-interface {v9, v8}, Lcom/path/android/jobqueue/executor/JobConsumerExecutor$Contract;->removeJob(Lcom/path/android/jobqueue/JobHolder;)V
.line 14
:goto_9c
iget-object v9, p0, Lcom/path/android/jobqueue/executor/JobConsumerExecutor$JobConsumer;->executor:Lcom/path/android/jobqueue/executor/JobConsumerExecutor;
# invokes: Lcom/path/android/jobqueue/executor/JobConsumerExecutor;->onAfterRun(Lcom/path/android/jobqueue/JobHolder;)V
invoke-static {v9, v8}, Lcom/path/android/jobqueue/executor/JobConsumerExecutor;->access$200(Lcom/path/android/jobqueue/executor/JobConsumerExecutor;Lcom/path/android/jobqueue/JobHolder;)V
:try_end_a1
.catchall {:try_start_1e .. :try_end_a1} :catchall_d8
:cond_a1
if-nez v8, :cond_4d
.line 15
iget-object v8, p0, Lcom/path/android/jobqueue/executor/JobConsumerExecutor$JobConsumer;->executor:Lcom/path/android/jobqueue/executor/JobConsumerExecutor;
# invokes: Lcom/path/android/jobqueue/executor/JobConsumerExecutor;->canIDie()Z
invoke-static {v8}, Lcom/path/android/jobqueue/executor/JobConsumerExecutor;->access$300(Lcom/path/android/jobqueue/executor/JobConsumerExecutor;)Z
move-result v8
.line 16
invoke-static {}, Lcom/path/android/jobqueue/log/JqLog;->isDebugEnabled()Z
move-result v9
if-eqz v9, :cond_d0
if-eqz v8, :cond_c1
new-array v9, v5, [Ljava/lang/Object;
.line 17
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object v10
invoke-virtual {v10}, Ljava/lang/Thread;->getName()Ljava/lang/String;
move-result-object v10
aput-object v10, v9, v4
invoke-static {v0, v9}, Lcom/path/android/jobqueue/log/JqLog;->d(Ljava/lang/String;[Ljava/lang/Object;)V
goto :goto_d0
:cond_c1
new-array v9, v5, [Ljava/lang/Object;
.line 18
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object v10
invoke-virtual {v10}, Ljava/lang/Thread;->getName()Ljava/lang/String;
move-result-object v10
aput-object v10, v9, v4
invoke-static {v1, v9}, Lcom/path/android/jobqueue/log/JqLog;->d(Ljava/lang/String;[Ljava/lang/Object;)V
:cond_d0
:goto_d0
if-eqz v8, :cond_1e
if-eqz v2, :cond_d7
.line 19
invoke-static {v7, v6, v3}, Lcom/shopee/monitor/trace/c;->b(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
:cond_d7
return-void
:catchall_d8
move-exception v8
.line 20
iget-object v9, p0, Lcom/path/android/jobqueue/executor/JobConsumerExecutor$JobConsumer;->executor:Lcom/path/android/jobqueue/executor/JobConsumerExecutor;
# invokes: Lcom/path/android/jobqueue/executor/JobConsumerExecutor;->canIDie()Z
invoke-static {v9}, Lcom/path/android/jobqueue/executor/JobConsumerExecutor;->access$300(Lcom/path/android/jobqueue/executor/JobConsumerExecutor;)Z
move-result v9
.line 21
invoke-static {}, Lcom/path/android/jobqueue/log/JqLog;->isDebugEnabled()Z
move-result v10
if-eqz v10, :cond_106
if-eqz v9, :cond_f7
new-array v1, v5, [Ljava/lang/Object;
.line 22
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object v5
invoke-virtual {v5}, Ljava/lang/Thread;->getName()Ljava/lang/String;
move-result-object v5
aput-object v5, v1, v4
invoke-static {v0, v1}, Lcom/path/android/jobqueue/log/JqLog;->d(Ljava/lang/String;[Ljava/lang/Object;)V
goto :goto_106
:cond_f7
new-array v0, v5, [Ljava/lang/Object;
.line 23
invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;
move-result-object v5
invoke-virtual {v5}, Ljava/lang/Thread;->getName()Ljava/lang/String;
move-result-object v5
aput-object v5, v0, v4
invoke-static {v1, v0}, Lcom/path/android/jobqueue/log/JqLog;->d(Ljava/lang/String;[Ljava/lang/Object;)V
:cond_106
:goto_106
if-eqz v2, :cond_10b
invoke-static {v7, v6, v3}, Lcom/shopee/monitor/trace/c;->b(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V
:cond_10b
throw v8
.end method