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