GreedyScheduler.smali
.class public Landroidx/work/impl/background/greedy/GreedyScheduler;
.super Ljava/lang/Object;
.source "SourceFile"
# interfaces
.implements Landroidx/work/impl/ExecutionListener;
.implements Landroidx/work/impl/Scheduler;
.implements Landroidx/work/impl/constraints/WorkConstraintsCallback;
# static fields
.field private static final TAG:Ljava/lang/String;
# instance fields
.field private mConstrainedWorkSpecs:Ljava/util/List;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/List<",
"Landroidx/work/impl/model/WorkSpec;",
">;"
}
.end annotation
.end field
.field private final mContext:Landroid/content/Context;
.field private mIsMainProcess:Ljava/lang/Boolean;
.field private final mLock:Ljava/lang/Object;
.field private mRegisteredExecutionListener:Z
.field private final mWorkConstraintsTracker:Landroidx/work/impl/constraints/WorkConstraintsTracker;
.field private final mWorkManagerImpl:Landroidx/work/impl/WorkManagerImpl;
# direct methods
.method static constructor <clinit>()V
.registers 1
const-string v0, "GreedyScheduler"
.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/background/greedy/GreedyScheduler;->TAG:Ljava/lang/String;
return-void
.end method
.method public constructor <init>(Landroid/content/Context;Landroidx/work/impl/WorkManagerImpl;Landroidx/work/impl/constraints/WorkConstraintsTracker;)V
.registers 5
.line 80
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 59
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
iput-object v0, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mConstrainedWorkSpecs:Ljava/util/List;
.line 81
iput-object p1, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mContext:Landroid/content/Context;
.line 82
iput-object p2, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mWorkManagerImpl:Landroidx/work/impl/WorkManagerImpl;
.line 83
iput-object p3, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mWorkConstraintsTracker:Landroidx/work/impl/constraints/WorkConstraintsTracker;
.line 84
new-instance p1, Ljava/lang/Object;
invoke-direct {p1}, Ljava/lang/Object;-><init>()V
iput-object p1, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mLock:Ljava/lang/Object;
return-void
.end method
.method public constructor <init>(Landroid/content/Context;Landroidx/work/impl/utils/taskexecutor/TaskExecutor;Landroidx/work/impl/WorkManagerImpl;)V
.registers 5
.line 69
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 59
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
iput-object v0, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mConstrainedWorkSpecs:Ljava/util/List;
.line 70
iput-object p1, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mContext:Landroid/content/Context;
.line 71
iput-object p3, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mWorkManagerImpl:Landroidx/work/impl/WorkManagerImpl;
.line 72
new-instance p3, Landroidx/work/impl/constraints/WorkConstraintsTracker;
invoke-direct {p3, p1, p2, p0}, Landroidx/work/impl/constraints/WorkConstraintsTracker;-><init>(Landroid/content/Context;Landroidx/work/impl/utils/taskexecutor/TaskExecutor;Landroidx/work/impl/constraints/WorkConstraintsCallback;)V
iput-object p3, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mWorkConstraintsTracker:Landroidx/work/impl/constraints/WorkConstraintsTracker;
.line 73
new-instance p1, Ljava/lang/Object;
invoke-direct {p1}, Ljava/lang/Object;-><init>()V
iput-object p1, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mLock:Ljava/lang/Object;
return-void
.end method
.method private getProcessName()Ljava/lang/String;
.registers 5
.line 215
invoke-static {}, Landroid/os/Process;->myPid()I
move-result v0
.line 216
iget-object v1, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mContext:Landroid/content/Context;
const-string v2, "activity"
.line 217
invoke-virtual {v1, v2}, Landroid/content/Context;->getSystemService(Ljava/lang/String;)Ljava/lang/Object;
move-result-object v1
check-cast v1, Landroid/app/ActivityManager;
if-eqz v1, :cond_33
.line 220
invoke-virtual {v1}, Landroid/app/ActivityManager;->getRunningAppProcesses()Ljava/util/List;
move-result-object v1
if-eqz v1, :cond_33
.line 221
invoke-interface {v1}, Ljava/util/List;->isEmpty()Z
move-result v2
if-nez v2, :cond_33
.line 222
invoke-interface {v1}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v1
:cond_20
invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z
move-result v2
if-eqz v2, :cond_33
invoke-interface {v1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v2
check-cast v2, Landroid/app/ActivityManager$RunningAppProcessInfo;
.line 223
iget v3, v2, Landroid/app/ActivityManager$RunningAppProcessInfo;->pid:I
if-ne v3, v0, :cond_20
.line 224
iget-object v0, v2, Landroid/app/ActivityManager$RunningAppProcessInfo;->processName:Ljava/lang/String;
return-object v0
:cond_33
const/4 v0, 0x0
return-object v0
.end method
.method private registerExecutionListenerIfNeeded()V
.registers 2
.line 207
iget-boolean v0, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mRegisteredExecutionListener:Z
if-nez v0, :cond_10
.line 208
iget-object v0, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mWorkManagerImpl:Landroidx/work/impl/WorkManagerImpl;
invoke-virtual {v0}, Landroidx/work/impl/WorkManagerImpl;->getProcessor()Landroidx/work/impl/Processor;
move-result-object v0
invoke-virtual {v0, p0}, Landroidx/work/impl/Processor;->addExecutionListener(Landroidx/work/impl/ExecutionListener;)V
const/4 v0, 0x1
.line 209
iput-boolean v0, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mRegisteredExecutionListener:Z
:cond_10
return-void
.end method
.method private removeConstraintTrackingFor(Ljava/lang/String;)V
.registers 9
.line 189
iget-object v0, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mLock:Ljava/lang/Object;
monitor-enter v0
.line 193
:try_start_3
iget-object v1, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mConstrainedWorkSpecs:Ljava/util/List;
invoke-interface {v1}, Ljava/util/List;->size()I
move-result v1
const/4 v2, 0x0
const/4 v3, 0x0
:goto_b
if-ge v3, v1, :cond_43
.line 194
iget-object v4, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mConstrainedWorkSpecs:Ljava/util/List;
invoke-interface {v4, v3}, Ljava/util/List;->get(I)Ljava/lang/Object;
move-result-object v4
check-cast v4, Landroidx/work/impl/model/WorkSpec;
iget-object v4, v4, Landroidx/work/impl/model/WorkSpec;->id:Ljava/lang/String;
invoke-virtual {v4, p1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z
move-result v4
if-eqz v4, :cond_40
.line 195
invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger;
move-result-object v1
sget-object v4, Landroidx/work/impl/background/greedy/GreedyScheduler;->TAG:Ljava/lang/String;
const-string v5, "Stopping tracking for %s"
const/4 v6, 0x1
new-array v6, v6, [Ljava/lang/Object;
aput-object p1, v6, v2
invoke-static {v5, v6}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object p1
new-array v2, v2, [Ljava/lang/Throwable;
invoke-virtual {v1, v4, p1, v2}, Landroidx/work/Logger;->debug(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Throwable;)V
.line 196
iget-object p1, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mConstrainedWorkSpecs:Ljava/util/List;
invoke-interface {p1, v3}, Ljava/util/List;->remove(I)Ljava/lang/Object;
.line 197
iget-object p1, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mWorkConstraintsTracker:Landroidx/work/impl/constraints/WorkConstraintsTracker;
iget-object v1, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mConstrainedWorkSpecs:Ljava/util/List;
invoke-virtual {p1, v1}, Landroidx/work/impl/constraints/WorkConstraintsTracker;->replace(Ljava/lang/Iterable;)V
goto :goto_43
:cond_40
add-int/lit8 v3, v3, 0x1
goto :goto_b
.line 201
:cond_43
:goto_43
monitor-exit v0
return-void
:catchall_45
move-exception p1
monitor-exit v0
:try_end_47
.catchall {:try_start_3 .. :try_end_47} :catchall_45
goto :goto_49
:goto_48
throw p1
:goto_49
goto :goto_48
.end method
# virtual methods
.method public cancel(Ljava/lang/String;)V
.registers 7
.line 148
iget-object v0, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mIsMainProcess:Ljava/lang/Boolean;
if-nez v0, :cond_18
.line 150
iget-object v0, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mContext:Landroid/content/Context;
invoke-virtual {v0}, Landroid/content/Context;->getPackageName()Ljava/lang/String;
move-result-object v0
invoke-direct {p0}, Landroidx/work/impl/background/greedy/GreedyScheduler;->getProcessName()Ljava/lang/String;
move-result-object v1
invoke-static {v0, v1}, Landroid/text/TextUtils;->equals(Ljava/lang/CharSequence;Ljava/lang/CharSequence;)Z
move-result v0
invoke-static {v0}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean;
move-result-object v0
iput-object v0, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mIsMainProcess:Ljava/lang/Boolean;
.line 153
:cond_18
iget-object v0, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mIsMainProcess:Ljava/lang/Boolean;
invoke-virtual {v0}, Ljava/lang/Boolean;->booleanValue()Z
move-result v0
const/4 v1, 0x0
if-nez v0, :cond_2f
.line 154
invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger;
move-result-object p1
sget-object v0, Landroidx/work/impl/background/greedy/GreedyScheduler;->TAG:Ljava/lang/String;
new-array v1, v1, [Ljava/lang/Throwable;
const-string v2, "Ignoring schedule request in non-main process"
invoke-virtual {p1, v0, v2, v1}, Landroidx/work/Logger;->info(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Throwable;)V
return-void
.line 158
:cond_2f
invoke-direct {p0}, Landroidx/work/impl/background/greedy/GreedyScheduler;->registerExecutionListenerIfNeeded()V
.line 159
invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger;
move-result-object v0
sget-object v2, Landroidx/work/impl/background/greedy/GreedyScheduler;->TAG:Ljava/lang/String;
const/4 v3, 0x1
new-array v3, v3, [Ljava/lang/Object;
aput-object p1, v3, v1
const-string v4, "Cancelling work ID %s"
invoke-static {v4, v3}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v3
new-array v1, v1, [Ljava/lang/Throwable;
invoke-virtual {v0, v2, v3, v1}, Landroidx/work/Logger;->debug(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Throwable;)V
.line 161
iget-object v0, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mWorkManagerImpl:Landroidx/work/impl/WorkManagerImpl;
invoke-virtual {v0, p1}, Landroidx/work/impl/WorkManagerImpl;->stopWork(Ljava/lang/String;)V
return-void
.end method
.method public onAllConstraintsMet(Ljava/util/List;)V
.registers 8
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/List<",
"Ljava/lang/String;",
">;)V"
}
.end annotation
.line 166
invoke-interface {p1}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object p1
:goto_4
invoke-interface {p1}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_2d
invoke-interface {p1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/lang/String;
.line 167
invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger;
move-result-object v1
sget-object v2, Landroidx/work/impl/background/greedy/GreedyScheduler;->TAG:Ljava/lang/String;
const/4 v3, 0x1
new-array v3, v3, [Ljava/lang/Object;
const/4 v4, 0x0
aput-object v0, v3, v4
const-string v5, "Constraints met: Scheduling work ID %s"
.line 169
invoke-static {v5, v3}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v3
new-array v4, v4, [Ljava/lang/Throwable;
.line 167
invoke-virtual {v1, v2, v3, v4}, Landroidx/work/Logger;->debug(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Throwable;)V
.line 170
iget-object v1, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mWorkManagerImpl:Landroidx/work/impl/WorkManagerImpl;
invoke-virtual {v1, v0}, Landroidx/work/impl/WorkManagerImpl;->startWork(Ljava/lang/String;)V
goto :goto_4
:cond_2d
return-void
.end method
.method public onAllConstraintsNotMet(Ljava/util/List;)V
.registers 8
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Ljava/util/List<",
"Ljava/lang/String;",
">;)V"
}
.end annotation
.line 176
invoke-interface {p1}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object p1
:goto_4
invoke-interface {p1}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_2d
invoke-interface {p1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/lang/String;
.line 177
invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger;
move-result-object v1
sget-object v2, Landroidx/work/impl/background/greedy/GreedyScheduler;->TAG:Ljava/lang/String;
const/4 v3, 0x1
new-array v3, v3, [Ljava/lang/Object;
const/4 v4, 0x0
aput-object v0, v3, v4
const-string v5, "Constraints not met: Cancelling work ID %s"
.line 178
invoke-static {v5, v3}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v3
new-array v4, v4, [Ljava/lang/Throwable;
.line 177
invoke-virtual {v1, v2, v3, v4}, Landroidx/work/Logger;->debug(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Throwable;)V
.line 179
iget-object v1, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mWorkManagerImpl:Landroidx/work/impl/WorkManagerImpl;
invoke-virtual {v1, v0}, Landroidx/work/impl/WorkManagerImpl;->stopWork(Ljava/lang/String;)V
goto :goto_4
:cond_2d
return-void
.end method
.method public onExecuted(Ljava/lang/String;Z)V
.registers 3
.line 185
invoke-direct {p0, p1}, Landroidx/work/impl/background/greedy/GreedyScheduler;->removeConstraintTrackingFor(Ljava/lang/String;)V
return-void
.end method
.method public varargs schedule([Landroidx/work/impl/model/WorkSpec;)V
.registers 14
.line 89
iget-object v0, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mIsMainProcess:Ljava/lang/Boolean;
if-nez v0, :cond_18
.line 91
iget-object v0, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mContext:Landroid/content/Context;
invoke-virtual {v0}, Landroid/content/Context;->getPackageName()Ljava/lang/String;
move-result-object v0
invoke-direct {p0}, Landroidx/work/impl/background/greedy/GreedyScheduler;->getProcessName()Ljava/lang/String;
move-result-object v1
invoke-static {v0, v1}, Landroid/text/TextUtils;->equals(Ljava/lang/CharSequence;Ljava/lang/CharSequence;)Z
move-result v0
invoke-static {v0}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean;
move-result-object v0
iput-object v0, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mIsMainProcess:Ljava/lang/Boolean;
.line 94
:cond_18
iget-object v0, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mIsMainProcess:Ljava/lang/Boolean;
invoke-virtual {v0}, Ljava/lang/Boolean;->booleanValue()Z
move-result v0
const/4 v1, 0x0
if-nez v0, :cond_2f
.line 95
invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger;
move-result-object p1
sget-object v0, Landroidx/work/impl/background/greedy/GreedyScheduler;->TAG:Ljava/lang/String;
new-array v1, v1, [Ljava/lang/Throwable;
const-string v2, "Ignoring schedule request in non-main process"
invoke-virtual {p1, v0, v2, v1}, Landroidx/work/Logger;->info(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Throwable;)V
return-void
.line 99
:cond_2f
invoke-direct {p0}, Landroidx/work/impl/background/greedy/GreedyScheduler;->registerExecutionListenerIfNeeded()V
.line 105
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
.line 106
new-instance v2, Ljava/util/ArrayList;
invoke-direct {v2}, Ljava/util/ArrayList;-><init>()V
.line 107
array-length v3, p1
const/4 v4, 0x0
:goto_3e
const/4 v5, 0x1
if-ge v4, v3, :cond_d6
aget-object v6, p1, v4
.line 108
iget-object v7, v6, Landroidx/work/impl/model/WorkSpec;->state:Landroidx/work/WorkInfo$State;
sget-object v8, Landroidx/work/WorkInfo$State;->ENQUEUED:Landroidx/work/WorkInfo$State;
if-ne v7, v8, :cond_d2
.line 109
invoke-virtual {v6}, Landroidx/work/impl/model/WorkSpec;->isPeriodic()Z
move-result v7
if-nez v7, :cond_d2
iget-wide v7, v6, Landroidx/work/impl/model/WorkSpec;->initialDelay:J
const-wide/16 v9, 0x0
cmp-long v11, v7, v9
if-nez v11, :cond_d2
.line 111
invoke-virtual {v6}, Landroidx/work/impl/model/WorkSpec;->isBackedOff()Z
move-result v7
if-nez v7, :cond_d2
.line 112
invoke-virtual {v6}, Landroidx/work/impl/model/WorkSpec;->hasConstraints()Z
move-result v7
if-eqz v7, :cond_b4
.line 113
sget v7, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v8, 0x17
if-lt v7, v8, :cond_87
iget-object v7, v6, Landroidx/work/impl/model/WorkSpec;->constraints:Landroidx/work/Constraints;
invoke-virtual {v7}, Landroidx/work/Constraints;->requiresDeviceIdle()Z
move-result v7
if-eqz v7, :cond_87
.line 115
invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger;
move-result-object v7
sget-object v8, Landroidx/work/impl/background/greedy/GreedyScheduler;->TAG:Ljava/lang/String;
new-array v5, v5, [Ljava/lang/Object;
aput-object v6, v5, v1
const-string v6, "Ignoring WorkSpec %s, Requires device idle."
.line 116
invoke-static {v6, v5}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v5
new-array v6, v1, [Ljava/lang/Throwable;
.line 115
invoke-virtual {v7, v8, v5, v6}, Landroidx/work/Logger;->debug(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Throwable;)V
goto :goto_d2
.line 118
:cond_87
sget v7, Landroid/os/Build$VERSION;->SDK_INT:I
const/16 v8, 0x18
if-lt v7, v8, :cond_ab
iget-object v7, v6, Landroidx/work/impl/model/WorkSpec;->constraints:Landroidx/work/Constraints;
invoke-virtual {v7}, Landroidx/work/Constraints;->hasContentUriTriggers()Z
move-result v7
if-eqz v7, :cond_ab
.line 120
invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger;
move-result-object v7
sget-object v8, Landroidx/work/impl/background/greedy/GreedyScheduler;->TAG:Ljava/lang/String;
new-array v5, v5, [Ljava/lang/Object;
aput-object v6, v5, v1
const-string v6, "Ignoring WorkSpec %s, Requires ContentUri triggers."
.line 121
invoke-static {v6, v5}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v5
new-array v6, v1, [Ljava/lang/Throwable;
.line 120
invoke-virtual {v7, v8, v5, v6}, Landroidx/work/Logger;->debug(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Throwable;)V
goto :goto_d2
.line 124
:cond_ab
invoke-interface {v0, v6}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 125
iget-object v5, v6, Landroidx/work/impl/model/WorkSpec;->id:Ljava/lang/String;
invoke-interface {v2, v5}, Ljava/util/List;->add(Ljava/lang/Object;)Z
goto :goto_d2
.line 128
:cond_b4
invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger;
move-result-object v7
sget-object v8, Landroidx/work/impl/background/greedy/GreedyScheduler;->TAG:Ljava/lang/String;
new-array v5, v5, [Ljava/lang/Object;
iget-object v9, v6, Landroidx/work/impl/model/WorkSpec;->id:Ljava/lang/String;
aput-object v9, v5, v1
const-string v9, "Starting work for %s"
invoke-static {v9, v5}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v5
new-array v9, v1, [Ljava/lang/Throwable;
invoke-virtual {v7, v8, v5, v9}, Landroidx/work/Logger;->debug(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Throwable;)V
.line 129
iget-object v5, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mWorkManagerImpl:Landroidx/work/impl/WorkManagerImpl;
iget-object v6, v6, Landroidx/work/impl/model/WorkSpec;->id:Ljava/lang/String;
invoke-virtual {v5, v6}, Landroidx/work/impl/WorkManagerImpl;->startWork(Ljava/lang/String;)V
:cond_d2
:goto_d2
add-int/lit8 v4, v4, 0x1
goto/16 :goto_3e
.line 136
:cond_d6
iget-object p1, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mLock:Ljava/lang/Object;
monitor-enter p1
.line 137
:try_start_d9
invoke-interface {v0}, Ljava/util/List;->isEmpty()Z
move-result v3
if-nez v3, :cond_106
.line 138
invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger;
move-result-object v3
sget-object v4, Landroidx/work/impl/background/greedy/GreedyScheduler;->TAG:Ljava/lang/String;
const-string v6, "Starting tracking for [%s]"
new-array v5, v5, [Ljava/lang/Object;
const-string v7, ","
.line 139
invoke-static {v7, v2}, Landroid/text/TextUtils;->join(Ljava/lang/CharSequence;Ljava/lang/Iterable;)Ljava/lang/String;
move-result-object v2
aput-object v2, v5, v1
.line 138
invoke-static {v6, v5}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v2
new-array v1, v1, [Ljava/lang/Throwable;
invoke-virtual {v3, v4, v2, v1}, Landroidx/work/Logger;->debug(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Throwable;)V
.line 140
iget-object v1, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mConstrainedWorkSpecs:Ljava/util/List;
invoke-interface {v1, v0}, Ljava/util/List;->addAll(Ljava/util/Collection;)Z
.line 141
iget-object v0, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mWorkConstraintsTracker:Landroidx/work/impl/constraints/WorkConstraintsTracker;
iget-object v1, p0, Landroidx/work/impl/background/greedy/GreedyScheduler;->mConstrainedWorkSpecs:Ljava/util/List;
invoke-virtual {v0, v1}, Landroidx/work/impl/constraints/WorkConstraintsTracker;->replace(Ljava/lang/Iterable;)V
.line 143
:cond_106
monitor-exit p1
return-void
:catchall_108
move-exception v0
monitor-exit p1
:try_end_10a
.catchall {:try_start_d9 .. :try_end_10a} :catchall_108
goto :goto_10c
:goto_10b
throw v0
:goto_10c
goto :goto_10b
.end method