JobManager.smali

.class public Lcom/path/android/jobqueue/JobManager;
.super Ljava/lang/Object;
.source "SourceFile"

# interfaces
.implements Lcom/path/android/jobqueue/network/NetworkEventProvider$Listener;


# annotations
.annotation system Ldalvik/annotation/MemberClasses;
    value = {
        Lcom/path/android/jobqueue/JobManager$DefaultQueueFactory;
    }
.end annotation


# static fields
.field public static final NOT_DELAYED_JOB_DELAY:J = -0x8000000000000000L

.field public static final NOT_RUNNING_SESSION_ID:J = -0x8000000000000000L

.field public static final NS_PER_MS:J = 0xf4240L


# instance fields
.field private final appContext:Landroid/content/Context;

.field private cancelExecutor:Ljava/util/concurrent/Executor;

.field private final cancelExecutorInitLock:Ljava/lang/Object;

.field private final consumerContract:Lcom/path/android/jobqueue/executor/JobConsumerExecutor$Contract;

.field private final dependencyInjector:Lcom/path/android/jobqueue/di/DependencyInjector;

.field private final getNextJobLock:Ljava/lang/Object;

.field private final jobConsumerExecutor:Lcom/path/android/jobqueue/executor/JobConsumerExecutor;

.field private final networkUtil:Lcom/path/android/jobqueue/network/NetworkUtil;

.field private final newJobListeners:Ljava/lang/Object;

.field private final nonPersistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

.field private final nonPersistentOnAddedLocks:Ljava/util/concurrent/ConcurrentHashMap;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/concurrent/ConcurrentHashMap<",
            "Ljava/lang/Long;",
            "Ljava/util/concurrent/CountDownLatch;",
            ">;"
        }
    .end annotation
.end field

.field private final notifyRunnable:Ljava/lang/Runnable;

.field private final persistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

.field private final persistentOnAddedLocks:Ljava/util/concurrent/ConcurrentHashMap;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/concurrent/ConcurrentHashMap<",
            "Ljava/lang/Long;",
            "Ljava/util/concurrent/CountDownLatch;",
            ">;"
        }
    .end annotation
.end field

.field private volatile running:Z

.field private final runningJobGroups:Lcom/path/android/jobqueue/RunningJobSet;

.field private final sessionId:J

.field private timedExecutor:Ljava/util/concurrent/ScheduledExecutorService;


# direct methods
.method public constructor <init>(Landroid/content/Context;)V
    .registers 3

    const-string v0, "default"

    .line 1
    invoke-direct {p0, p1, v0}, Lcom/path/android/jobqueue/JobManager;-><init>(Landroid/content/Context;Ljava/lang/String;)V

    return-void
.end method

.method public constructor <init>(Landroid/content/Context;Lcom/path/android/jobqueue/config/Configuration;)V
    .registers 10

    .line 3
    invoke-direct {p0}, Ljava/lang/Object;-><init>()V

    .line 4
    new-instance v0, Ljava/lang/Object;

    invoke-direct {v0}, Ljava/lang/Object;-><init>()V

    iput-object v0, p0, Lcom/path/android/jobqueue/JobManager;->newJobListeners:Ljava/lang/Object;

    .line 5
    new-instance v0, Ljava/lang/Object;

    invoke-direct {v0}, Ljava/lang/Object;-><init>()V

    iput-object v0, p0, Lcom/path/android/jobqueue/JobManager;->cancelExecutorInitLock:Ljava/lang/Object;

    .line 6
    new-instance v0, Ljava/lang/Object;

    invoke-direct {v0}, Ljava/lang/Object;-><init>()V

    iput-object v0, p0, Lcom/path/android/jobqueue/JobManager;->getNextJobLock:Ljava/lang/Object;

    .line 7
    new-instance v0, Lcom/path/android/jobqueue/JobManager$4;

    invoke-direct {v0, p0}, Lcom/path/android/jobqueue/JobManager$4;-><init>(Lcom/path/android/jobqueue/JobManager;)V

    iput-object v0, p0, Lcom/path/android/jobqueue/JobManager;->notifyRunnable:Ljava/lang/Runnable;

    .line 8
    new-instance v0, Lcom/path/android/jobqueue/JobManager$5;

    invoke-direct {v0, p0}, Lcom/path/android/jobqueue/JobManager$5;-><init>(Lcom/path/android/jobqueue/JobManager;)V

    iput-object v0, p0, Lcom/path/android/jobqueue/JobManager;->consumerContract:Lcom/path/android/jobqueue/executor/JobConsumerExecutor$Contract;

    .line 9
    invoke-virtual {p2}, Lcom/path/android/jobqueue/config/Configuration;->getCustomLogger()Lcom/path/android/jobqueue/log/CustomLogger;

    move-result-object v1

    if-eqz v1, :cond_33

    .line 10
    invoke-virtual {p2}, Lcom/path/android/jobqueue/config/Configuration;->getCustomLogger()Lcom/path/android/jobqueue/log/CustomLogger;

    move-result-object v1

    invoke-static {v1}, Lcom/path/android/jobqueue/log/JqLog;->setCustomLogger(Lcom/path/android/jobqueue/log/CustomLogger;)V

    .line 11
    :cond_33
    invoke-virtual {p1}, Landroid/content/Context;->getApplicationContext()Landroid/content/Context;

    move-result-object v1

    iput-object v1, p0, Lcom/path/android/jobqueue/JobManager;->appContext:Landroid/content/Context;

    const/4 v1, 0x1

    .line 12
    iput-boolean v1, p0, Lcom/path/android/jobqueue/JobManager;->running:Z

    .line 13
    new-instance v1, Lcom/path/android/jobqueue/RunningJobSet;

    invoke-direct {v1}, Lcom/path/android/jobqueue/RunningJobSet;-><init>()V

    iput-object v1, p0, Lcom/path/android/jobqueue/JobManager;->runningJobGroups:Lcom/path/android/jobqueue/RunningJobSet;

    .line 14
    invoke-static {}, Ljava/lang/System;->nanoTime()J

    move-result-wide v1

    iput-wide v1, p0, Lcom/path/android/jobqueue/JobManager;->sessionId:J

    .line 15
    invoke-virtual {p2}, Lcom/path/android/jobqueue/config/Configuration;->getQueueFactory()Lcom/path/android/jobqueue/QueueFactory;

    move-result-object v3

    invoke-static {v1, v2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;

    move-result-object v4

    invoke-virtual {p2}, Lcom/path/android/jobqueue/config/Configuration;->getId()Ljava/lang/String;

    move-result-object v5

    invoke-virtual {p2}, Lcom/path/android/jobqueue/config/Configuration;->isInTestMode()Z

    move-result v6

    invoke-interface {v3, p1, v4, v5, v6}, Lcom/path/android/jobqueue/QueueFactory;->createPersistentQueue(Landroid/content/Context;Ljava/lang/Long;Ljava/lang/String;Z)Lcom/path/android/jobqueue/JobQueue;

    move-result-object v3

    iput-object v3, p0, Lcom/path/android/jobqueue/JobManager;->persistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    .line 16
    invoke-virtual {p2}, Lcom/path/android/jobqueue/config/Configuration;->getQueueFactory()Lcom/path/android/jobqueue/QueueFactory;

    move-result-object v3

    invoke-static {v1, v2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;

    move-result-object v1

    invoke-virtual {p2}, Lcom/path/android/jobqueue/config/Configuration;->getId()Ljava/lang/String;

    move-result-object v2

    invoke-virtual {p2}, Lcom/path/android/jobqueue/config/Configuration;->isInTestMode()Z

    move-result v4

    invoke-interface {v3, p1, v1, v2, v4}, Lcom/path/android/jobqueue/QueueFactory;->createNonPersistent(Landroid/content/Context;Ljava/lang/Long;Ljava/lang/String;Z)Lcom/path/android/jobqueue/JobQueue;

    move-result-object p1

    iput-object p1, p0, Lcom/path/android/jobqueue/JobManager;->nonPersistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    .line 17
    new-instance p1, Ljava/util/concurrent/ConcurrentHashMap;

    invoke-direct {p1}, Ljava/util/concurrent/ConcurrentHashMap;-><init>()V

    iput-object p1, p0, Lcom/path/android/jobqueue/JobManager;->persistentOnAddedLocks:Ljava/util/concurrent/ConcurrentHashMap;

    .line 18
    new-instance p1, Ljava/util/concurrent/ConcurrentHashMap;

    invoke-direct {p1}, Ljava/util/concurrent/ConcurrentHashMap;-><init>()V

    iput-object p1, p0, Lcom/path/android/jobqueue/JobManager;->nonPersistentOnAddedLocks:Ljava/util/concurrent/ConcurrentHashMap;

    .line 19
    invoke-virtual {p2}, Lcom/path/android/jobqueue/config/Configuration;->getNetworkUtil()Lcom/path/android/jobqueue/network/NetworkUtil;

    move-result-object p1

    iput-object p1, p0, Lcom/path/android/jobqueue/JobManager;->networkUtil:Lcom/path/android/jobqueue/network/NetworkUtil;

    .line 20
    invoke-virtual {p2}, Lcom/path/android/jobqueue/config/Configuration;->getDependencyInjector()Lcom/path/android/jobqueue/di/DependencyInjector;

    move-result-object v1

    iput-object v1, p0, Lcom/path/android/jobqueue/JobManager;->dependencyInjector:Lcom/path/android/jobqueue/di/DependencyInjector;

    .line 21
    instance-of v1, p1, Lcom/path/android/jobqueue/network/NetworkEventProvider;

    if-eqz v1, :cond_98

    .line 22
    check-cast p1, Lcom/path/android/jobqueue/network/NetworkEventProvider;

    invoke-interface {p1, p0}, Lcom/path/android/jobqueue/network/NetworkEventProvider;->setListener(Lcom/path/android/jobqueue/network/NetworkEventProvider$Listener;)V

    .line 23
    :cond_98
    new-instance p1, Lcom/path/android/jobqueue/executor/JobConsumerExecutor;

    invoke-direct {p1, p2, v0}, Lcom/path/android/jobqueue/executor/JobConsumerExecutor;-><init>(Lcom/path/android/jobqueue/config/Configuration;Lcom/path/android/jobqueue/executor/JobConsumerExecutor$Contract;)V

    iput-object p1, p0, Lcom/path/android/jobqueue/JobManager;->jobConsumerExecutor:Lcom/path/android/jobqueue/executor/JobConsumerExecutor;

    .line 24
    invoke-static {}, Ljava/util/concurrent/Executors;->newSingleThreadScheduledExecutor()Ljava/util/concurrent/ScheduledExecutorService;

    move-result-object p1

    iput-object p1, p0, Lcom/path/android/jobqueue/JobManager;->timedExecutor:Ljava/util/concurrent/ScheduledExecutorService;

    .line 25
    invoke-virtual {p0}, Lcom/path/android/jobqueue/JobManager;->start()V

    return-void
.end method

.method public constructor <init>(Landroid/content/Context;Ljava/lang/String;)V
    .registers 4

    .line 2
    new-instance v0, Lcom/path/android/jobqueue/config/Configuration$Builder;

    invoke-direct {v0, p1}, Lcom/path/android/jobqueue/config/Configuration$Builder;-><init>(Landroid/content/Context;)V

    invoke-virtual {v0, p2}, Lcom/path/android/jobqueue/config/Configuration$Builder;->id(Ljava/lang/String;)Lcom/path/android/jobqueue/config/Configuration$Builder;

    move-result-object p2

    invoke-virtual {p2}, Lcom/path/android/jobqueue/config/Configuration$Builder;->build()Lcom/path/android/jobqueue/config/Configuration;

    move-result-object p2

    invoke-direct {p0, p1, p2}, Lcom/path/android/jobqueue/JobManager;-><init>(Landroid/content/Context;Lcom/path/android/jobqueue/config/Configuration;)V

    return-void
.end method

.method public static INVOKEINTERFACE_com_path_android_jobqueue_JobManager_com_shopee_app_asm_anr_threadpool_ExecutorProxy_execute(Ljava/util/concurrent/Executor;Ljava/lang/Runnable;)V
    .registers 4

    .line 1
    invoke-static {}, Lcom/shopee/app/asm/anr/threadpool/c;->b()Z

    move-result v0

    if-eqz v0, :cond_3a

    invoke-static {}, Lcom/shopee/app/asm/anr/threadpool/c;->a()Z

    move-result v0

    if-eqz v0, :cond_3a

    .line 2
    :try_start_c
    sget-object v0, Lcom/shopee/app/asm/anr/threadpool/c;->a:Landroid/os/HandlerThread;

    .line 3
    sget-object v0, Lcom/shopee/app/asm/anr/threadpool/c;->b:Landroid/os/Handler;

    new-instance v1, Lcom/shopee/app/asm/anr/threadpool/a$b;

    invoke-direct {v1, p0, p1}, Lcom/shopee/app/asm/anr/threadpool/a$b;-><init>(Ljava/util/concurrent/Executor;Ljava/lang/Runnable;)V

    invoke-virtual {v0, v1}, Landroid/os/Handler;->post(Ljava/lang/Runnable;)Z
    :try_end_18
    .catchall {:try_start_c .. :try_end_18} :catchall_19

    goto :goto_54

    :catchall_19
    move-exception v0

    .line 4
    invoke-virtual {v0}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;

    sget-object v0, Lcom/shopee/app/asm/anr/threadpool/c;->a:Landroid/os/HandlerThread;

    .line 5
    :try_start_1f
    invoke-static {p1, p0}, Lcom/shopee/app/asm/anr/threadpool/a;->a(Ljava/lang/Object;Ljava/lang/Object;)Z

    move-result v0

    if-eqz v0, :cond_2b

    .line 6
    sget-object p0, Lcom/shopee/app/asm/fix/threadpool/global/i;->e:Lcom/shopee/app/asm/fix/threadpool/global/j;

    .line 7
    invoke-virtual {p0, p1}, Lcom/shopee/app/asm/anr/threadpool/b;->execute(Ljava/lang/Runnable;)V

    return-void

    .line 8
    :cond_2b
    invoke-interface {p0, p1}, Ljava/util/concurrent/Executor;->execute(Ljava/lang/Runnable;)V
    :try_end_2e
    .catchall {:try_start_1f .. :try_end_2e} :catchall_2f

    goto :goto_54

    :catchall_2f
    move-exception p0

    .line 9
    sget-object p1, Lcom/shopee/app/asm/anr/threadpool/c;->a:Landroid/os/HandlerThread;

    .line 10
    invoke-static {}, Lcom/shopee/app/apm/c;->d()Lcom/shopee/app/apm/nonfatal/a;

    move-result-object p1

    invoke-virtual {p1, p0}, Lcom/shopee/app/apm/nonfatal/a;->c(Ljava/lang/Throwable;)V

    goto :goto_54

    .line 11
    :cond_3a
    :try_start_3a
    invoke-static {p1, p0}, Lcom/shopee/app/asm/anr/threadpool/a;->a(Ljava/lang/Object;Ljava/lang/Object;)Z

    move-result v0

    if-eqz v0, :cond_46

    .line 12
    sget-object p0, Lcom/shopee/app/asm/fix/threadpool/global/i;->e:Lcom/shopee/app/asm/fix/threadpool/global/j;

    .line 13
    invoke-virtual {p0, p1}, Lcom/shopee/app/asm/anr/threadpool/b;->execute(Ljava/lang/Runnable;)V

    return-void

    .line 14
    :cond_46
    invoke-interface {p0, p1}, Ljava/util/concurrent/Executor;->execute(Ljava/lang/Runnable;)V
    :try_end_49
    .catchall {:try_start_3a .. :try_end_49} :catchall_4a

    goto :goto_54

    :catchall_4a
    move-exception p0

    .line 15
    sget-object p1, Lcom/shopee/app/asm/anr/threadpool/c;->a:Landroid/os/HandlerThread;

    .line 16
    invoke-static {}, Lcom/shopee/app/apm/c;->d()Lcom/shopee/app/apm/nonfatal/a;

    move-result-object p1

    invoke-virtual {p1, p0}, Lcom/shopee/app/apm/nonfatal/a;->c(Ljava/lang/Throwable;)V

    :goto_54
    return-void
.end method

.method public static INVOKEINTERFACE_com_path_android_jobqueue_JobManager_com_shopee_app_asm_anr_threadpool_ExecutorProxy_execute(Ljava/util/concurrent/ScheduledExecutorService;Ljava/lang/Runnable;)V
    .registers 4

    .line 17
    invoke-static {}, Lcom/shopee/app/asm/anr/threadpool/c;->b()Z

    move-result v0

    if-eqz v0, :cond_3a

    invoke-static {}, Lcom/shopee/app/asm/anr/threadpool/c;->a()Z

    move-result v0

    if-eqz v0, :cond_3a

    .line 18
    :try_start_c
    sget-object v0, Lcom/shopee/app/asm/anr/threadpool/c;->a:Landroid/os/HandlerThread;

    .line 19
    sget-object v0, Lcom/shopee/app/asm/anr/threadpool/c;->b:Landroid/os/Handler;

    new-instance v1, Lcom/shopee/app/asm/anr/threadpool/a$b;

    invoke-direct {v1, p0, p1}, Lcom/shopee/app/asm/anr/threadpool/a$b;-><init>(Ljava/util/concurrent/Executor;Ljava/lang/Runnable;)V

    invoke-virtual {v0, v1}, Landroid/os/Handler;->post(Ljava/lang/Runnable;)Z
    :try_end_18
    .catchall {:try_start_c .. :try_end_18} :catchall_19

    goto :goto_54

    :catchall_19
    move-exception v0

    .line 20
    invoke-virtual {v0}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;

    sget-object v0, Lcom/shopee/app/asm/anr/threadpool/c;->a:Landroid/os/HandlerThread;

    .line 21
    :try_start_1f
    invoke-static {p1, p0}, Lcom/shopee/app/asm/anr/threadpool/a;->a(Ljava/lang/Object;Ljava/lang/Object;)Z

    move-result v0

    if-eqz v0, :cond_2b

    .line 22
    sget-object p0, Lcom/shopee/app/asm/fix/threadpool/global/i;->e:Lcom/shopee/app/asm/fix/threadpool/global/j;

    .line 23
    invoke-virtual {p0, p1}, Lcom/shopee/app/asm/anr/threadpool/b;->execute(Ljava/lang/Runnable;)V

    return-void

    .line 24
    :cond_2b
    invoke-interface {p0, p1}, Ljava/util/concurrent/Executor;->execute(Ljava/lang/Runnable;)V
    :try_end_2e
    .catchall {:try_start_1f .. :try_end_2e} :catchall_2f

    goto :goto_54

    :catchall_2f
    move-exception p0

    .line 25
    sget-object p1, Lcom/shopee/app/asm/anr/threadpool/c;->a:Landroid/os/HandlerThread;

    .line 26
    invoke-static {}, Lcom/shopee/app/apm/c;->d()Lcom/shopee/app/apm/nonfatal/a;

    move-result-object p1

    invoke-virtual {p1, p0}, Lcom/shopee/app/apm/nonfatal/a;->c(Ljava/lang/Throwable;)V

    goto :goto_54

    .line 27
    :cond_3a
    :try_start_3a
    invoke-static {p1, p0}, Lcom/shopee/app/asm/anr/threadpool/a;->a(Ljava/lang/Object;Ljava/lang/Object;)Z

    move-result v0

    if-eqz v0, :cond_46

    .line 28
    sget-object p0, Lcom/shopee/app/asm/fix/threadpool/global/i;->e:Lcom/shopee/app/asm/fix/threadpool/global/j;

    .line 29
    invoke-virtual {p0, p1}, Lcom/shopee/app/asm/anr/threadpool/b;->execute(Ljava/lang/Runnable;)V

    return-void

    .line 30
    :cond_46
    invoke-interface {p0, p1}, Ljava/util/concurrent/Executor;->execute(Ljava/lang/Runnable;)V
    :try_end_49
    .catchall {:try_start_3a .. :try_end_49} :catchall_4a

    goto :goto_54

    :catchall_4a
    move-exception p0

    .line 31
    sget-object p1, Lcom/shopee/app/asm/anr/threadpool/c;->a:Landroid/os/HandlerThread;

    .line 32
    invoke-static {}, Lcom/shopee/app/apm/c;->d()Lcom/shopee/app/apm/nonfatal/a;

    move-result-object p1

    invoke-virtual {p1, p0}, Lcom/shopee/app/apm/nonfatal/a;->c(Ljava/lang/Throwable;)V

    :goto_54
    return-void
.end method

.method public static synthetic access$000(Lcom/path/android/jobqueue/JobManager;)Lcom/path/android/jobqueue/executor/JobConsumerExecutor;
    .registers 1

    iget-object p0, p0, Lcom/path/android/jobqueue/JobManager;->jobConsumerExecutor:Lcom/path/android/jobqueue/executor/JobConsumerExecutor;

    return-object p0
.end method

.method public static synthetic access$100(Lcom/path/android/jobqueue/JobManager;)Lcom/path/android/jobqueue/JobQueue;
    .registers 1

    iget-object p0, p0, Lcom/path/android/jobqueue/JobManager;->nonPersistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    return-object p0
.end method

.method public static synthetic access$1000(Lcom/path/android/jobqueue/JobManager;Ljava/lang/Boolean;)J
    .registers 2

    invoke-direct {p0, p1}, Lcom/path/android/jobqueue/JobManager;->ensureConsumerWhenNeeded(Ljava/lang/Boolean;)J

    move-result-wide p0

    return-wide p0
.end method

.method public static synthetic access$1100(Lcom/path/android/jobqueue/JobManager;)Lcom/path/android/jobqueue/network/NetworkUtil;
    .registers 1

    iget-object p0, p0, Lcom/path/android/jobqueue/JobManager;->networkUtil:Lcom/path/android/jobqueue/network/NetworkUtil;

    return-object p0
.end method

.method public static synthetic access$1200(Lcom/path/android/jobqueue/JobManager;)Ljava/lang/Object;
    .registers 1

    iget-object p0, p0, Lcom/path/android/jobqueue/JobManager;->newJobListeners:Ljava/lang/Object;

    return-object p0
.end method

.method public static synthetic access$1300(Lcom/path/android/jobqueue/JobManager;)Z
    .registers 1

    invoke-direct {p0}, Lcom/path/android/jobqueue/JobManager;->hasNetwork()Z

    move-result p0

    return p0
.end method

.method public static synthetic access$1400(Lcom/path/android/jobqueue/JobManager;Z)I
    .registers 2

    invoke-direct {p0, p1}, Lcom/path/android/jobqueue/JobManager;->countReadyJobs(Z)I

    move-result p0

    return p0
.end method

.method public static synthetic access$200(Lcom/path/android/jobqueue/JobManager;Ljava/util/Set;Lcom/path/android/jobqueue/JobQueue;Ljava/util/Set;)V
    .registers 4

    invoke-direct {p0, p1, p2, p3}, Lcom/path/android/jobqueue/JobManager;->markJobsAsCancelledAndFilterAlreadyCancelled(Ljava/util/Set;Lcom/path/android/jobqueue/JobQueue;Ljava/util/Set;)V

    return-void
.end method

.method public static synthetic access$300(Lcom/path/android/jobqueue/JobManager;)Lcom/path/android/jobqueue/JobQueue;
    .registers 1

    iget-object p0, p0, Lcom/path/android/jobqueue/JobManager;->persistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    return-object p0
.end method

.method public static synthetic access$400(Lcom/path/android/jobqueue/JobManager;)V
    .registers 1

    invoke-direct {p0}, Lcom/path/android/jobqueue/JobManager;->notifyJobConsumer()V

    return-void
.end method

.method public static synthetic access$500(Lcom/path/android/jobqueue/JobManager;)Z
    .registers 1

    iget-boolean p0, p0, Lcom/path/android/jobqueue/JobManager;->running:Z

    return p0
.end method

.method public static synthetic access$600(Lcom/path/android/jobqueue/JobManager;Lcom/path/android/jobqueue/JobHolder;)V
    .registers 2

    invoke-direct {p0, p1}, Lcom/path/android/jobqueue/JobManager;->reAddJob(Lcom/path/android/jobqueue/JobHolder;)V

    return-void
.end method

.method public static synthetic access$700(Lcom/path/android/jobqueue/JobManager;)Lcom/path/android/jobqueue/RunningJobSet;
    .registers 1

    iget-object p0, p0, Lcom/path/android/jobqueue/JobManager;->runningJobGroups:Lcom/path/android/jobqueue/RunningJobSet;

    return-object p0
.end method

.method public static synthetic access$800(Lcom/path/android/jobqueue/JobManager;Lcom/path/android/jobqueue/JobHolder;)V
    .registers 2

    invoke-direct {p0, p1}, Lcom/path/android/jobqueue/JobManager;->removeJob(Lcom/path/android/jobqueue/JobHolder;)V

    return-void
.end method

.method public static synthetic access$900(Lcom/path/android/jobqueue/JobManager;)Lcom/path/android/jobqueue/JobHolder;
    .registers 1

    invoke-direct {p0}, Lcom/path/android/jobqueue/JobManager;->getNextJob()Lcom/path/android/jobqueue/JobHolder;

    move-result-object p0

    return-object p0
.end method

.method private addOnAddedLock(Ljava/util/concurrent/ConcurrentHashMap;J)V
    .registers 5
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "(",
            "Ljava/util/concurrent/ConcurrentHashMap<",
            "Ljava/lang/Long;",
            "Ljava/util/concurrent/CountDownLatch;",
            ">;J)V"
        }
    .end annotation

    invoke-static {p2, p3}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;

    move-result-object p2

    new-instance p3, Ljava/util/concurrent/CountDownLatch;

    const/4 v0, 0x1

    invoke-direct {p3, v0}, Ljava/util/concurrent/CountDownLatch;-><init>(I)V

    invoke-virtual {p1, p2, p3}, Ljava/util/concurrent/ConcurrentHashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    return-void
.end method

.method private clearOnAddedLock(Ljava/util/concurrent/ConcurrentHashMap;J)V
    .registers 5
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "(",
            "Ljava/util/concurrent/ConcurrentHashMap<",
            "Ljava/lang/Long;",
            "Ljava/util/concurrent/CountDownLatch;",
            ">;J)V"
        }
    .end annotation

    .line 1
    invoke-static {p2, p3}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;

    move-result-object v0

    invoke-virtual {p1, v0}, Ljava/util/concurrent/ConcurrentHashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Ljava/util/concurrent/CountDownLatch;

    if-eqz v0, :cond_f

    .line 2
    invoke-virtual {v0}, Ljava/util/concurrent/CountDownLatch;->countDown()V

    .line 3
    :cond_f
    invoke-static {p2, p3}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;

    move-result-object p2

    invoke-virtual {p1, p2}, Ljava/util/concurrent/ConcurrentHashMap;->remove(Ljava/lang/Object;)Ljava/lang/Object;

    return-void
.end method

.method private countReadyJobs(Z)I
    .registers 6

    .line 1
    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->nonPersistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    monitor-enter v0

    .line 2
    :try_start_3
    iget-object v1, p0, Lcom/path/android/jobqueue/JobManager;->nonPersistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    iget-object v2, p0, Lcom/path/android/jobqueue/JobManager;->runningJobGroups:Lcom/path/android/jobqueue/RunningJobSet;

    invoke-virtual {v2}, Lcom/path/android/jobqueue/RunningJobSet;->getSafe()Ljava/util/Collection;

    move-result-object v2

    invoke-interface {v1, p1, v2}, Lcom/path/android/jobqueue/JobQueue;->countReadyJobs(ZLjava/util/Collection;)I

    move-result v1

    add-int/lit8 v1, v1, 0x0

    .line 3
    monitor-exit v0
    :try_end_12
    .catchall {:try_start_3 .. :try_end_12} :catchall_27

    .line 4
    iget-object v2, p0, Lcom/path/android/jobqueue/JobManager;->persistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    monitor-enter v2

    .line 5
    :try_start_15
    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->persistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    iget-object v3, p0, Lcom/path/android/jobqueue/JobManager;->runningJobGroups:Lcom/path/android/jobqueue/RunningJobSet;

    invoke-virtual {v3}, Lcom/path/android/jobqueue/RunningJobSet;->getSafe()Ljava/util/Collection;

    move-result-object v3

    invoke-interface {v0, p1, v3}, Lcom/path/android/jobqueue/JobQueue;->countReadyJobs(ZLjava/util/Collection;)I

    move-result p1

    add-int/2addr v1, p1

    .line 6
    monitor-exit v2

    return v1

    :catchall_24
    move-exception p1

    monitor-exit v2
    :try_end_26
    .catchall {:try_start_15 .. :try_end_26} :catchall_24

    throw p1

    :catchall_27
    move-exception p1

    .line 7
    :try_start_28
    monitor-exit v0
    :try_end_29
    .catchall {:try_start_28 .. :try_end_29} :catchall_27

    throw p1
.end method

.method private ensureConsumerOnTime(J)V
    .registers 6

    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->timedExecutor:Ljava/util/concurrent/ScheduledExecutorService;

    iget-object v1, p0, Lcom/path/android/jobqueue/JobManager;->notifyRunnable:Ljava/lang/Runnable;

    sget-object v2, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;

    invoke-interface {v0, v1, p1, p2, v2}, Ljava/util/concurrent/ScheduledExecutorService;->schedule(Ljava/lang/Runnable;JLjava/util/concurrent/TimeUnit;)Ljava/util/concurrent/ScheduledFuture;

    return-void
.end method

.method private ensureConsumerWhenNeeded(Ljava/lang/Boolean;)J
    .registers 11

    if-nez p1, :cond_12

    .line 1
    iget-object p1, p0, Lcom/path/android/jobqueue/JobManager;->networkUtil:Lcom/path/android/jobqueue/network/NetworkUtil;

    instance-of p1, p1, Lcom/path/android/jobqueue/network/NetworkEventProvider;

    if-eqz p1, :cond_d

    invoke-direct {p0}, Lcom/path/android/jobqueue/JobManager;->hasNetwork()Z

    move-result p1

    goto :goto_e

    :cond_d
    const/4 p1, 0x1

    :goto_e
    invoke-static {p1}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean;

    move-result-object p1

    .line 2
    :cond_12
    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->runningJobGroups:Lcom/path/android/jobqueue/RunningJobSet;

    invoke-virtual {v0}, Lcom/path/android/jobqueue/RunningJobSet;->getNextDelayForGroups()Ljava/lang/Long;

    move-result-object v0

    .line 3
    iget-object v1, p0, Lcom/path/android/jobqueue/JobManager;->runningJobGroups:Lcom/path/android/jobqueue/RunningJobSet;

    invoke-virtual {v1}, Lcom/path/android/jobqueue/RunningJobSet;->getSafe()Ljava/util/Collection;

    move-result-object v1

    .line 4
    iget-object v2, p0, Lcom/path/android/jobqueue/JobManager;->nonPersistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    monitor-enter v2

    .line 5
    :try_start_21
    iget-object v3, p0, Lcom/path/android/jobqueue/JobManager;->nonPersistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    invoke-virtual {p1}, Ljava/lang/Boolean;->booleanValue()Z

    move-result v4

    invoke-interface {v3, v4, v1}, Lcom/path/android/jobqueue/JobQueue;->getNextJobDelayUntilNs(ZLjava/util/Collection;)Ljava/lang/Long;

    move-result-object v3

    .line 6
    monitor-exit v2
    :try_end_2c
    .catchall {:try_start_21 .. :try_end_2c} :catchall_a5

    if-eqz v0, :cond_3c

    if-eqz v3, :cond_3d

    .line 7
    invoke-virtual {v3}, Ljava/lang/Long;->longValue()J

    move-result-wide v4

    invoke-virtual {v0}, Ljava/lang/Long;->longValue()J

    move-result-wide v6

    cmp-long v2, v4, v6

    if-gez v2, :cond_3d

    :cond_3c
    move-object v0, v3

    :cond_3d
    const-wide/16 v2, 0x0

    if-eqz v0, :cond_51

    .line 8
    invoke-virtual {v0}, Ljava/lang/Long;->longValue()J

    move-result-wide v4

    invoke-static {}, Ljava/lang/System;->nanoTime()J

    move-result-wide v6

    cmp-long v8, v4, v6

    if-gtz v8, :cond_51

    .line 9
    invoke-direct {p0}, Lcom/path/android/jobqueue/JobManager;->notifyJobConsumer()V

    return-wide v2

    .line 10
    :cond_51
    iget-object v4, p0, Lcom/path/android/jobqueue/JobManager;->persistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    monitor-enter v4

    .line 11
    :try_start_54
    iget-object v5, p0, Lcom/path/android/jobqueue/JobManager;->persistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    invoke-virtual {p1}, Ljava/lang/Boolean;->booleanValue()Z

    move-result p1

    invoke-interface {v5, p1, v1}, Lcom/path/android/jobqueue/JobQueue;->getNextJobDelayUntilNs(ZLjava/util/Collection;)Ljava/lang/Long;

    move-result-object p1

    .line 12
    monitor-exit v4
    :try_end_5f
    .catchall {:try_start_54 .. :try_end_5f} :catchall_a2

    if-eqz p1, :cond_71

    if-nez v0, :cond_64

    goto :goto_70

    .line 13
    :cond_64
    invoke-virtual {p1}, Ljava/lang/Long;->longValue()J

    move-result-wide v4

    invoke-virtual {v0}, Ljava/lang/Long;->longValue()J

    move-result-wide v6

    cmp-long v1, v4, v6

    if-gez v1, :cond_71

    :goto_70
    move-object v0, p1

    :cond_71
    if-eqz v0, :cond_9c

    .line 14
    invoke-virtual {v0}, Ljava/lang/Long;->longValue()J

    move-result-wide v4

    invoke-static {}, Ljava/lang/System;->nanoTime()J

    move-result-wide v6

    cmp-long p1, v4, v6

    if-gez p1, :cond_83

    .line 15
    invoke-direct {p0}, Lcom/path/android/jobqueue/JobManager;->notifyJobConsumer()V

    return-wide v2

    .line 16
    :cond_83
    invoke-virtual {v0}, Ljava/lang/Long;->longValue()J

    move-result-wide v0

    invoke-static {}, Ljava/lang/System;->nanoTime()J

    move-result-wide v2

    sub-long/2addr v0, v2

    long-to-double v0, v0

    const-wide v2, 0x412e848000000000L    # 1000000.0

    div-double/2addr v0, v2

    invoke-static {v0, v1}, Ljava/lang/Math;->ceil(D)D

    move-result-wide v0

    double-to-long v0, v0

    .line 17
    invoke-direct {p0, v0, v1}, Lcom/path/android/jobqueue/JobManager;->ensureConsumerOnTime(J)V

    return-wide v0

    :cond_9c
    const-wide v0, 0x7fffffffffffffffL

    return-wide v0

    :catchall_a2
    move-exception p1

    .line 18
    :try_start_a3
    monitor-exit v4
    :try_end_a4
    .catchall {:try_start_a3 .. :try_end_a4} :catchall_a2

    throw p1

    :catchall_a5
    move-exception p1

    .line 19
    :try_start_a6
    monitor-exit v2
    :try_end_a7
    .catchall {:try_start_a6 .. :try_end_a7} :catchall_a5

    throw p1
.end method

.method private getNextJob()Lcom/path/android/jobqueue/JobHolder;
    .registers 9

    .line 1
    invoke-direct {p0}, Lcom/path/android/jobqueue/JobManager;->hasNetwork()Z

    move-result v0

    const-string v1, "looking for next job"

    const/4 v2, 0x0

    new-array v3, v2, [Ljava/lang/Object;

    .line 2
    invoke-static {v1, v3}, Lcom/path/android/jobqueue/log/JqLog;->d(Ljava/lang/String;[Ljava/lang/Object;)V

    .line 3
    iget-object v1, p0, Lcom/path/android/jobqueue/JobManager;->getNextJobLock:Ljava/lang/Object;

    monitor-enter v1

    .line 4
    :try_start_f
    iget-object v3, p0, Lcom/path/android/jobqueue/JobManager;->runningJobGroups:Lcom/path/android/jobqueue/RunningJobSet;

    invoke-virtual {v3}, Lcom/path/android/jobqueue/RunningJobSet;->getSafe()Ljava/util/Collection;

    move-result-object v3

    .line 5
    invoke-static {}, Lcom/path/android/jobqueue/log/JqLog;->isDebugEnabled()Z

    move-result v4

    const/4 v5, 0x1

    if-eqz v4, :cond_2b

    const-string v4, "running groups %s"

    new-array v6, v5, [Ljava/lang/Object;

    const-string v7, ","

    .line 6
    invoke-static {v7, v3}, Lcom/path/android/jobqueue/persistentQueue/sqlite/SqlHelper;->joinStrings(Ljava/lang/String;Ljava/util/Collection;)Ljava/lang/String;

    move-result-object v7

    aput-object v7, v6, v2

    invoke-static {v4, v6}, Lcom/path/android/jobqueue/log/JqLog;->d(Ljava/lang/String;[Ljava/lang/Object;)V

    .line 7
    :cond_2b
    iget-object v4, p0, Lcom/path/android/jobqueue/JobManager;->nonPersistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    monitor-enter v4
    :try_end_2e
    .catchall {:try_start_f .. :try_end_2e} :catchall_a4

    .line 8
    :try_start_2e
    iget-object v6, p0, Lcom/path/android/jobqueue/JobManager;->nonPersistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    invoke-interface {v6, v0, v3}, Lcom/path/android/jobqueue/JobQueue;->nextJobAndIncRunCount(ZLjava/util/Collection;)Lcom/path/android/jobqueue/JobHolder;

    move-result-object v6

    .line 9
    monitor-exit v4
    :try_end_35
    .catchall {:try_start_2e .. :try_end_35} :catchall_a1

    :try_start_35
    const-string v4, "non persistent result %s"

    new-array v7, v5, [Ljava/lang/Object;

    aput-object v6, v7, v2

    .line 10
    invoke-static {v4, v7}, Lcom/path/android/jobqueue/log/JqLog;->d(Ljava/lang/String;[Ljava/lang/Object;)V

    if-nez v6, :cond_58

    .line 11
    iget-object v4, p0, Lcom/path/android/jobqueue/JobManager;->persistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    monitor-enter v4
    :try_end_43
    .catchall {:try_start_35 .. :try_end_43} :catchall_a4

    .line 12
    :try_start_43
    iget-object v6, p0, Lcom/path/android/jobqueue/JobManager;->persistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    invoke-interface {v6, v0, v3}, Lcom/path/android/jobqueue/JobQueue;->nextJobAndIncRunCount(ZLjava/util/Collection;)Lcom/path/android/jobqueue/JobHolder;

    move-result-object v6

    .line 13
    monitor-exit v4
    :try_end_4a
    .catchall {:try_start_43 .. :try_end_4a} :catchall_55

    :try_start_4a
    const-string v0, "persistent result %s"

    new-array v3, v5, [Ljava/lang/Object;

    aput-object v6, v3, v2

    .line 14
    invoke-static {v0, v3}, Lcom/path/android/jobqueue/log/JqLog;->d(Ljava/lang/String;[Ljava/lang/Object;)V
    :try_end_53
    .catchall {:try_start_4a .. :try_end_53} :catchall_a4

    const/4 v2, 0x1

    goto :goto_58

    :catchall_55
    move-exception v0

    .line 15
    :try_start_56
    monitor-exit v4
    :try_end_57
    .catchall {:try_start_56 .. :try_end_57} :catchall_55

    :try_start_57
    throw v0

    :cond_58
    :goto_58
    if-nez v6, :cond_5d

    const/4 v0, 0x0

    .line 16
    monitor-exit v1

    return-object v0

    :cond_5d
    if-eqz v2, :cond_6a

    .line 17
    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->dependencyInjector:Lcom/path/android/jobqueue/di/DependencyInjector;

    if-eqz v0, :cond_6a

    .line 18
    invoke-virtual {v6}, Lcom/path/android/jobqueue/JobHolder;->getJob()Lcom/path/android/jobqueue/Job;

    move-result-object v3

    invoke-interface {v0, v3}, Lcom/path/android/jobqueue/di/DependencyInjector;->inject(Lcom/path/android/jobqueue/Job;)V

    .line 19
    :cond_6a
    invoke-virtual {v6}, Lcom/path/android/jobqueue/JobHolder;->getGroupId()Ljava/lang/String;

    move-result-object v0

    if-eqz v0, :cond_79

    .line 20
    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->runningJobGroups:Lcom/path/android/jobqueue/RunningJobSet;

    invoke-virtual {v6}, Lcom/path/android/jobqueue/JobHolder;->getGroupId()Ljava/lang/String;

    move-result-object v3

    invoke-virtual {v0, v3}, Lcom/path/android/jobqueue/RunningJobSet;->add(Ljava/lang/String;)V

    .line 21
    :cond_79
    monitor-exit v1
    :try_end_7a
    .catchall {:try_start_57 .. :try_end_7a} :catchall_a4

    if-eqz v2, :cond_8a

    .line 22
    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->persistentOnAddedLocks:Ljava/util/concurrent/ConcurrentHashMap;

    invoke-virtual {v6}, Lcom/path/android/jobqueue/JobHolder;->getId()Ljava/lang/Long;

    move-result-object v1

    invoke-virtual {v1}, Ljava/lang/Long;->longValue()J

    move-result-wide v1

    invoke-direct {p0, v0, v1, v2}, Lcom/path/android/jobqueue/JobManager;->waitForOnAddedLock(Ljava/util/concurrent/ConcurrentHashMap;J)V

    goto :goto_97

    .line 23
    :cond_8a
    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->nonPersistentOnAddedLocks:Ljava/util/concurrent/ConcurrentHashMap;

    invoke-virtual {v6}, Lcom/path/android/jobqueue/JobHolder;->getId()Ljava/lang/Long;

    move-result-object v1

    invoke-virtual {v1}, Ljava/lang/Long;->longValue()J

    move-result-wide v1

    invoke-direct {p0, v0, v1, v2}, Lcom/path/android/jobqueue/JobManager;->waitForOnAddedLock(Ljava/util/concurrent/ConcurrentHashMap;J)V

    .line 24
    :goto_97
    invoke-virtual {v6}, Lcom/path/android/jobqueue/JobHolder;->getJob()Lcom/path/android/jobqueue/Job;

    move-result-object v0

    iget-object v1, p0, Lcom/path/android/jobqueue/JobManager;->appContext:Landroid/content/Context;

    invoke-virtual {v0, v1}, Lcom/path/android/jobqueue/Job;->setApplicationContext(Landroid/content/Context;)V

    return-object v6

    :catchall_a1
    move-exception v0

    .line 25
    :try_start_a2
    monitor-exit v4
    :try_end_a3
    .catchall {:try_start_a2 .. :try_end_a3} :catchall_a1

    :try_start_a3
    throw v0

    :catchall_a4
    move-exception v0

    .line 26
    monitor-exit v1
    :try_end_a6
    .catchall {:try_start_a3 .. :try_end_a6} :catchall_a4

    throw v0
.end method

.method private hasNetwork()Z
    .registers 3

    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->networkUtil:Lcom/path/android/jobqueue/network/NetworkUtil;

    if-eqz v0, :cond_f

    iget-object v1, p0, Lcom/path/android/jobqueue/JobManager;->appContext:Landroid/content/Context;

    invoke-interface {v0, v1}, Lcom/path/android/jobqueue/network/NetworkUtil;->isConnected(Landroid/content/Context;)Z

    move-result v0

    if-eqz v0, :cond_d

    goto :goto_f

    :cond_d
    const/4 v0, 0x0

    goto :goto_10

    :cond_f
    :goto_f
    const/4 v0, 0x1

    :goto_10
    return v0
.end method

.method private markJobsAsCancelledAndFilterAlreadyCancelled(Ljava/util/Set;Lcom/path/android/jobqueue/JobQueue;Ljava/util/Set;)V
    .registers 6
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "(",
            "Ljava/util/Set<",
            "Lcom/path/android/jobqueue/JobHolder;",
            ">;",
            "Lcom/path/android/jobqueue/JobQueue;",
            "Ljava/util/Set<",
            "Ljava/lang/Long;",
            ">;)V"
        }
    .end annotation

    .line 1
    invoke-interface {p1}, Ljava/util/Set;->iterator()Ljava/util/Iterator;

    move-result-object p1

    .line 2
    :goto_4
    invoke-interface {p1}, Ljava/util/Iterator;->hasNext()Z

    move-result v0

    if-eqz v0, :cond_28

    .line 3
    invoke-interface {p1}, Ljava/util/Iterator;->next()Ljava/lang/Object;

    move-result-object v0

    check-cast v0, Lcom/path/android/jobqueue/JobHolder;

    .line 4
    invoke-virtual {v0}, Lcom/path/android/jobqueue/JobHolder;->isCancelled()Z

    move-result v1

    if-eqz v1, :cond_1a

    .line 5
    invoke-interface {p1}, Ljava/util/Iterator;->remove()V

    goto :goto_4

    .line 6
    :cond_1a
    invoke-virtual {v0}, Lcom/path/android/jobqueue/JobHolder;->markAsCancelled()V

    .line 7
    invoke-virtual {v0}, Lcom/path/android/jobqueue/JobHolder;->getId()Ljava/lang/Long;

    move-result-object v1

    invoke-interface {p3, v1}, Ljava/util/Set;->add(Ljava/lang/Object;)Z

    .line 8
    invoke-interface {p2, v0}, Lcom/path/android/jobqueue/JobQueue;->onJobCancelled(Lcom/path/android/jobqueue/JobHolder;)V

    goto :goto_4

    :cond_28
    return-void
.end method

.method private notifyJobConsumer()V
    .registers 3

    .line 1
    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->newJobListeners:Ljava/lang/Object;

    monitor-enter v0

    .line 2
    :try_start_3
    iget-object v1, p0, Lcom/path/android/jobqueue/JobManager;->newJobListeners:Ljava/lang/Object;

    invoke-virtual {v1}, Ljava/lang/Object;->notifyAll()V

    .line 3
    monitor-exit v0
    :try_end_9
    .catchall {:try_start_3 .. :try_end_9} :catchall_f

    .line 4
    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->jobConsumerExecutor:Lcom/path/android/jobqueue/executor/JobConsumerExecutor;

    invoke-virtual {v0}, Lcom/path/android/jobqueue/executor/JobConsumerExecutor;->considerAddingConsumer()V

    return-void

    :catchall_f
    move-exception v1

    .line 5
    :try_start_10
    monitor-exit v0
    :try_end_11
    .catchall {:try_start_10 .. :try_end_11} :catchall_f

    throw v1
.end method

.method private reAddJob(Lcom/path/android/jobqueue/JobHolder;)V
    .registers 6

    const-string v0, "re-adding job %s"

    const/4 v1, 0x1

    new-array v1, v1, [Ljava/lang/Object;

    .line 1
    invoke-virtual {p1}, Lcom/path/android/jobqueue/JobHolder;->getId()Ljava/lang/Long;

    move-result-object v2

    const/4 v3, 0x0

    aput-object v2, v1, v3

    invoke-static {v0, v1}, Lcom/path/android/jobqueue/log/JqLog;->d(Ljava/lang/String;[Ljava/lang/Object;)V

    .line 2
    invoke-virtual {p1}, Lcom/path/android/jobqueue/JobHolder;->isCancelled()Z

    move-result v0

    if-nez v0, :cond_39

    .line 3
    invoke-virtual {p1}, Lcom/path/android/jobqueue/JobHolder;->getJob()Lcom/path/android/jobqueue/Job;

    move-result-object v0

    invoke-virtual {v0}, Lcom/path/android/jobqueue/Job;->isPersistent()Z

    move-result v0

    if-eqz v0, :cond_2c

    .line 4
    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->persistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    monitor-enter v0

    .line 5
    :try_start_22
    iget-object v1, p0, Lcom/path/android/jobqueue/JobManager;->persistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    invoke-interface {v1, p1}, Lcom/path/android/jobqueue/JobQueue;->insertOrReplace(Lcom/path/android/jobqueue/JobHolder;)J

    .line 6
    monitor-exit v0

    goto :goto_4f

    :catchall_29
    move-exception p1

    monitor-exit v0
    :try_end_2b
    .catchall {:try_start_22 .. :try_end_2b} :catchall_29

    throw p1

    .line 7
    :cond_2c
    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->nonPersistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    monitor-enter v0

    .line 8
    :try_start_2f
    iget-object v1, p0, Lcom/path/android/jobqueue/JobManager;->nonPersistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    invoke-interface {v1, p1}, Lcom/path/android/jobqueue/JobQueue;->insertOrReplace(Lcom/path/android/jobqueue/JobHolder;)J

    .line 9
    monitor-exit v0

    goto :goto_4f

    :catchall_36
    move-exception p1

    monitor-exit v0
    :try_end_38
    .catchall {:try_start_2f .. :try_end_38} :catchall_36

    throw p1

    .line 10
    :cond_39
    new-instance v0, Ljava/lang/StringBuilder;

    invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V

    const-string v1, "not re-adding cancelled job "

    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

    new-array v1, v3, [Ljava/lang/Object;

    invoke-static {v0, v1}, Lcom/path/android/jobqueue/log/JqLog;->d(Ljava/lang/String;[Ljava/lang/Object;)V

    .line 11
    :goto_4f
    invoke-virtual {p1}, Lcom/path/android/jobqueue/JobHolder;->getGroupId()Ljava/lang/String;

    move-result-object v0

    if-eqz v0, :cond_5e

    .line 12
    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->runningJobGroups:Lcom/path/android/jobqueue/RunningJobSet;

    invoke-virtual {p1}, Lcom/path/android/jobqueue/JobHolder;->getGroupId()Ljava/lang/String;

    move-result-object p1

    invoke-virtual {v0, p1}, Lcom/path/android/jobqueue/RunningJobSet;->remove(Ljava/lang/String;)V

    :cond_5e
    return-void
.end method

.method private removeJob(Lcom/path/android/jobqueue/JobHolder;)V
    .registers 4

    .line 1
    invoke-virtual {p1}, Lcom/path/android/jobqueue/JobHolder;->getJob()Lcom/path/android/jobqueue/Job;

    move-result-object v0

    invoke-virtual {v0}, Lcom/path/android/jobqueue/Job;->isPersistent()Z

    move-result v0

    if-eqz v0, :cond_17

    .line 2
    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->persistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    monitor-enter v0

    .line 3
    :try_start_d
    iget-object v1, p0, Lcom/path/android/jobqueue/JobManager;->persistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    invoke-interface {v1, p1}, Lcom/path/android/jobqueue/JobQueue;->remove(Lcom/path/android/jobqueue/JobHolder;)V

    .line 4
    monitor-exit v0

    goto :goto_20

    :catchall_14
    move-exception p1

    monitor-exit v0
    :try_end_16
    .catchall {:try_start_d .. :try_end_16} :catchall_14

    throw p1

    .line 5
    :cond_17
    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->nonPersistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    monitor-enter v0

    .line 6
    :try_start_1a
    iget-object v1, p0, Lcom/path/android/jobqueue/JobManager;->nonPersistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    invoke-interface {v1, p1}, Lcom/path/android/jobqueue/JobQueue;->remove(Lcom/path/android/jobqueue/JobHolder;)V

    .line 7
    monitor-exit v0
    :try_end_20
    .catchall {:try_start_1a .. :try_end_20} :catchall_30

    .line 8
    :goto_20
    invoke-virtual {p1}, Lcom/path/android/jobqueue/JobHolder;->getGroupId()Ljava/lang/String;

    move-result-object v0

    if-eqz v0, :cond_2f

    .line 9
    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->runningJobGroups:Lcom/path/android/jobqueue/RunningJobSet;

    invoke-virtual {p1}, Lcom/path/android/jobqueue/JobHolder;->getGroupId()Ljava/lang/String;

    move-result-object p1

    invoke-virtual {v0, p1}, Lcom/path/android/jobqueue/RunningJobSet;->remove(Ljava/lang/String;)V

    :cond_2f
    return-void

    :catchall_30
    move-exception p1

    .line 10
    :try_start_31
    monitor-exit v0
    :try_end_32
    .catchall {:try_start_31 .. :try_end_32} :catchall_30

    throw p1
.end method

.method private waitForOnAddedLock(Ljava/util/concurrent/ConcurrentHashMap;J)V
    .registers 4
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "(",
            "Ljava/util/concurrent/ConcurrentHashMap<",
            "Ljava/lang/Long;",
            "Ljava/util/concurrent/CountDownLatch;",
            ">;J)V"
        }
    .end annotation

    .line 1
    invoke-static {p2, p3}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;

    move-result-object p2

    invoke-virtual {p1, p2}, Ljava/util/concurrent/ConcurrentHashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;

    move-result-object p1

    check-cast p1, Ljava/util/concurrent/CountDownLatch;

    if-nez p1, :cond_d

    return-void

    .line 2
    :cond_d
    :try_start_d
    invoke-virtual {p1}, Ljava/util/concurrent/CountDownLatch;->await()V
    :try_end_10
    .catch Ljava/lang/InterruptedException; {:try_start_d .. :try_end_10} :catch_11

    goto :goto_1a

    :catch_11
    move-exception p1

    const/4 p2, 0x0

    new-array p2, p2, [Ljava/lang/Object;

    const-string p3, "could not wait for onAdded lock"

    .line 3
    invoke-static {p1, p3, p2}, Lcom/path/android/jobqueue/log/JqLog;->e(Ljava/lang/Throwable;Ljava/lang/String;[Ljava/lang/Object;)V

    :goto_1a
    return-void
.end method


# virtual methods
.method public addJob(Lcom/path/android/jobqueue/Job;)J
    .registers 12

    .line 1
    new-instance v7, Lcom/path/android/jobqueue/JobHolder;

    invoke-virtual {p1}, Lcom/path/android/jobqueue/Job;->getPriority()I

    move-result v1

    invoke-virtual {p1}, Lcom/path/android/jobqueue/Job;->getDelayInMs()J

    move-result-wide v2

    const-wide/16 v4, 0x0

    cmp-long v0, v2, v4

    if-lez v0, :cond_20

    invoke-static {}, Ljava/lang/System;->nanoTime()J

    move-result-wide v2

    invoke-virtual {p1}, Lcom/path/android/jobqueue/Job;->getDelayInMs()J

    move-result-wide v4

    const-wide/32 v8, 0xf4240

    mul-long v4, v4, v8

    add-long/2addr v4, v2

    move-wide v3, v4

    goto :goto_23

    :cond_20
    const-wide/high16 v2, -0x8000000000000000L

    move-wide v3, v2

    :goto_23
    const-wide/high16 v5, -0x8000000000000000L

    move-object v0, v7

    move-object v2, p1

    invoke-direct/range {v0 .. v6}, Lcom/path/android/jobqueue/JobHolder;-><init>(ILcom/path/android/jobqueue/Job;JJ)V

    .line 2
    invoke-virtual {p1}, Lcom/path/android/jobqueue/Job;->isPersistent()Z

    move-result v0

    if-eqz v0, :cond_43

    .line 3
    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->persistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    monitor-enter v0

    .line 4
    :try_start_33
    iget-object v1, p0, Lcom/path/android/jobqueue/JobManager;->persistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    invoke-interface {v1, v7}, Lcom/path/android/jobqueue/JobQueue;->insert(Lcom/path/android/jobqueue/JobHolder;)J

    move-result-wide v1

    .line 5
    iget-object v3, p0, Lcom/path/android/jobqueue/JobManager;->persistentOnAddedLocks:Ljava/util/concurrent/ConcurrentHashMap;

    invoke-direct {p0, v3, v1, v2}, Lcom/path/android/jobqueue/JobManager;->addOnAddedLock(Ljava/util/concurrent/ConcurrentHashMap;J)V

    .line 6
    monitor-exit v0

    goto :goto_52

    :catchall_40
    move-exception p1

    monitor-exit v0
    :try_end_42
    .catchall {:try_start_33 .. :try_end_42} :catchall_40

    throw p1

    .line 7
    :cond_43
    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->nonPersistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    monitor-enter v0

    .line 8
    :try_start_46
    iget-object v1, p0, Lcom/path/android/jobqueue/JobManager;->nonPersistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    invoke-interface {v1, v7}, Lcom/path/android/jobqueue/JobQueue;->insert(Lcom/path/android/jobqueue/JobHolder;)J

    move-result-wide v1

    .line 9
    iget-object v3, p0, Lcom/path/android/jobqueue/JobManager;->nonPersistentOnAddedLocks:Ljava/util/concurrent/ConcurrentHashMap;

    invoke-direct {p0, v3, v1, v2}, Lcom/path/android/jobqueue/JobManager;->addOnAddedLock(Ljava/util/concurrent/ConcurrentHashMap;J)V

    .line 10
    monitor-exit v0
    :try_end_52
    .catchall {:try_start_46 .. :try_end_52} :catchall_e0

    .line 11
    :goto_52
    invoke-static {}, Lcom/path/android/jobqueue/log/JqLog;->isDebugEnabled()Z

    move-result v0

    if-eqz v0, :cond_a5

    const-string v0, "added job id: %d class: %s priority: %d delay: %d group : %s persistent: %s requires network: %s"

    const/4 v3, 0x7

    new-array v3, v3, [Ljava/lang/Object;

    const/4 v4, 0x0

    .line 12
    invoke-static {v1, v2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;

    move-result-object v5

    aput-object v5, v3, v4

    const/4 v4, 0x1

    invoke-virtual {p1}, Ljava/lang/Object;->getClass()Ljava/lang/Class;

    move-result-object v5

    invoke-virtual {v5}, Ljava/lang/Class;->getSimpleName()Ljava/lang/String;

    move-result-object v5

    aput-object v5, v3, v4

    const/4 v4, 0x2

    invoke-virtual {p1}, Lcom/path/android/jobqueue/Job;->getPriority()I

    move-result v5

    invoke-static {v5}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;

    move-result-object v5

    aput-object v5, v3, v4

    const/4 v4, 0x3

    invoke-virtual {p1}, Lcom/path/android/jobqueue/Job;->getDelayInMs()J

    move-result-wide v5

    invoke-static {v5, v6}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;

    move-result-object v5

    aput-object v5, v3, v4

    const/4 v4, 0x4

    invoke-virtual {p1}, Lcom/path/android/jobqueue/Job;->getRunGroupId()Ljava/lang/String;

    move-result-object v5

    aput-object v5, v3, v4

    const/4 v4, 0x5

    invoke-virtual {p1}, Lcom/path/android/jobqueue/Job;->isPersistent()Z

    move-result v5

    invoke-static {v5}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean;

    move-result-object v5

    aput-object v5, v3, v4

    const/4 v4, 0x6

    invoke-virtual {p1}, Lcom/path/android/jobqueue/Job;->requiresNetwork()Z

    move-result v5

    invoke-static {v5}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean;

    move-result-object v5

    aput-object v5, v3, v4

    invoke-static {v0, v3}, Lcom/path/android/jobqueue/log/JqLog;->d(Ljava/lang/String;[Ljava/lang/Object;)V

    .line 13
    :cond_a5
    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->dependencyInjector:Lcom/path/android/jobqueue/di/DependencyInjector;

    if-eqz v0, :cond_ac

    .line 14
    invoke-interface {v0, p1}, Lcom/path/android/jobqueue/di/DependencyInjector;->inject(Lcom/path/android/jobqueue/Job;)V

    .line 15
    :cond_ac
    invoke-virtual {v7}, Lcom/path/android/jobqueue/JobHolder;->getJob()Lcom/path/android/jobqueue/Job;

    move-result-object v0

    iget-object v3, p0, Lcom/path/android/jobqueue/JobManager;->appContext:Landroid/content/Context;

    invoke-virtual {v0, v3}, Lcom/path/android/jobqueue/Job;->setApplicationContext(Landroid/content/Context;)V

    .line 16
    invoke-virtual {v7}, Lcom/path/android/jobqueue/JobHolder;->getJob()Lcom/path/android/jobqueue/Job;

    move-result-object v0

    invoke-virtual {v0}, Lcom/path/android/jobqueue/Job;->onAdded()V

    .line 17
    invoke-virtual {p1}, Lcom/path/android/jobqueue/Job;->isPersistent()Z

    move-result p1

    if-eqz p1, :cond_cf

    .line 18
    iget-object p1, p0, Lcom/path/android/jobqueue/JobManager;->persistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    monitor-enter p1

    .line 19
    :try_start_c5
    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->persistentOnAddedLocks:Ljava/util/concurrent/ConcurrentHashMap;

    invoke-direct {p0, v0, v1, v2}, Lcom/path/android/jobqueue/JobManager;->clearOnAddedLock(Ljava/util/concurrent/ConcurrentHashMap;J)V

    .line 20
    monitor-exit p1

    goto :goto_d8

    :catchall_cc
    move-exception v0

    monitor-exit p1
    :try_end_ce
    .catchall {:try_start_c5 .. :try_end_ce} :catchall_cc

    throw v0

    .line 21
    :cond_cf
    iget-object p1, p0, Lcom/path/android/jobqueue/JobManager;->nonPersistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    monitor-enter p1

    .line 22
    :try_start_d2
    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->nonPersistentOnAddedLocks:Ljava/util/concurrent/ConcurrentHashMap;

    invoke-direct {p0, v0, v1, v2}, Lcom/path/android/jobqueue/JobManager;->clearOnAddedLock(Ljava/util/concurrent/ConcurrentHashMap;J)V

    .line 23
    monitor-exit p1
    :try_end_d8
    .catchall {:try_start_d2 .. :try_end_d8} :catchall_dd

    :goto_d8
    const/4 p1, 0x0

    .line 24
    invoke-direct {p0, p1}, Lcom/path/android/jobqueue/JobManager;->ensureConsumerWhenNeeded(Ljava/lang/Boolean;)J

    return-wide v1

    :catchall_dd
    move-exception v0

    .line 25
    :try_start_de
    monitor-exit p1
    :try_end_df
    .catchall {:try_start_de .. :try_end_df} :catchall_dd

    throw v0

    :catchall_e0
    move-exception p1

    .line 26
    :try_start_e1
    monitor-exit v0
    :try_end_e2
    .catchall {:try_start_e1 .. :try_end_e2} :catchall_e0

    throw p1
.end method

.method public addJobInBackground(Lcom/path/android/jobqueue/Job;)V
    .registers 3

    const/4 v0, 0x0

    .line 1
    invoke-virtual {p0, p1, v0}, Lcom/path/android/jobqueue/JobManager;->addJobInBackground(Lcom/path/android/jobqueue/Job;Lcom/path/android/jobqueue/AsyncAddCallback;)V

    return-void
.end method

.method public addJobInBackground(Lcom/path/android/jobqueue/Job;Lcom/path/android/jobqueue/AsyncAddCallback;)V
    .registers 5

    .line 2
    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->timedExecutor:Ljava/util/concurrent/ScheduledExecutorService;

    new-instance v1, Lcom/path/android/jobqueue/JobManager$3;

    invoke-direct {v1, p0, p1, p2}, Lcom/path/android/jobqueue/JobManager$3;-><init>(Lcom/path/android/jobqueue/JobManager;Lcom/path/android/jobqueue/Job;Lcom/path/android/jobqueue/AsyncAddCallback;)V

    invoke-static {v0, v1}, Lcom/path/android/jobqueue/JobManager;->INVOKEINTERFACE_com_path_android_jobqueue_JobManager_com_shopee_app_asm_anr_threadpool_ExecutorProxy_execute(Ljava/util/concurrent/ScheduledExecutorService;Ljava/lang/Runnable;)V

    return-void
.end method

.method public varargs cancelJobs(Lcom/path/android/jobqueue/TagConstraint;[Ljava/lang/String;)Lcom/path/android/jobqueue/CancelResult;
    .registers 21

    move-object/from16 v10, p0

    .line 1
    new-instance v11, Ljava/util/ArrayList;

    invoke-direct {v11}, Ljava/util/ArrayList;-><init>()V

    .line 2
    new-instance v0, Ljava/util/HashSet;

    invoke-direct {v0}, Ljava/util/HashSet;-><init>()V

    .line 3
    new-instance v12, Ljava/util/HashSet;

    invoke-direct {v12}, Ljava/util/HashSet;-><init>()V

    .line 4
    new-instance v13, Ljava/util/HashSet;

    invoke-direct {v13}, Ljava/util/HashSet;-><init>()V

    .line 5
    new-instance v14, Ljava/util/HashSet;

    invoke-direct {v14}, Ljava/util/HashSet;-><init>()V

    .line 6
    iget-object v15, v10, Lcom/path/android/jobqueue/JobManager;->getNextJobLock:Ljava/lang/Object;

    monitor-enter v15

    .line 7
    :try_start_1e
    iget-object v9, v10, Lcom/path/android/jobqueue/JobManager;->jobConsumerExecutor:Lcom/path/android/jobqueue/executor/JobConsumerExecutor;

    new-instance v8, Lcom/path/android/jobqueue/JobManager$2;

    move-object v1, v8

    move-object/from16 v2, p0

    move-object/from16 v3, p1

    move-object/from16 v4, p2

    move-object v5, v12

    move-object v6, v13

    move-object v7, v11

    move-object/from16 v16, v13

    move-object v13, v8

    move-object v8, v0

    move-object/from16 v17, v11

    move-object v11, v9

    move-object v9, v14

    invoke-direct/range {v1 .. v9}, Lcom/path/android/jobqueue/JobManager$2;-><init>(Lcom/path/android/jobqueue/JobManager;Lcom/path/android/jobqueue/TagConstraint;[Ljava/lang/String;Ljava/util/Set;Ljava/util/Set;Ljava/util/List;Ljava/util/Set;Ljava/util/Set;)V

    invoke-virtual {v11, v13}, Lcom/path/android/jobqueue/executor/JobConsumerExecutor;->inRunningJobHoldersLock(Ljava/lang/Runnable;)V

    .line 8
    monitor-exit v15
    :try_end_3b
    .catchall {:try_start_1e .. :try_end_3b} :catchall_f5

    const/4 v1, 0x0

    .line 9
    :try_start_3c
    iget-object v2, v10, Lcom/path/android/jobqueue/JobManager;->jobConsumerExecutor:Lcom/path/android/jobqueue/executor/JobConsumerExecutor;

    invoke-virtual {v2, v0, v12}, Lcom/path/android/jobqueue/executor/JobConsumerExecutor;->waitUntilDone(Ljava/util/Set;Ljava/util/Set;)V
    :try_end_41
    .catch Ljava/lang/InterruptedException; {:try_start_3c .. :try_end_41} :catch_42

    goto :goto_4a

    :catch_42
    move-exception v0

    const-string v2, "error while waiting for jobs to finish"

    new-array v3, v1, [Ljava/lang/Object;

    .line 10
    invoke-static {v0, v2, v3}, Lcom/path/android/jobqueue/log/JqLog;->e(Ljava/lang/Throwable;Ljava/lang/String;[Ljava/lang/Object;)V

    .line 11
    :goto_4a
    new-instance v2, Lcom/path/android/jobqueue/CancelResult;

    invoke-direct {v2}, Lcom/path/android/jobqueue/CancelResult;-><init>()V

    .line 12
    invoke-virtual/range {v17 .. v17}, Ljava/util/ArrayList;->iterator()Ljava/util/Iterator;

    move-result-object v3

    :goto_53
    invoke-interface {v3}, Ljava/util/Iterator;->hasNext()Z

    move-result v0

    if-eqz v0, :cond_f4

    invoke-interface {v3}, Ljava/util/Iterator;->next()Ljava/lang/Object;

    move-result-object v0

    move-object v4, v0

    check-cast v4, Lcom/path/android/jobqueue/JobHolder;

    const-string v0, "checking if I could cancel %s. Result: %s"

    const/4 v5, 0x2

    new-array v5, v5, [Ljava/lang/Object;

    .line 13
    invoke-virtual {v4}, Lcom/path/android/jobqueue/JobHolder;->getJob()Lcom/path/android/jobqueue/Job;

    move-result-object v6

    aput-object v6, v5, v1

    invoke-virtual {v4}, Lcom/path/android/jobqueue/JobHolder;->isSuccessful()Z

    move-result v6

    const/4 v7, 0x1

    xor-int/2addr v6, v7

    invoke-static {v6}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean;

    move-result-object v6

    aput-object v6, v5, v7

    invoke-static {v0, v5}, Lcom/path/android/jobqueue/log/JqLog;->d(Ljava/lang/String;[Ljava/lang/Object;)V

    .line 14
    invoke-virtual {v4}, Lcom/path/android/jobqueue/JobHolder;->isSuccessful()Z

    move-result v0

    if-eqz v0, :cond_8c

    .line 15
    iget-object v0, v2, Lcom/path/android/jobqueue/CancelResult;->failedToCancel:Ljava/util/Collection;

    invoke-virtual {v4}, Lcom/path/android/jobqueue/JobHolder;->getJob()Lcom/path/android/jobqueue/Job;

    move-result-object v4

    invoke-interface {v0, v4}, Ljava/util/Collection;->add(Ljava/lang/Object;)Z

    :cond_89
    :goto_89
    move-object/from16 v5, v16

    goto :goto_f0

    .line 16
    :cond_8c
    iget-object v0, v2, Lcom/path/android/jobqueue/CancelResult;->cancelledJobs:Ljava/util/Collection;

    invoke-virtual {v4}, Lcom/path/android/jobqueue/JobHolder;->getJob()Lcom/path/android/jobqueue/Job;

    move-result-object v5

    invoke-interface {v0, v5}, Ljava/util/Collection;->add(Ljava/lang/Object;)Z

    .line 17
    :try_start_95
    invoke-virtual {v4}, Lcom/path/android/jobqueue/JobHolder;->getJob()Lcom/path/android/jobqueue/Job;

    move-result-object v0

    invoke-virtual {v0}, Lcom/path/android/jobqueue/Job;->onCancel()V
    :try_end_9c
    .catchall {:try_start_95 .. :try_end_9c} :catchall_9d

    goto :goto_a5

    :catchall_9d
    move-exception v0

    const-string v5, "cancelled job\'s onCancel has thrown exception"

    new-array v6, v1, [Ljava/lang/Object;

    .line 18
    invoke-static {v0, v5, v6}, Lcom/path/android/jobqueue/log/JqLog;->e(Ljava/lang/Throwable;Ljava/lang/String;[Ljava/lang/Object;)V

    .line 19
    :goto_a5
    invoke-virtual {v4}, Lcom/path/android/jobqueue/JobHolder;->getJob()Lcom/path/android/jobqueue/Job;

    move-result-object v0

    invoke-virtual {v0}, Lcom/path/android/jobqueue/Job;->isPersistent()Z

    move-result v0

    if-eqz v0, :cond_d5

    .line 20
    iget-object v5, v10, Lcom/path/android/jobqueue/JobManager;->persistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    monitor-enter v5

    .line 21
    :try_start_b2
    iget-object v0, v10, Lcom/path/android/jobqueue/JobManager;->persistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    invoke-interface {v0, v4}, Lcom/path/android/jobqueue/JobQueue;->remove(Lcom/path/android/jobqueue/JobHolder;)V

    .line 22
    monitor-exit v5
    :try_end_b8
    .catchall {:try_start_b2 .. :try_end_b8} :catchall_d2

    .line 23
    invoke-virtual {v4}, Lcom/path/android/jobqueue/JobHolder;->getGroupId()Ljava/lang/String;

    move-result-object v0

    if-eqz v0, :cond_89

    invoke-virtual {v4}, Lcom/path/android/jobqueue/JobHolder;->getId()Ljava/lang/Long;

    move-result-object v0

    invoke-virtual {v14, v0}, Ljava/util/HashSet;->contains(Ljava/lang/Object;)Z

    move-result v0

    if-eqz v0, :cond_89

    .line 24
    iget-object v0, v10, Lcom/path/android/jobqueue/JobManager;->runningJobGroups:Lcom/path/android/jobqueue/RunningJobSet;

    invoke-virtual {v4}, Lcom/path/android/jobqueue/JobHolder;->getGroupId()Ljava/lang/String;

    move-result-object v4

    invoke-virtual {v0, v4}, Lcom/path/android/jobqueue/RunningJobSet;->remove(Ljava/lang/String;)V

    goto :goto_89

    :catchall_d2
    move-exception v0

    .line 25
    :try_start_d3
    monitor-exit v5
    :try_end_d4
    .catchall {:try_start_d3 .. :try_end_d4} :catchall_d2

    throw v0

    .line 26
    :cond_d5
    invoke-virtual {v4}, Lcom/path/android/jobqueue/JobHolder;->getGroupId()Ljava/lang/String;

    move-result-object v0

    if-eqz v0, :cond_89

    invoke-virtual {v4}, Lcom/path/android/jobqueue/JobHolder;->getId()Ljava/lang/Long;

    move-result-object v0

    move-object/from16 v5, v16

    invoke-virtual {v5, v0}, Ljava/util/HashSet;->contains(Ljava/lang/Object;)Z

    move-result v0

    if-eqz v0, :cond_f0

    .line 27
    iget-object v0, v10, Lcom/path/android/jobqueue/JobManager;->runningJobGroups:Lcom/path/android/jobqueue/RunningJobSet;

    invoke-virtual {v4}, Lcom/path/android/jobqueue/JobHolder;->getGroupId()Ljava/lang/String;

    move-result-object v4

    invoke-virtual {v0, v4}, Lcom/path/android/jobqueue/RunningJobSet;->remove(Ljava/lang/String;)V

    :cond_f0
    :goto_f0
    move-object/from16 v16, v5

    goto/16 :goto_53

    :cond_f4
    return-object v2

    :catchall_f5
    move-exception v0

    .line 28
    :try_start_f6
    monitor-exit v15
    :try_end_f7
    .catchall {:try_start_f6 .. :try_end_f7} :catchall_f5

    throw v0
.end method

.method public varargs cancelJobsInBackground(Lcom/path/android/jobqueue/CancelResult$AsyncCancelCallback;Lcom/path/android/jobqueue/TagConstraint;[Ljava/lang/String;)V
    .registers 7

    .line 1
    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->cancelExecutorInitLock:Ljava/lang/Object;

    monitor-enter v0

    .line 2
    :try_start_3
    iget-object v1, p0, Lcom/path/android/jobqueue/JobManager;->cancelExecutor:Ljava/util/concurrent/Executor;

    if-nez v1, :cond_d

    .line 3
    invoke-static {}, Ljava/util/concurrent/Executors;->newSingleThreadExecutor()Ljava/util/concurrent/ExecutorService;

    move-result-object v1

    iput-object v1, p0, Lcom/path/android/jobqueue/JobManager;->cancelExecutor:Ljava/util/concurrent/Executor;

    .line 4
    :cond_d
    iget-object v1, p0, Lcom/path/android/jobqueue/JobManager;->cancelExecutor:Ljava/util/concurrent/Executor;

    new-instance v2, Lcom/path/android/jobqueue/JobManager$1;

    invoke-direct {v2, p0, p2, p3, p1}, Lcom/path/android/jobqueue/JobManager$1;-><init>(Lcom/path/android/jobqueue/JobManager;Lcom/path/android/jobqueue/TagConstraint;[Ljava/lang/String;Lcom/path/android/jobqueue/CancelResult$AsyncCancelCallback;)V

    invoke-static {v1, v2}, Lcom/path/android/jobqueue/JobManager;->INVOKEINTERFACE_com_path_android_jobqueue_JobManager_com_shopee_app_asm_anr_threadpool_ExecutorProxy_execute(Ljava/util/concurrent/Executor;Ljava/lang/Runnable;)V

    .line 5
    monitor-exit v0

    return-void

    :catchall_19
    move-exception p1

    monitor-exit v0
    :try_end_1b
    .catchall {:try_start_3 .. :try_end_1b} :catchall_19

    throw p1
.end method

.method public declared-synchronized clear()V
    .registers 3

    monitor-enter p0

    .line 1
    :try_start_1
    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->nonPersistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    monitor-enter v0
    :try_end_4
    .catchall {:try_start_1 .. :try_end_4} :catchall_2a

    .line 2
    :try_start_4
    iget-object v1, p0, Lcom/path/android/jobqueue/JobManager;->nonPersistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    invoke-interface {v1}, Lcom/path/android/jobqueue/JobQueue;->clear()V

    .line 3
    iget-object v1, p0, Lcom/path/android/jobqueue/JobManager;->nonPersistentOnAddedLocks:Ljava/util/concurrent/ConcurrentHashMap;

    invoke-virtual {v1}, Ljava/util/concurrent/ConcurrentHashMap;->clear()V

    .line 4
    monitor-exit v0
    :try_end_f
    .catchall {:try_start_4 .. :try_end_f} :catchall_27

    .line 5
    :try_start_f
    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->persistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    monitor-enter v0
    :try_end_12
    .catchall {:try_start_f .. :try_end_12} :catchall_2a

    .line 6
    :try_start_12
    iget-object v1, p0, Lcom/path/android/jobqueue/JobManager;->persistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    invoke-interface {v1}, Lcom/path/android/jobqueue/JobQueue;->clear()V

    .line 7
    iget-object v1, p0, Lcom/path/android/jobqueue/JobManager;->persistentOnAddedLocks:Ljava/util/concurrent/ConcurrentHashMap;

    invoke-virtual {v1}, Ljava/util/concurrent/ConcurrentHashMap;->clear()V

    .line 8
    monitor-exit v0
    :try_end_1d
    .catchall {:try_start_12 .. :try_end_1d} :catchall_24

    .line 9
    :try_start_1d
    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->runningJobGroups:Lcom/path/android/jobqueue/RunningJobSet;

    invoke-virtual {v0}, Lcom/path/android/jobqueue/RunningJobSet;->clear()V
    :try_end_22
    .catchall {:try_start_1d .. :try_end_22} :catchall_2a

    .line 10
    monitor-exit p0

    return-void

    :catchall_24
    move-exception v1

    .line 11
    :try_start_25
    monitor-exit v0
    :try_end_26
    .catchall {:try_start_25 .. :try_end_26} :catchall_24

    :try_start_26
    throw v1
    :try_end_27
    .catchall {:try_start_26 .. :try_end_27} :catchall_2a

    :catchall_27
    move-exception v1

    .line 12
    :try_start_28
    monitor-exit v0
    :try_end_29
    .catchall {:try_start_28 .. :try_end_29} :catchall_27

    :try_start_29
    throw v1
    :try_end_2a
    .catchall {:try_start_29 .. :try_end_2a} :catchall_2a

    :catchall_2a
    move-exception v0

    monitor-exit p0

    throw v0
.end method

.method public count()I
    .registers 4

    .line 1
    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->nonPersistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    monitor-enter v0

    .line 2
    :try_start_3
    iget-object v1, p0, Lcom/path/android/jobqueue/JobManager;->nonPersistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    invoke-interface {v1}, Lcom/path/android/jobqueue/JobQueue;->count()I

    move-result v1

    add-int/lit8 v1, v1, 0x0

    .line 3
    monitor-exit v0
    :try_end_c
    .catchall {:try_start_3 .. :try_end_c} :catchall_1b

    .line 4
    iget-object v2, p0, Lcom/path/android/jobqueue/JobManager;->persistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    monitor-enter v2

    .line 5
    :try_start_f
    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->persistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    invoke-interface {v0}, Lcom/path/android/jobqueue/JobQueue;->count()I

    move-result v0

    add-int/2addr v1, v0

    .line 6
    monitor-exit v2

    return v1

    :catchall_18
    move-exception v0

    monitor-exit v2
    :try_end_1a
    .catchall {:try_start_f .. :try_end_1a} :catchall_18

    throw v0

    :catchall_1b
    move-exception v1

    .line 7
    :try_start_1c
    monitor-exit v0
    :try_end_1d
    .catchall {:try_start_1c .. :try_end_1d} :catchall_1b

    throw v1
.end method

.method public getJobStatus(JZ)Lcom/path/android/jobqueue/JobStatus;
    .registers 6

    .line 1
    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->jobConsumerExecutor:Lcom/path/android/jobqueue/executor/JobConsumerExecutor;

    invoke-virtual {v0, p1, p2, p3}, Lcom/path/android/jobqueue/executor/JobConsumerExecutor;->isRunning(JZ)Z

    move-result v0

    if-eqz v0, :cond_b

    .line 2
    sget-object p1, Lcom/path/android/jobqueue/JobStatus;->RUNNING:Lcom/path/android/jobqueue/JobStatus;

    return-object p1

    :cond_b
    if-eqz p3, :cond_1b

    .line 3
    iget-object p3, p0, Lcom/path/android/jobqueue/JobManager;->persistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    monitor-enter p3

    .line 4
    :try_start_10
    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->persistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    invoke-interface {v0, p1, p2}, Lcom/path/android/jobqueue/JobQueue;->findJobById(J)Lcom/path/android/jobqueue/JobHolder;

    move-result-object p1

    .line 5
    monitor-exit p3

    goto :goto_25

    :catchall_18
    move-exception p1

    monitor-exit p3
    :try_end_1a
    .catchall {:try_start_10 .. :try_end_1a} :catchall_18

    throw p1

    .line 6
    :cond_1b
    iget-object p3, p0, Lcom/path/android/jobqueue/JobManager;->nonPersistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    monitor-enter p3

    .line 7
    :try_start_1e
    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->nonPersistentJobQueue:Lcom/path/android/jobqueue/JobQueue;

    invoke-interface {v0, p1, p2}, Lcom/path/android/jobqueue/JobQueue;->findJobById(J)Lcom/path/android/jobqueue/JobHolder;

    move-result-object p1

    .line 8
    monitor-exit p3
    :try_end_25
    .catchall {:try_start_1e .. :try_end_25} :catchall_4b

    :goto_25
    if-nez p1, :cond_2a

    .line 9
    sget-object p1, Lcom/path/android/jobqueue/JobStatus;->UNKNOWN:Lcom/path/android/jobqueue/JobStatus;

    return-object p1

    .line 10
    :cond_2a
    invoke-direct {p0}, Lcom/path/android/jobqueue/JobManager;->hasNetwork()Z

    move-result p2

    .line 11
    invoke-virtual {p1}, Lcom/path/android/jobqueue/JobHolder;->requiresNetwork()Z

    move-result p3

    if-eqz p3, :cond_39

    if-nez p2, :cond_39

    .line 12
    sget-object p1, Lcom/path/android/jobqueue/JobStatus;->WAITING_NOT_READY:Lcom/path/android/jobqueue/JobStatus;

    return-object p1

    .line 13
    :cond_39
    invoke-virtual {p1}, Lcom/path/android/jobqueue/JobHolder;->getDelayUntilNs()J

    move-result-wide p1

    invoke-static {}, Ljava/lang/System;->nanoTime()J

    move-result-wide v0

    cmp-long p3, p1, v0

    if-lez p3, :cond_48

    .line 14
    sget-object p1, Lcom/path/android/jobqueue/JobStatus;->WAITING_NOT_READY:Lcom/path/android/jobqueue/JobStatus;

    return-object p1

    .line 15
    :cond_48
    sget-object p1, Lcom/path/android/jobqueue/JobStatus;->WAITING_READY:Lcom/path/android/jobqueue/JobStatus;

    return-object p1

    :catchall_4b
    move-exception p1

    .line 16
    :try_start_4c
    monitor-exit p3
    :try_end_4d
    .catchall {:try_start_4c .. :try_end_4d} :catchall_4b

    throw p1
.end method

.method public onNetworkChange(Z)V
    .registers 2

    invoke-static {p1}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean;

    move-result-object p1

    invoke-direct {p0, p1}, Lcom/path/android/jobqueue/JobManager;->ensureConsumerWhenNeeded(Ljava/lang/Boolean;)J

    return-void
.end method

.method public start()V
    .registers 2

    .line 1
    iget-boolean v0, p0, Lcom/path/android/jobqueue/JobManager;->running:Z

    if-eqz v0, :cond_5

    return-void

    :cond_5
    const/4 v0, 0x1

    .line 2
    iput-boolean v0, p0, Lcom/path/android/jobqueue/JobManager;->running:Z

    .line 3
    invoke-direct {p0}, Lcom/path/android/jobqueue/JobManager;->notifyJobConsumer()V

    return-void
.end method

.method public stop()V
    .registers 2

    const/4 v0, 0x0

    iput-boolean v0, p0, Lcom/path/android/jobqueue/JobManager;->running:Z

    return-void
.end method

.method public declared-synchronized stopAndWaitUntilConsumersAreFinished()V
    .registers 3
    .annotation system Ldalvik/annotation/Throws;
        value = {
            Ljava/lang/InterruptedException;
        }
    .end annotation

    monitor-enter p0

    .line 1
    :try_start_1
    invoke-virtual {p0}, Lcom/path/android/jobqueue/JobManager;->stop()V

    .line 2
    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->timedExecutor:Ljava/util/concurrent/ScheduledExecutorService;

    invoke-interface {v0}, Ljava/util/concurrent/ExecutorService;->shutdownNow()Ljava/util/List;

    .line 3
    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->newJobListeners:Ljava/lang/Object;

    monitor-enter v0
    :try_end_c
    .catchall {:try_start_1 .. :try_end_c} :catchall_22

    .line 4
    :try_start_c
    iget-object v1, p0, Lcom/path/android/jobqueue/JobManager;->newJobListeners:Ljava/lang/Object;

    invoke-virtual {v1}, Ljava/lang/Object;->notifyAll()V

    .line 5
    monitor-exit v0
    :try_end_12
    .catchall {:try_start_c .. :try_end_12} :catchall_1f

    .line 6
    :try_start_12
    iget-object v0, p0, Lcom/path/android/jobqueue/JobManager;->jobConsumerExecutor:Lcom/path/android/jobqueue/executor/JobConsumerExecutor;

    invoke-virtual {v0}, Lcom/path/android/jobqueue/executor/JobConsumerExecutor;->waitUntilAllConsumersAreFinished()V

    .line 7
    invoke-static {}, Ljava/util/concurrent/Executors;->newSingleThreadScheduledExecutor()Ljava/util/concurrent/ScheduledExecutorService;

    move-result-object v0

    iput-object v0, p0, Lcom/path/android/jobqueue/JobManager;->timedExecutor:Ljava/util/concurrent/ScheduledExecutorService;
    :try_end_1d
    .catchall {:try_start_12 .. :try_end_1d} :catchall_22

    .line 8
    monitor-exit p0

    return-void

    :catchall_1f
    move-exception v1

    .line 9
    :try_start_20
    monitor-exit v0
    :try_end_21
    .catchall {:try_start_20 .. :try_end_21} :catchall_1f

    :try_start_21
    throw v1
    :try_end_22
    .catchall {:try_start_21 .. :try_end_22} :catchall_22

    :catchall_22
    move-exception v0

    monitor-exit p0

    throw v0
.end method