WorkManagerGcmService.smali

.class public Landroidx/work/impl/background/gcm/WorkManagerGcmService;
.super Lcom/google/android/gms/gcm/GcmTaskService;
.source "SourceFile"


# instance fields
.field public a:Z

.field public b:Landroidx/work/impl/background/gcm/d;


# direct methods
.method public constructor <init>()V
    .registers 1

    invoke-direct {p0}, Lcom/google/android/gms/gcm/GcmTaskService;-><init>()V

    return-void
.end method


# virtual methods
.method public final a()V
    .registers 4

    .line 1
    iget-boolean v0, p0, Landroidx/work/impl/background/gcm/WorkManagerGcmService;->a:Z

    if-eqz v0, :cond_20

    .line 2
    invoke-static {}, Landroidx/work/o;->c()Landroidx/work/o;

    move-result-object v0

    const/4 v1, 0x0

    new-array v2, v1, [Ljava/lang/Throwable;

    invoke-virtual {v0, v2}, Landroidx/work/o;->a([Ljava/lang/Throwable;)V

    .line 3
    iput-boolean v1, p0, Landroidx/work/impl/background/gcm/WorkManagerGcmService;->a:Z

    .line 4
    new-instance v0, Landroidx/work/impl/background/gcm/d;

    invoke-virtual {p0}, Landroid/content/Context;->getApplicationContext()Landroid/content/Context;

    move-result-object v1

    new-instance v2, Landroidx/work/impl/utils/q;

    invoke-direct {v2}, Landroidx/work/impl/utils/q;-><init>()V

    invoke-direct {v0, v1, v2}, Landroidx/work/impl/background/gcm/d;-><init>(Landroid/content/Context;Landroidx/work/impl/utils/q;)V

    iput-object v0, p0, Landroidx/work/impl/background/gcm/WorkManagerGcmService;->b:Landroidx/work/impl/background/gcm/d;

    :cond_20
    return-void
.end method

.method public final onCreate()V
    .registers 4

    .line 1
    invoke-super {p0}, Lcom/google/android/gms/gcm/GcmTaskService;->onCreate()V

    const/4 v0, 0x0

    .line 2
    iput-boolean v0, p0, Landroidx/work/impl/background/gcm/WorkManagerGcmService;->a:Z

    .line 3
    new-instance v0, Landroidx/work/impl/background/gcm/d;

    invoke-virtual {p0}, Landroid/content/Context;->getApplicationContext()Landroid/content/Context;

    move-result-object v1

    new-instance v2, Landroidx/work/impl/utils/q;

    invoke-direct {v2}, Landroidx/work/impl/utils/q;-><init>()V

    invoke-direct {v0, v1, v2}, Landroidx/work/impl/background/gcm/d;-><init>(Landroid/content/Context;Landroidx/work/impl/utils/q;)V

    iput-object v0, p0, Landroidx/work/impl/background/gcm/WorkManagerGcmService;->b:Landroidx/work/impl/background/gcm/d;

    return-void
.end method

.method public final onDestroy()V
    .registers 3

    .line 1
    invoke-super {p0}, Lcom/google/android/gms/gcm/GcmTaskService;->onDestroy()V

    const/4 v0, 0x1

    .line 2
    iput-boolean v0, p0, Landroidx/work/impl/background/gcm/WorkManagerGcmService;->a:Z

    .line 3
    iget-object v0, p0, Landroidx/work/impl/background/gcm/WorkManagerGcmService;->b:Landroidx/work/impl/background/gcm/d;

    .line 4
    iget-object v0, v0, Landroidx/work/impl/background/gcm/d;->b:Landroidx/work/impl/utils/q;

    .line 5
    iget-object v1, v0, Landroidx/work/impl/utils/q;->b:Ljava/util/concurrent/ScheduledExecutorService;

    invoke-interface {v1}, Ljava/util/concurrent/ExecutorService;->isShutdown()Z

    move-result v1

    if-nez v1, :cond_17

    .line 6
    iget-object v0, v0, Landroidx/work/impl/utils/q;->b:Ljava/util/concurrent/ScheduledExecutorService;

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

    :cond_17
    return-void
.end method

.method public final onInitializeTasks()V
    .registers 4

    .line 1
    invoke-virtual {p0}, Landroidx/work/impl/background/gcm/WorkManagerGcmService;->a()V

    .line 2
    iget-object v0, p0, Landroidx/work/impl/background/gcm/WorkManagerGcmService;->b:Landroidx/work/impl/background/gcm/d;

    .line 3
    iget-object v1, v0, Landroidx/work/impl/background/gcm/d;->c:Landroidx/work/impl/l;

    .line 4
    iget-object v1, v1, Landroidx/work/impl/l;->d:Landroidx/work/impl/utils/taskexecutor/a;

    .line 5
    new-instance v2, Landroidx/work/impl/background/gcm/b;

    invoke-direct {v2, v0}, Landroidx/work/impl/background/gcm/b;-><init>(Landroidx/work/impl/background/gcm/d;)V

    check-cast v1, Landroidx/work/impl/utils/taskexecutor/b;

    invoke-virtual {v1, v2}, Landroidx/work/impl/utils/taskexecutor/b;->a(Ljava/lang/Runnable;)V

    return-void
.end method

.method public final onRunTask(Lcom/google/android/gms/gcm/TaskParams;)I
    .registers 14

    .line 1
    invoke-virtual {p0}, Landroidx/work/impl/background/gcm/WorkManagerGcmService;->a()V

    .line 2
    iget-object v0, p0, Landroidx/work/impl/background/gcm/WorkManagerGcmService;->b:Landroidx/work/impl/background/gcm/d;

    invoke-static {v0}, Ljava/util/Objects;->requireNonNull(Ljava/lang/Object;)Ljava/lang/Object;

    const-string v1, "Rescheduling WorkSpec %s"

    .line 3
    invoke-static {}, Landroidx/work/o;->c()Landroidx/work/o;

    move-result-object v2

    sget-object v3, Landroidx/work/impl/background/gcm/d;->d:Ljava/lang/String;

    const/4 v3, 0x1

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

    const/4 v5, 0x0

    aput-object p1, v4, v5

    const-string v6, "Handling task %s"

    invoke-static {v6, v4}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;

    new-array v4, v5, [Ljava/lang/Throwable;

    invoke-virtual {v2, v4}, Landroidx/work/o;->a([Ljava/lang/Throwable;)V

    .line 4
    invoke-virtual {p1}, Lcom/google/android/gms/gcm/TaskParams;->getTag()Ljava/lang/String;

    move-result-object p1

    const/4 v2, 0x2

    if-eqz p1, :cond_125

    .line 5
    invoke-virtual {p1}, Ljava/lang/String;->isEmpty()Z

    move-result v4

    if-eqz v4, :cond_2f

    goto/16 :goto_125

    .line 6
    :cond_2f
    new-instance v4, Landroidx/work/impl/background/gcm/d$b;

    invoke-direct {v4, p1}, Landroidx/work/impl/background/gcm/d$b;-><init>(Ljava/lang/String;)V

    .line 7
    new-instance v6, Landroidx/work/impl/background/gcm/d$c;

    iget-object v7, v0, Landroidx/work/impl/background/gcm/d;->c:Landroidx/work/impl/l;

    invoke-direct {v6, v7}, Landroidx/work/impl/background/gcm/d$c;-><init>(Landroidx/work/impl/l;)V

    .line 8
    iget-object v7, v7, Landroidx/work/impl/l;->f:Landroidx/work/impl/d;

    .line 9
    invoke-virtual {v7, v4}, Landroidx/work/impl/d;->a(Landroidx/work/impl/b;)V

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

    aput-object p1, v8, v5

    const-string v9, "WorkGcm-onRunTask (%s)"

    .line 10
    invoke-static {v9, v8}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;

    move-result-object v8

    .line 11
    iget-object v9, v0, Landroidx/work/impl/background/gcm/d;->a:Landroid/content/Context;

    invoke-static {v9, v8}, Landroidx/work/impl/utils/l;->a(Landroid/content/Context;Ljava/lang/String;)Landroid/os/PowerManager$WakeLock;

    move-result-object v8

    .line 12
    iget-object v9, v0, Landroidx/work/impl/background/gcm/d;->c:Landroidx/work/impl/l;

    invoke-virtual {v9, p1}, Landroidx/work/impl/l;->h(Ljava/lang/String;)V

    .line 13
    iget-object v9, v0, Landroidx/work/impl/background/gcm/d;->b:Landroidx/work/impl/utils/q;

    invoke-virtual {v9, p1, v6}, Landroidx/work/impl/utils/q;->a(Ljava/lang/String;Landroidx/work/impl/utils/q$b;)V

    .line 14
    :try_start_5a
    invoke-virtual {v8}, Landroid/os/PowerManager$WakeLock;->acquire()V

    .line 15
    iget-object v6, v4, Landroidx/work/impl/background/gcm/d$b;->b:Ljava/util/concurrent/CountDownLatch;

    const-wide/16 v9, 0xa

    .line 16
    sget-object v11, Ljava/util/concurrent/TimeUnit;->MINUTES:Ljava/util/concurrent/TimeUnit;

    invoke-virtual {v6, v9, v10, v11}, Ljava/util/concurrent/CountDownLatch;->await(JLjava/util/concurrent/TimeUnit;)Z
    :try_end_66
    .catch Ljava/lang/InterruptedException; {:try_start_5a .. :try_end_66} :catch_f8
    .catchall {:try_start_5a .. :try_end_66} :catchall_f6

    .line 17
    invoke-virtual {v7, v4}, Landroidx/work/impl/d;->e(Landroidx/work/impl/b;)V

    .line 18
    iget-object v6, v0, Landroidx/work/impl/background/gcm/d;->b:Landroidx/work/impl/utils/q;

    invoke-virtual {v6, p1}, Landroidx/work/impl/utils/q;->b(Ljava/lang/String;)V

    .line 19
    invoke-virtual {v8}, Landroid/os/PowerManager$WakeLock;->release()V

    .line 20
    iget-boolean v4, v4, Landroidx/work/impl/background/gcm/d$b;->c:Z

    if-eqz v4, :cond_8a

    .line 21
    invoke-static {}, Landroidx/work/o;->c()Landroidx/work/o;

    move-result-object v2

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

    aput-object p1, v3, v5

    invoke-static {v1, v3}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;

    new-array v1, v5, [Ljava/lang/Throwable;

    invoke-virtual {v2, v1}, Landroidx/work/o;->a([Ljava/lang/Throwable;)V

    .line 22
    invoke-virtual {v0, p1}, Landroidx/work/impl/background/gcm/d;->a(Ljava/lang/String;)V

    goto/16 :goto_12f

    .line 23
    :cond_8a
    iget-object v1, v0, Landroidx/work/impl/background/gcm/d;->c:Landroidx/work/impl/l;

    .line 24
    iget-object v1, v1, Landroidx/work/impl/l;->c:Landroidx/work/impl/WorkDatabase;

    .line 25
    invoke-virtual {v1}, Landroidx/work/impl/WorkDatabase;->f()Landroidx/work/impl/model/q;

    move-result-object v1

    check-cast v1, Landroidx/work/impl/model/r;

    invoke-virtual {v1, p1}, Landroidx/work/impl/model/r;->h(Ljava/lang/String;)Landroidx/work/impl/model/p;

    move-result-object v1

    if-eqz v1, :cond_9d

    .line 26
    iget-object v1, v1, Landroidx/work/impl/model/p;->b:Landroidx/work/u;

    goto :goto_9e

    :cond_9d
    const/4 v1, 0x0

    :goto_9e
    if-nez v1, :cond_b4

    .line 27
    invoke-static {}, Landroidx/work/o;->c()Landroidx/work/o;

    move-result-object v0

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

    aput-object p1, v1, v5

    const-string p1, "WorkSpec %s does not exist"

    invoke-static {p1, v1}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;

    new-array p1, v5, [Ljava/lang/Throwable;

    invoke-virtual {v0, p1}, Landroidx/work/o;->a([Ljava/lang/Throwable;)V

    goto/16 :goto_12e

    .line 28
    :cond_b4
    sget-object v4, Landroidx/work/impl/background/gcm/d$a;->a:[I

    invoke-virtual {v1}, Ljava/lang/Enum;->ordinal()I

    move-result v1

    aget v1, v4, v1

    if-eq v1, v3, :cond_e3

    if-eq v1, v2, :cond_e3

    const/4 v4, 0x3

    if-eq v1, v4, :cond_d0

    .line 29
    invoke-static {}, Landroidx/work/o;->c()Landroidx/work/o;

    move-result-object v1

    new-array v2, v5, [Ljava/lang/Throwable;

    invoke-virtual {v1, v2}, Landroidx/work/o;->a([Ljava/lang/Throwable;)V

    .line 30
    invoke-virtual {v0, p1}, Landroidx/work/impl/background/gcm/d;->a(Ljava/lang/String;)V

    goto :goto_12f

    .line 31
    :cond_d0
    invoke-static {}, Landroidx/work/o;->c()Landroidx/work/o;

    move-result-object v0

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

    aput-object p1, v1, v5

    const-string p1, "Returning RESULT_FAILURE for WorkSpec %s"

    .line 32
    invoke-static {p1, v1}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;

    new-array p1, v5, [Ljava/lang/Throwable;

    .line 33
    invoke-virtual {v0, p1}, Landroidx/work/o;->a([Ljava/lang/Throwable;)V

    goto :goto_12e

    .line 34
    :cond_e3
    invoke-static {}, Landroidx/work/o;->c()Landroidx/work/o;

    move-result-object v0

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

    aput-object p1, v1, v5

    const-string p1, "Returning RESULT_SUCCESS for WorkSpec %s"

    .line 35
    invoke-static {p1, v1}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;

    new-array p1, v5, [Ljava/lang/Throwable;

    .line 36
    invoke-virtual {v0, p1}, Landroidx/work/o;->a([Ljava/lang/Throwable;)V

    goto :goto_12f

    :catchall_f6
    move-exception v1

    goto :goto_119

    .line 37
    :catch_f8
    :try_start_f8
    invoke-static {}, Landroidx/work/o;->c()Landroidx/work/o;

    move-result-object v2

    sget-object v6, Landroidx/work/impl/background/gcm/d;->d:Ljava/lang/String;

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

    aput-object p1, v3, v5

    invoke-static {v1, v3}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;

    new-array v1, v5, [Ljava/lang/Throwable;

    invoke-virtual {v2, v1}, Landroidx/work/o;->a([Ljava/lang/Throwable;)V

    .line 38
    invoke-virtual {v0, p1}, Landroidx/work/impl/background/gcm/d;->a(Ljava/lang/String;)V
    :try_end_10d
    .catchall {:try_start_f8 .. :try_end_10d} :catchall_f6

    .line 39
    invoke-virtual {v7, v4}, Landroidx/work/impl/d;->e(Landroidx/work/impl/b;)V

    .line 40
    iget-object v0, v0, Landroidx/work/impl/background/gcm/d;->b:Landroidx/work/impl/utils/q;

    invoke-virtual {v0, p1}, Landroidx/work/impl/utils/q;->b(Ljava/lang/String;)V

    .line 41
    invoke-virtual {v8}, Landroid/os/PowerManager$WakeLock;->release()V

    goto :goto_12f

    .line 42
    :goto_119
    invoke-virtual {v7, v4}, Landroidx/work/impl/d;->e(Landroidx/work/impl/b;)V

    .line 43
    iget-object v0, v0, Landroidx/work/impl/background/gcm/d;->b:Landroidx/work/impl/utils/q;

    invoke-virtual {v0, p1}, Landroidx/work/impl/utils/q;->b(Ljava/lang/String;)V

    .line 44
    invoke-virtual {v8}, Landroid/os/PowerManager$WakeLock;->release()V

    .line 45
    throw v1

    .line 46
    :cond_125
    :goto_125
    invoke-static {}, Landroidx/work/o;->c()Landroidx/work/o;

    move-result-object p1

    new-array v0, v5, [Ljava/lang/Throwable;

    invoke-virtual {p1, v0}, Landroidx/work/o;->a([Ljava/lang/Throwable;)V

    :goto_12e
    const/4 v5, 0x2

    :goto_12f
    return v5
.end method