Processor.smali
.class public Landroidx/work/impl/Processor;
.super Ljava/lang/Object;
.source "SourceFile"
# interfaces
.implements Landroidx/work/impl/ExecutionListener;
.implements Landroidx/work/impl/foreground/ForegroundProcessor;
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Landroidx/work/impl/Processor$FutureListener;
}
.end annotation
# static fields
.field private static final FOREGROUND_WAKELOCK_TAG:Ljava/lang/String; = "ProcessorForegroundLck"
.field private static final TAG:Ljava/lang/String;
# instance fields
.field private mAppContext:Landroid/content/Context;
.field private mCancelledIds:Ljava/util/Set;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Set<",
"Ljava/lang/String;",
">;"
}
.end annotation
.end field
.field private mConfiguration:Landroidx/work/Configuration;
.field private mEnqueuedWorkMap:Ljava/util/Map;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Map<",
"Ljava/lang/String;",
"Landroidx/work/impl/WorkerWrapper;",
">;"
}
.end annotation
.end field
.field private mForegroundLock:Landroid/os/PowerManager$WakeLock;
.field private mForegroundWorkMap:Ljava/util/Map;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Map<",
"Ljava/lang/String;",
"Landroidx/work/impl/WorkerWrapper;",
">;"
}
.end annotation
.end field
.field private final mLock:Ljava/lang/Object;
.field private final mOuterListeners:Ljava/util/List;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/List<",
"Landroidx/work/impl/ExecutionListener;",
">;"
}
.end annotation
.end field
.field private mSchedulers:Ljava/util/List;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/List<",
"Landroidx/work/impl/Scheduler;",
">;"
}
.end annotation
.end field
.field private mWorkDatabase:Landroidx/work/impl/WorkDatabase;
.field private mWorkTaskExecutor:Landroidx/work/impl/utils/taskexecutor/TaskExecutor;
# direct methods
.method static constructor <clinit>()V
.registers 1
const-string v0, "Processor"
.line 54
invoke-static {v0}, Landroidx/work/Logger;->tagWithPrefix(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
sput-object v0, Landroidx/work/impl/Processor;->TAG:Ljava/lang/String;
return-void
.end method
.method public constructor <init>(Landroid/content/Context;Landroidx/work/Configuration;Landroidx/work/impl/utils/taskexecutor/TaskExecutor;Landroidx/work/impl/WorkDatabase;Ljava/util/List;)V
.registers 6
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Landroid/content/Context;",
"Landroidx/work/Configuration;",
"Landroidx/work/impl/utils/taskexecutor/TaskExecutor;",
"Landroidx/work/impl/WorkDatabase;",
"Ljava/util/List<",
"Landroidx/work/impl/Scheduler;",
">;)V"
}
.end annotation
.line 78
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 79
iput-object p1, p0, Landroidx/work/impl/Processor;->mAppContext:Landroid/content/Context;
.line 80
iput-object p2, p0, Landroidx/work/impl/Processor;->mConfiguration:Landroidx/work/Configuration;
.line 81
iput-object p3, p0, Landroidx/work/impl/Processor;->mWorkTaskExecutor:Landroidx/work/impl/utils/taskexecutor/TaskExecutor;
.line 82
iput-object p4, p0, Landroidx/work/impl/Processor;->mWorkDatabase:Landroidx/work/impl/WorkDatabase;
.line 83
new-instance p1, Ljava/util/HashMap;
invoke-direct {p1}, Ljava/util/HashMap;-><init>()V
iput-object p1, p0, Landroidx/work/impl/Processor;->mEnqueuedWorkMap:Ljava/util/Map;
.line 84
new-instance p1, Ljava/util/HashMap;
invoke-direct {p1}, Ljava/util/HashMap;-><init>()V
iput-object p1, p0, Landroidx/work/impl/Processor;->mForegroundWorkMap:Ljava/util/Map;
.line 85
iput-object p5, p0, Landroidx/work/impl/Processor;->mSchedulers:Ljava/util/List;
.line 86
new-instance p1, Ljava/util/HashSet;
invoke-direct {p1}, Ljava/util/HashSet;-><init>()V
iput-object p1, p0, Landroidx/work/impl/Processor;->mCancelledIds:Ljava/util/Set;
.line 87
new-instance p1, Ljava/util/ArrayList;
invoke-direct {p1}, Ljava/util/ArrayList;-><init>()V
iput-object p1, p0, Landroidx/work/impl/Processor;->mOuterListeners:Ljava/util/List;
const/4 p1, 0x0
.line 88
iput-object p1, p0, Landroidx/work/impl/Processor;->mForegroundLock:Landroid/os/PowerManager$WakeLock;
.line 89
new-instance p1, Ljava/lang/Object;
invoke-direct {p1}, Ljava/lang/Object;-><init>()V
iput-object p1, p0, Landroidx/work/impl/Processor;->mLock:Ljava/lang/Object;
return-void
.end method
.method private static interrupt(Ljava/lang/String;Landroidx/work/impl/WorkerWrapper;)Z
.registers 6
const/4 v0, 0x1
const/4 v1, 0x0
if-eqz p1, :cond_1d
.line 338
invoke-virtual {p1}, Landroidx/work/impl/WorkerWrapper;->interrupt()V
.line 339
invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger;
move-result-object p1
sget-object v2, Landroidx/work/impl/Processor;->TAG:Ljava/lang/String;
new-array v3, v0, [Ljava/lang/Object;
aput-object p0, v3, v1
const-string p0, "WorkerWrapper interrupted for %s"
invoke-static {p0, v3}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object p0
new-array v1, v1, [Ljava/lang/Throwable;
invoke-virtual {p1, v2, p0, v1}, Landroidx/work/Logger;->debug(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Throwable;)V
return v0
.line 342
:cond_1d
invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger;
move-result-object p1
sget-object v2, Landroidx/work/impl/Processor;->TAG:Ljava/lang/String;
new-array v0, v0, [Ljava/lang/Object;
aput-object p0, v0, v1
const-string p0, "WorkerWrapper could not be found for %s"
invoke-static {p0, v0}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object p0
new-array v0, v1, [Ljava/lang/Throwable;
invoke-virtual {p1, v2, p0, v0}, Landroidx/work/Logger;->debug(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Throwable;)V
return v1
.end method
.method private stopForegroundService()V
.registers 7
.line 308
iget-object v0, p0, Landroidx/work/impl/Processor;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 309
:try_start_3
iget-object v1, p0, Landroidx/work/impl/Processor;->mForegroundWorkMap:Ljava/util/Map;
invoke-interface {v1}, Ljava/util/Map;->isEmpty()Z
move-result v1
xor-int/lit8 v1, v1, 0x1
if-nez v1, :cond_3e
.line 311
invoke-static {}, Landroidx/work/impl/foreground/SystemForegroundService;->getInstance()Landroidx/work/impl/foreground/SystemForegroundService;
move-result-object v1
const/4 v2, 0x0
if-eqz v1, :cond_25
.line 313
invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger;
move-result-object v3
sget-object v4, Landroidx/work/impl/Processor;->TAG:Ljava/lang/String;
const-string v5, "No more foreground work. Stopping SystemForegroundService"
new-array v2, v2, [Ljava/lang/Throwable;
invoke-virtual {v3, v4, v5, v2}, Landroidx/work/Logger;->debug(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Throwable;)V
.line 315
invoke-virtual {v1}, Landroidx/work/impl/foreground/SystemForegroundService;->stopForegroundService()V
goto :goto_32
.line 317
:cond_25
invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger;
move-result-object v1
sget-object v3, Landroidx/work/impl/Processor;->TAG:Ljava/lang/String;
const-string v4, "No more foreground work. SystemForegroundService is already stopped"
new-array v2, v2, [Ljava/lang/Throwable;
invoke-virtual {v1, v3, v4, v2}, Landroidx/work/Logger;->debug(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Throwable;)V
.line 321
:goto_32
iget-object v1, p0, Landroidx/work/impl/Processor;->mForegroundLock:Landroid/os/PowerManager$WakeLock;
if-eqz v1, :cond_3e
.line 322
iget-object v1, p0, Landroidx/work/impl/Processor;->mForegroundLock:Landroid/os/PowerManager$WakeLock;
invoke-virtual {v1}, Landroid/os/PowerManager$WakeLock;->release()V
const/4 v1, 0x0
.line 323
iput-object v1, p0, Landroidx/work/impl/Processor;->mForegroundLock:Landroid/os/PowerManager$WakeLock;
.line 326
:cond_3e
monitor-exit v0
return-void
:catchall_40
move-exception v1
monitor-exit v0
:try_end_42
.catchall {:try_start_3 .. :try_end_42} :catchall_40
throw v1
.end method
# virtual methods
.method public addExecutionListener(Landroidx/work/impl/ExecutionListener;)V
.registers 4
.line 275
iget-object v0, p0, Landroidx/work/impl/Processor;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 276
:try_start_3
iget-object v1, p0, Landroidx/work/impl/Processor;->mOuterListeners:Ljava/util/List;
invoke-interface {v1, p1}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 277
monitor-exit v0
return-void
:catchall_a
move-exception p1
monitor-exit v0
:try_end_c
.catchall {:try_start_3 .. :try_end_c} :catchall_a
throw p1
.end method
.method public hasWork()Z
.registers 3
.line 242
iget-object v0, p0, Landroidx/work/impl/Processor;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 243
:try_start_3
iget-object v1, p0, Landroidx/work/impl/Processor;->mEnqueuedWorkMap:Ljava/util/Map;
invoke-interface {v1}, Ljava/util/Map;->isEmpty()Z
move-result v1
if-eqz v1, :cond_16
iget-object v1, p0, Landroidx/work/impl/Processor;->mForegroundWorkMap:Ljava/util/Map;
.line 244
invoke-interface {v1}, Ljava/util/Map;->isEmpty()Z
move-result v1
if-nez v1, :cond_14
goto :goto_16
:cond_14
const/4 v1, 0x0
goto :goto_17
:cond_16
:goto_16
const/4 v1, 0x1
:goto_17
monitor-exit v0
return v1
:catchall_19
move-exception v1
.line 245
monitor-exit v0
:try_end_1b
.catchall {:try_start_3 .. :try_end_1b} :catchall_19
throw v1
.end method
.method public isCancelled(Ljava/lang/String;)Z
.registers 4
.line 233
iget-object v0, p0, Landroidx/work/impl/Processor;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 234
:try_start_3
iget-object v1, p0, Landroidx/work/impl/Processor;->mCancelledIds:Ljava/util/Set;
invoke-interface {v1, p1}, Ljava/util/Set;->contains(Ljava/lang/Object;)Z
move-result p1
monitor-exit v0
return p1
:catchall_b
move-exception p1
.line 235
monitor-exit v0
:try_end_d
.catchall {:try_start_3 .. :try_end_d} :catchall_b
throw p1
.end method
.method public isEnqueued(Ljava/lang/String;)Z
.registers 4
.line 253
iget-object v0, p0, Landroidx/work/impl/Processor;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 254
:try_start_3
iget-object v1, p0, Landroidx/work/impl/Processor;->mEnqueuedWorkMap:Ljava/util/Map;
invoke-interface {v1, p1}, Ljava/util/Map;->containsKey(Ljava/lang/Object;)Z
move-result v1
if-nez v1, :cond_16
iget-object v1, p0, Landroidx/work/impl/Processor;->mForegroundWorkMap:Ljava/util/Map;
.line 255
invoke-interface {v1, p1}, Ljava/util/Map;->containsKey(Ljava/lang/Object;)Z
move-result p1
if-eqz p1, :cond_14
goto :goto_16
:cond_14
const/4 p1, 0x0
goto :goto_17
:cond_16
:goto_16
const/4 p1, 0x1
:goto_17
monitor-exit v0
return p1
:catchall_19
move-exception p1
.line 256
monitor-exit v0
:try_end_1b
.catchall {:try_start_3 .. :try_end_1b} :catchall_19
throw p1
.end method
.method public isEnqueuedInForeground(Ljava/lang/String;)Z
.registers 4
.line 264
iget-object v0, p0, Landroidx/work/impl/Processor;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 265
:try_start_3
iget-object v1, p0, Landroidx/work/impl/Processor;->mForegroundWorkMap:Ljava/util/Map;
invoke-interface {v1, p1}, Ljava/util/Map;->containsKey(Ljava/lang/Object;)Z
move-result p1
monitor-exit v0
return p1
:catchall_b
move-exception p1
.line 266
monitor-exit v0
:try_end_d
.catchall {:try_start_3 .. :try_end_d} :catchall_b
throw p1
.end method
.method public onExecuted(Ljava/lang/String;Z)V
.registers 11
.line 296
iget-object v0, p0, Landroidx/work/impl/Processor;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 297
:try_start_3
iget-object v1, p0, Landroidx/work/impl/Processor;->mEnqueuedWorkMap:Ljava/util/Map;
invoke-interface {v1, p1}, Ljava/util/Map;->remove(Ljava/lang/Object;)Ljava/lang/Object;
.line 298
invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger;
move-result-object v1
sget-object v2, Landroidx/work/impl/Processor;->TAG:Ljava/lang/String;
const-string v3, "%s %s executed; reschedule = %s"
const/4 v4, 0x3
new-array v4, v4, [Ljava/lang/Object;
.line 299
invoke-virtual {p0}, 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
const/4 v6, 0x0
aput-object v5, v4, v6
const/4 v5, 0x1
aput-object p1, v4, v5
const/4 v5, 0x2
invoke-static {p2}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean;
move-result-object v7
aput-object v7, v4, v5
.line 298
invoke-static {v3, v4}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v3
new-array v4, v6, [Ljava/lang/Throwable;
invoke-virtual {v1, v2, v3, v4}, Landroidx/work/Logger;->debug(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Throwable;)V
.line 301
iget-object v1, p0, Landroidx/work/impl/Processor;->mOuterListeners:Ljava/util/List;
invoke-interface {v1}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v1
:goto_37
invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z
move-result v2
if-eqz v2, :cond_47
invoke-interface {v1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v2
check-cast v2, Landroidx/work/impl/ExecutionListener;
.line 302
invoke-interface {v2, p1, p2}, Landroidx/work/impl/ExecutionListener;->onExecuted(Ljava/lang/String;Z)V
goto :goto_37
.line 304
:cond_47
monitor-exit v0
return-void
:catchall_49
move-exception p1
monitor-exit v0
:try_end_4b
.catchall {:try_start_3 .. :try_end_4b} :catchall_49
goto :goto_4d
:goto_4c
throw p1
:goto_4d
goto :goto_4c
.end method
.method public removeExecutionListener(Landroidx/work/impl/ExecutionListener;)V
.registers 4
.line 286
iget-object v0, p0, Landroidx/work/impl/Processor;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 287
:try_start_3
iget-object v1, p0, Landroidx/work/impl/Processor;->mOuterListeners:Ljava/util/List;
invoke-interface {v1, p1}, Ljava/util/List;->remove(Ljava/lang/Object;)Z
.line 288
monitor-exit v0
return-void
:catchall_a
move-exception p1
monitor-exit v0
:try_end_c
.catchall {:try_start_3 .. :try_end_c} :catchall_a
throw p1
.end method
.method public startForeground(Ljava/lang/String;Landroidx/work/ForegroundInfo;)V
.registers 9
.line 148
iget-object v0, p0, Landroidx/work/impl/Processor;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 149
:try_start_3
invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger;
move-result-object v1
sget-object v2, Landroidx/work/impl/Processor;->TAG:Ljava/lang/String;
const-string v3, "Moving WorkSpec (%s) to the foreground"
const/4 v4, 0x1
new-array v4, v4, [Ljava/lang/Object;
const/4 v5, 0x0
aput-object p1, v4, v5
invoke-static {v3, v4}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v3
new-array v4, v5, [Ljava/lang/Throwable;
invoke-virtual {v1, v2, v3, v4}, Landroidx/work/Logger;->info(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Throwable;)V
.line 151
iget-object v1, p0, Landroidx/work/impl/Processor;->mEnqueuedWorkMap:Ljava/util/Map;
invoke-interface {v1, p1}, Ljava/util/Map;->remove(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v1
check-cast v1, Landroidx/work/impl/WorkerWrapper;
if-eqz v1, :cond_45
.line 153
iget-object v2, p0, Landroidx/work/impl/Processor;->mForegroundLock:Landroid/os/PowerManager$WakeLock;
if-nez v2, :cond_35
.line 154
iget-object v2, p0, Landroidx/work/impl/Processor;->mAppContext:Landroid/content/Context;
const-string v3, "ProcessorForegroundLck"
invoke-static {v2, v3}, Landroidx/work/impl/utils/WakeLocks;->newWakeLock(Landroid/content/Context;Ljava/lang/String;)Landroid/os/PowerManager$WakeLock;
move-result-object v2
iput-object v2, p0, Landroidx/work/impl/Processor;->mForegroundLock:Landroid/os/PowerManager$WakeLock;
.line 155
invoke-virtual {v2}, Landroid/os/PowerManager$WakeLock;->acquire()V
.line 157
:cond_35
iget-object v2, p0, Landroidx/work/impl/Processor;->mForegroundWorkMap:Ljava/util/Map;
invoke-interface {v2, p1, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 158
iget-object v1, p0, Landroidx/work/impl/Processor;->mAppContext:Landroid/content/Context;
invoke-static {v1, p1, p2}, Landroidx/work/impl/foreground/SystemForegroundDispatcher;->createStartForegroundIntent(Landroid/content/Context;Ljava/lang/String;Landroidx/work/ForegroundInfo;)Landroid/content/Intent;
move-result-object p1
.line 159
iget-object p2, p0, Landroidx/work/impl/Processor;->mAppContext:Landroid/content/Context;
invoke-static {p2, p1}, Landroidx/core/content/ContextCompat;->startForegroundService(Landroid/content/Context;Landroid/content/Intent;)V
.line 161
:cond_45
monitor-exit v0
return-void
:catchall_47
move-exception p1
monitor-exit v0
:try_end_49
.catchall {:try_start_3 .. :try_end_49} :catchall_47
throw p1
.end method
.method public startWork(Ljava/lang/String;)Z
.registers 3
const/4 v0, 0x0
.line 99
invoke-virtual {p0, p1, v0}, Landroidx/work/impl/Processor;->startWork(Ljava/lang/String;Landroidx/work/WorkerParameters$RuntimeExtras;)Z
move-result p1
return p1
.end method
.method public startWork(Ljava/lang/String;Landroidx/work/WorkerParameters$RuntimeExtras;)Z
.registers 14
.line 114
iget-object v0, p0, Landroidx/work/impl/Processor;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 117
:try_start_3
iget-object v1, p0, Landroidx/work/impl/Processor;->mEnqueuedWorkMap:Ljava/util/Map;
invoke-interface {v1, p1}, Ljava/util/Map;->containsKey(Ljava/lang/Object;)Z
move-result v1
const/4 v2, 0x1
const/4 v3, 0x0
if-eqz v1, :cond_24
.line 118
invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger;
move-result-object p2
sget-object v1, Landroidx/work/impl/Processor;->TAG:Ljava/lang/String;
const-string v4, "Work %s is already enqueued for processing"
new-array v2, v2, [Ljava/lang/Object;
aput-object p1, v2, v3
.line 120
invoke-static {v4, v2}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object p1
new-array v2, v3, [Ljava/lang/Throwable;
.line 118
invoke-virtual {p2, v1, p1, v2}, Landroidx/work/Logger;->debug(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Throwable;)V
.line 121
monitor-exit v0
return v3
.line 124
:cond_24
new-instance v1, Landroidx/work/impl/WorkerWrapper$Builder;
iget-object v5, p0, Landroidx/work/impl/Processor;->mAppContext:Landroid/content/Context;
iget-object v6, p0, Landroidx/work/impl/Processor;->mConfiguration:Landroidx/work/Configuration;
iget-object v7, p0, Landroidx/work/impl/Processor;->mWorkTaskExecutor:Landroidx/work/impl/utils/taskexecutor/TaskExecutor;
iget-object v9, p0, Landroidx/work/impl/Processor;->mWorkDatabase:Landroidx/work/impl/WorkDatabase;
move-object v4, v1
move-object v8, p0
move-object v10, p1
invoke-direct/range {v4 .. v10}, Landroidx/work/impl/WorkerWrapper$Builder;-><init>(Landroid/content/Context;Landroidx/work/Configuration;Landroidx/work/impl/utils/taskexecutor/TaskExecutor;Landroidx/work/impl/foreground/ForegroundProcessor;Landroidx/work/impl/WorkDatabase;Ljava/lang/String;)V
iget-object v4, p0, Landroidx/work/impl/Processor;->mSchedulers:Ljava/util/List;
.line 132
invoke-virtual {v1, v4}, Landroidx/work/impl/WorkerWrapper$Builder;->withSchedulers(Ljava/util/List;)Landroidx/work/impl/WorkerWrapper$Builder;
move-result-object v1
.line 133
invoke-virtual {v1, p2}, Landroidx/work/impl/WorkerWrapper$Builder;->withRuntimeExtras(Landroidx/work/WorkerParameters$RuntimeExtras;)Landroidx/work/impl/WorkerWrapper$Builder;
move-result-object p2
.line 134
invoke-virtual {p2}, Landroidx/work/impl/WorkerWrapper$Builder;->build()Landroidx/work/impl/WorkerWrapper;
move-result-object p2
.line 135
invoke-virtual {p2}, Landroidx/work/impl/WorkerWrapper;->getFuture()Lcom/google/common/util/concurrent/a;
move-result-object v1
.line 136
new-instance v4, Landroidx/work/impl/Processor$FutureListener;
invoke-direct {v4, p0, p1, v1}, Landroidx/work/impl/Processor$FutureListener;-><init>(Landroidx/work/impl/ExecutionListener;Ljava/lang/String;Lcom/google/common/util/concurrent/a;)V
iget-object v5, p0, Landroidx/work/impl/Processor;->mWorkTaskExecutor:Landroidx/work/impl/utils/taskexecutor/TaskExecutor;
.line 138
invoke-interface {v5}, Landroidx/work/impl/utils/taskexecutor/TaskExecutor;->getMainThreadExecutor()Ljava/util/concurrent/Executor;
move-result-object v5
.line 136
invoke-interface {v1, v4, v5}, Lcom/google/common/util/concurrent/a;->addListener(Ljava/lang/Runnable;Ljava/util/concurrent/Executor;)V
.line 139
iget-object v1, p0, Landroidx/work/impl/Processor;->mEnqueuedWorkMap:Ljava/util/Map;
invoke-interface {v1, p1, p2}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 140
monitor-exit v0
:try_end_5a
.catchall {:try_start_3 .. :try_end_5a} :catchall_84
.line 141
iget-object v0, p0, Landroidx/work/impl/Processor;->mWorkTaskExecutor:Landroidx/work/impl/utils/taskexecutor/TaskExecutor;
invoke-interface {v0}, Landroidx/work/impl/utils/taskexecutor/TaskExecutor;->getBackgroundExecutor()Landroidx/work/impl/utils/SerialExecutor;
move-result-object v0
invoke-virtual {v0, p2}, Landroidx/work/impl/utils/SerialExecutor;->execute(Ljava/lang/Runnable;)V
.line 142
invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger;
move-result-object p2
sget-object v0, Landroidx/work/impl/Processor;->TAG:Ljava/lang/String;
const/4 v1, 0x2
new-array v1, v1, [Ljava/lang/Object;
invoke-virtual {p0}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
move-result-object v4
invoke-virtual {v4}, Ljava/lang/Class;->getSimpleName()Ljava/lang/String;
move-result-object v4
aput-object v4, v1, v3
aput-object p1, v1, v2
const-string p1, "%s: processing %s"
invoke-static {p1, v1}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object p1
new-array v1, v3, [Ljava/lang/Throwable;
invoke-virtual {p2, v0, p1, v1}, Landroidx/work/Logger;->debug(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Throwable;)V
return v2
:catchall_84
move-exception p1
.line 140
:try_start_85
monitor-exit v0
:try_end_86
.catchall {:try_start_85 .. :try_end_86} :catchall_84
throw p1
.end method
.method public stopAndCancelWork(Ljava/lang/String;)Z
.registers 9
.line 199
iget-object v0, p0, Landroidx/work/impl/Processor;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 200
:try_start_3
invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger;
move-result-object v1
sget-object v2, Landroidx/work/impl/Processor;->TAG:Ljava/lang/String;
const-string v3, "Processor cancelling %s"
const/4 v4, 0x1
new-array v5, v4, [Ljava/lang/Object;
const/4 v6, 0x0
aput-object p1, v5, v6
invoke-static {v3, v5}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v3
new-array v5, v6, [Ljava/lang/Throwable;
invoke-virtual {v1, v2, v3, v5}, Landroidx/work/Logger;->debug(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Throwable;)V
.line 201
iget-object v1, p0, Landroidx/work/impl/Processor;->mCancelledIds:Ljava/util/Set;
invoke-interface {v1, p1}, Ljava/util/Set;->add(Ljava/lang/Object;)Z
.line 204
iget-object v1, p0, Landroidx/work/impl/Processor;->mForegroundWorkMap:Ljava/util/Map;
invoke-interface {v1, p1}, Ljava/util/Map;->remove(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v1
check-cast v1, Landroidx/work/impl/WorkerWrapper;
if-eqz v1, :cond_2a
goto :goto_2b
:cond_2a
const/4 v4, 0x0
:goto_2b
if-nez v1, :cond_35
.line 208
iget-object v1, p0, Landroidx/work/impl/Processor;->mEnqueuedWorkMap:Ljava/util/Map;
invoke-interface {v1, p1}, Ljava/util/Map;->remove(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v1
check-cast v1, Landroidx/work/impl/WorkerWrapper;
.line 210
:cond_35
invoke-static {p1, v1}, Landroidx/work/impl/Processor;->interrupt(Ljava/lang/String;Landroidx/work/impl/WorkerWrapper;)Z
move-result p1
if-eqz v4, :cond_3e
.line 212
invoke-direct {p0}, Landroidx/work/impl/Processor;->stopForegroundService()V
.line 214
:cond_3e
monitor-exit v0
return p1
:catchall_40
move-exception p1
.line 215
monitor-exit v0
:try_end_42
.catchall {:try_start_3 .. :try_end_42} :catchall_40
throw p1
.end method
.method public stopForeground(Ljava/lang/String;)V
.registers 4
.line 220
iget-object v0, p0, Landroidx/work/impl/Processor;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 221
:try_start_3
iget-object v1, p0, Landroidx/work/impl/Processor;->mForegroundWorkMap:Ljava/util/Map;
invoke-interface {v1, p1}, Ljava/util/Map;->remove(Ljava/lang/Object;)Ljava/lang/Object;
.line 222
invoke-direct {p0}, Landroidx/work/impl/Processor;->stopForegroundService()V
.line 223
monitor-exit v0
return-void
:catchall_d
move-exception p1
monitor-exit v0
:try_end_f
.catchall {:try_start_3 .. :try_end_f} :catchall_d
throw p1
.end method
.method public stopForegroundWork(Ljava/lang/String;)Z
.registers 8
.line 171
iget-object v0, p0, Landroidx/work/impl/Processor;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 172
:try_start_3
invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger;
move-result-object v1
sget-object v2, Landroidx/work/impl/Processor;->TAG:Ljava/lang/String;
const-string v3, "Processor stopping foreground work %s"
const/4 v4, 0x1
new-array v4, v4, [Ljava/lang/Object;
const/4 v5, 0x0
aput-object p1, v4, v5
invoke-static {v3, v4}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v3
new-array v4, v5, [Ljava/lang/Throwable;
invoke-virtual {v1, v2, v3, v4}, Landroidx/work/Logger;->debug(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Throwable;)V
.line 173
iget-object v1, p0, Landroidx/work/impl/Processor;->mForegroundWorkMap:Ljava/util/Map;
invoke-interface {v1, p1}, Ljava/util/Map;->remove(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v1
check-cast v1, Landroidx/work/impl/WorkerWrapper;
.line 174
invoke-static {p1, v1}, Landroidx/work/impl/Processor;->interrupt(Ljava/lang/String;Landroidx/work/impl/WorkerWrapper;)Z
move-result p1
monitor-exit v0
return p1
:catchall_28
move-exception p1
.line 175
monitor-exit v0
:try_end_2a
.catchall {:try_start_3 .. :try_end_2a} :catchall_28
throw p1
.end method
.method public stopWork(Ljava/lang/String;)Z
.registers 8
.line 185
iget-object v0, p0, Landroidx/work/impl/Processor;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 186
:try_start_3
invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger;
move-result-object v1
sget-object v2, Landroidx/work/impl/Processor;->TAG:Ljava/lang/String;
const-string v3, "Processor stopping background work %s"
const/4 v4, 0x1
new-array v4, v4, [Ljava/lang/Object;
const/4 v5, 0x0
aput-object p1, v4, v5
invoke-static {v3, v4}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v3
new-array v4, v5, [Ljava/lang/Throwable;
invoke-virtual {v1, v2, v3, v4}, Landroidx/work/Logger;->debug(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Throwable;)V
.line 187
iget-object v1, p0, Landroidx/work/impl/Processor;->mEnqueuedWorkMap:Ljava/util/Map;
invoke-interface {v1, p1}, Ljava/util/Map;->remove(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v1
check-cast v1, Landroidx/work/impl/WorkerWrapper;
.line 188
invoke-static {p1, v1}, Landroidx/work/impl/Processor;->interrupt(Ljava/lang/String;Landroidx/work/impl/WorkerWrapper;)Z
move-result p1
monitor-exit v0
return p1
:catchall_28
move-exception p1
.line 189
monitor-exit v0
:try_end_2a
.catchall {:try_start_3 .. :try_end_2a} :catchall_28
throw p1
.end method