.class public Landroidx/work/impl/background/systemjob/SystemJobScheduler; .super Ljava/lang/Object; .source "SourceFile" # interfaces .implements Landroidx/work/impl/Scheduler; # annotations .annotation build Landroidx/annotation/RequiresApi; value = 0x17 .end annotation .annotation build Landroidx/annotation/RestrictTo; value = { .enum Landroidx/annotation/RestrictTo$Scope;->LIBRARY_GROUP:Landroidx/annotation/RestrictTo$Scope; } .end annotation # static fields .field private static final TAG:Ljava/lang/String; # instance fields .field private final mConfiguration:Landroidx/work/Configuration; .field private final mContext:Landroid/content/Context; .field private final mJobScheduler:Landroid/app/job/JobScheduler; .field private final mSystemJobInfoConverter:Landroidx/work/impl/background/systemjob/SystemJobInfoConverter; .field private final mWorkDatabase:Landroidx/work/impl/WorkDatabase; # direct methods .method static constructor ()V .locals 1 const-string v0, "SystemJobScheduler" .line 68 invoke-static {v0}, Landroidx/work/Logger;->tagWithPrefix(Ljava/lang/String;)Ljava/lang/String; move-result-object v0 sput-object v0, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->TAG:Ljava/lang/String; return-void .end method .method public constructor (Landroid/content/Context;Landroidx/work/impl/WorkDatabase;Landroidx/work/Configuration;)V .locals 6 .param p1 # Landroid/content/Context; .annotation build Landroidx/annotation/NonNull; .end annotation .end param .param p2 # Landroidx/work/impl/WorkDatabase; .annotation build Landroidx/annotation/NonNull; .end annotation .end param .param p3 # Landroidx/work/Configuration; .annotation build Landroidx/annotation/NonNull; .end annotation .end param .line 82 invoke-static {p1}, Landroidx/work/impl/background/systemjob/JobSchedulerExtKt;->getWmJobScheduler(Landroid/content/Context;)Landroid/app/job/JobScheduler; move-result-object v4 new-instance v5, Landroidx/work/impl/background/systemjob/SystemJobInfoConverter; .line 83 invoke-virtual {p3}, Landroidx/work/Configuration;->getClock()Landroidx/work/Clock; move-result-object v0 .line 84 invoke-virtual {p3}, Landroidx/work/Configuration;->isMarkingJobsAsImportantWhileForeground()Z move-result v1 invoke-direct {v5, p1, v0, v1}, Landroidx/work/impl/background/systemjob/SystemJobInfoConverter;->(Landroid/content/Context;Landroidx/work/Clock;Z)V move-object v0, p0 move-object v1, p1 move-object v2, p2 move-object v3, p3 .line 79 invoke-direct/range {v0 .. v5}, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->(Landroid/content/Context;Landroidx/work/impl/WorkDatabase;Landroidx/work/Configuration;Landroid/app/job/JobScheduler;Landroidx/work/impl/background/systemjob/SystemJobInfoConverter;)V return-void .end method .method public constructor (Landroid/content/Context;Landroidx/work/impl/WorkDatabase;Landroidx/work/Configuration;Landroid/app/job/JobScheduler;Landroidx/work/impl/background/systemjob/SystemJobInfoConverter;)V .locals 0 .param p1 # Landroid/content/Context; .annotation build Landroidx/annotation/NonNull; .end annotation .end param .param p2 # Landroidx/work/impl/WorkDatabase; .annotation build Landroidx/annotation/NonNull; .end annotation .end param .param p3 # Landroidx/work/Configuration; .annotation build Landroidx/annotation/NonNull; .end annotation .end param .param p4 # Landroid/app/job/JobScheduler; .annotation build Landroidx/annotation/NonNull; .end annotation .end param .param p5 # Landroidx/work/impl/background/systemjob/SystemJobInfoConverter; .annotation build Landroidx/annotation/NonNull; .end annotation .end param .annotation build Landroidx/annotation/VisibleForTesting; .end annotation .line 94 invoke-direct {p0}, Ljava/lang/Object;->()V iput-object p1, p0, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->mContext:Landroid/content/Context; iput-object p4, p0, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->mJobScheduler:Landroid/app/job/JobScheduler; iput-object p5, p0, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->mSystemJobInfoConverter:Landroidx/work/impl/background/systemjob/SystemJobInfoConverter; iput-object p2, p0, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->mWorkDatabase:Landroidx/work/impl/WorkDatabase; iput-object p3, p0, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->mConfiguration:Landroidx/work/Configuration; return-void .end method .method public static cancelAllInAllNamespaces(Landroid/content/Context;)V .locals 2 .param p0 # Landroid/content/Context; .annotation build Landroidx/annotation/NonNull; .end annotation .end param sget v0, Landroid/os/Build$VERSION;->SDK_INT:I const/16 v1, 0x22 if-lt v0, v1, :cond_0 .line 273 invoke-static {p0}, Landroidx/work/impl/background/systemjob/JobSchedulerExtKt;->getWmJobScheduler(Landroid/content/Context;)Landroid/app/job/JobScheduler; move-result-object v0 .line 274 invoke-virtual {v0}, Landroid/app/job/JobScheduler;->cancelAll()V :cond_0 const-string v0, "jobscheduler" .line 281 invoke-virtual {p0, v0}, Landroid/content/Context;->getSystemService(Ljava/lang/String;)Ljava/lang/Object; move-result-object v0 check-cast v0, Landroid/app/job/JobScheduler; .line 282 invoke-static {p0, v0}, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->getPendingJobs(Landroid/content/Context;Landroid/app/job/JobScheduler;)Ljava/util/List; move-result-object p0 if-eqz p0, :cond_1 .line 283 invoke-interface {p0}, Ljava/util/List;->isEmpty()Z move-result v1 if-nez v1, :cond_1 .line 284 invoke-interface {p0}, Ljava/util/List;->iterator()Ljava/util/Iterator; move-result-object p0 :goto_0 invoke-interface {p0}, Ljava/util/Iterator;->hasNext()Z move-result v1 if-eqz v1, :cond_1 invoke-interface {p0}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v1 check-cast v1, Landroid/app/job/JobInfo; .line 285 invoke-virtual {v1}, Landroid/app/job/JobInfo;->getId()I move-result v1 invoke-static {v0, v1}, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->cancelJobById(Landroid/app/job/JobScheduler;I)V goto :goto_0 :cond_1 return-void .end method .method private static cancelJobById(Landroid/app/job/JobScheduler;I)V .locals 4 .param p0 # Landroid/app/job/JobScheduler; .annotation build Landroidx/annotation/NonNull; .end annotation .end param .line 253 :try_start_0 invoke-virtual {p0, p1}, Landroid/app/job/JobScheduler;->cancel(I)V :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 goto :goto_0 :catchall_0 move-exception p0 .line 256 invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger; move-result-object v0 sget-object v1, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->TAG:Ljava/lang/String; .line 258 invoke-static {}, Ljava/util/Locale;->getDefault()Ljava/util/Locale; move-result-object v2 .line 260 invoke-static {p1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer; move-result-object p1 filled-new-array {p1}, [Ljava/lang/Object; move-result-object p1 const-string v3, "Exception while trying to cancel job (%d)" .line 257 invoke-static {v2, v3, p1}, Ljava/lang/String;->format(Ljava/util/Locale;Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String; move-result-object p1 .line 256 invoke-virtual {v0, v1, p1, p0}, Landroidx/work/Logger;->error(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V :goto_0 return-void .end method .method private static getPendingJobIds(Landroid/content/Context;Landroid/app/job/JobScheduler;Ljava/lang/String;)Ljava/util/List; .locals 2 .param p0 # Landroid/content/Context; .annotation build Landroidx/annotation/NonNull; .end annotation .end param .param p1 # Landroid/app/job/JobScheduler; .annotation build Landroidx/annotation/NonNull; .end annotation .end param .param p2 # Ljava/lang/String; .annotation build Landroidx/annotation/NonNull; .end annotation .end param .annotation build Landroidx/annotation/Nullable; .end annotation .annotation system Ldalvik/annotation/Signature; value = { "(", "Landroid/content/Context;", "Landroid/app/job/JobScheduler;", "Ljava/lang/String;", ")", "Ljava/util/List<", "Ljava/lang/Integer;", ">;" } .end annotation .line 392 invoke-static {p0, p1}, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->getPendingJobs(Landroid/content/Context;Landroid/app/job/JobScheduler;)Ljava/util/List; move-result-object p0 if-nez p0, :cond_0 const/4 p0, 0x0 return-object p0 .line 398 :cond_0 new-instance p1, Ljava/util/ArrayList; const/4 v0, 0x2 invoke-direct {p1, v0}, Ljava/util/ArrayList;->(I)V .line 400 invoke-interface {p0}, Ljava/util/List;->iterator()Ljava/util/Iterator; move-result-object p0 :cond_1 :goto_0 invoke-interface {p0}, Ljava/util/Iterator;->hasNext()Z move-result v0 if-eqz v0, :cond_2 invoke-interface {p0}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v0 check-cast v0, Landroid/app/job/JobInfo; .line 401 invoke-static {v0}, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->getWorkGenerationalIdFromJobInfo(Landroid/app/job/JobInfo;)Landroidx/work/impl/model/WorkGenerationalId; move-result-object v1 if-eqz v1, :cond_1 .line 402 invoke-virtual {v1}, Landroidx/work/impl/model/WorkGenerationalId;->getWorkSpecId()Ljava/lang/String; move-result-object v1 invoke-virtual {p2, v1}, Ljava/lang/String;->equals(Ljava/lang/Object;)Z move-result v1 if-eqz v1, :cond_1 .line 403 invoke-virtual {v0}, Landroid/app/job/JobInfo;->getId()I move-result v0 invoke-static {v0}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer; move-result-object v0 invoke-interface {p1, v0}, Ljava/util/List;->add(Ljava/lang/Object;)Z goto :goto_0 :cond_2 return-object p1 .end method .method public static getPendingJobs(Landroid/content/Context;Landroid/app/job/JobScheduler;)Ljava/util/List; .locals 3 .param p0 # Landroid/content/Context; .annotation build Landroidx/annotation/NonNull; .end annotation .end param .param p1 # Landroid/app/job/JobScheduler; .annotation build Landroidx/annotation/NonNull; .end annotation .end param .annotation build Landroidx/annotation/Nullable; .end annotation .annotation system Ldalvik/annotation/Signature; value = { "(", "Landroid/content/Context;", "Landroid/app/job/JobScheduler;", ")", "Ljava/util/List<", "Landroid/app/job/JobInfo;", ">;" } .end annotation .line 364 invoke-static {p1}, Landroidx/work/impl/background/systemjob/JobSchedulerExtKt;->getSafePendingJobs(Landroid/app/job/JobScheduler;)Ljava/util/List; move-result-object p1 if-nez p1, :cond_0 const/4 p0, 0x0 return-object p0 .line 370 :cond_0 new-instance v0, Ljava/util/ArrayList; invoke-interface {p1}, Ljava/util/List;->size()I move-result v1 invoke-direct {v0, v1}, Ljava/util/ArrayList;->(I)V .line 371 new-instance v1, Landroid/content/ComponentName; const-class v2, Landroidx/work/impl/background/systemjob/SystemJobService; invoke-direct {v1, p0, v2}, Landroid/content/ComponentName;->(Landroid/content/Context;Ljava/lang/Class;)V .line 372 invoke-interface {p1}, Ljava/util/List;->iterator()Ljava/util/Iterator; move-result-object p0 :cond_1 :goto_0 invoke-interface {p0}, Ljava/util/Iterator;->hasNext()Z move-result p1 if-eqz p1, :cond_2 invoke-interface {p0}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object p1 check-cast p1, Landroid/app/job/JobInfo; .line 373 invoke-virtual {p1}, Landroid/app/job/JobInfo;->getService()Landroid/content/ComponentName; move-result-object v2 invoke-virtual {v1, v2}, Landroid/content/ComponentName;->equals(Ljava/lang/Object;)Z move-result v2 if-eqz v2, :cond_1 .line 374 invoke-interface {v0, p1}, Ljava/util/List;->add(Ljava/lang/Object;)Z goto :goto_0 :cond_2 return-object v0 .end method .method private static getWorkGenerationalIdFromJobInfo(Landroid/app/job/JobInfo;)Landroidx/work/impl/model/WorkGenerationalId; .locals 3 .param p0 # Landroid/app/job/JobInfo; .annotation build Landroidx/annotation/NonNull; .end annotation .end param .annotation build Landroidx/annotation/Nullable; .end annotation const-string v0, "EXTRA_WORK_SPEC_ID" .line 412 invoke-virtual {p0}, Landroid/app/job/JobInfo;->getExtras()Landroid/os/PersistableBundle; move-result-object p0 if-eqz p0, :cond_0 .line 414 :try_start_0 invoke-virtual {p0, v0}, Landroid/os/BaseBundle;->containsKey(Ljava/lang/String;)Z move-result v1 if-eqz v1, :cond_0 const-string v1, "EXTRA_WORK_SPEC_GENERATION" const/4 v2, 0x0 .line 415 invoke-virtual {p0, v1, v2}, Landroid/os/BaseBundle;->getInt(Ljava/lang/String;I)I move-result v1 .line 416 new-instance v2, Landroidx/work/impl/model/WorkGenerationalId; invoke-virtual {p0, v0}, Landroid/os/BaseBundle;->getString(Ljava/lang/String;)Ljava/lang/String; move-result-object p0 invoke-direct {v2, p0, v1}, Landroidx/work/impl/model/WorkGenerationalId;->(Ljava/lang/String;I)V :try_end_0 .catch Ljava/lang/NullPointerException; {:try_start_0 .. :try_end_0} :catch_0 return-object v2 :catch_0 :cond_0 const/4 p0, 0x0 return-object p0 .end method .method public static reconcileJobs(Landroid/content/Context;Landroidx/work/impl/WorkDatabase;)Z .locals 6 .param p0 # Landroid/content/Context; .annotation build Landroidx/annotation/NonNull; .end annotation .end param .param p1 # Landroidx/work/impl/WorkDatabase; .annotation build Landroidx/annotation/NonNull; .end annotation .end param .line 310 invoke-static {p0}, Landroidx/work/impl/background/systemjob/JobSchedulerExtKt;->getWmJobScheduler(Landroid/content/Context;)Landroid/app/job/JobScheduler; move-result-object v0 .line 311 invoke-static {p0, v0}, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->getPendingJobs(Landroid/content/Context;Landroid/app/job/JobScheduler;)Ljava/util/List; move-result-object p0 .line 313 invoke-virtual {p1}, Landroidx/work/impl/WorkDatabase;->systemIdInfoDao()Landroidx/work/impl/model/SystemIdInfoDao; move-result-object v1 invoke-interface {v1}, Landroidx/work/impl/model/SystemIdInfoDao;->getWorkSpecIds()Ljava/util/List; move-result-object v1 const/4 v2, 0x0 if-eqz p0, :cond_0 .line 315 invoke-interface {p0}, Ljava/util/List;->size()I move-result v3 goto :goto_0 :cond_0 move v3, v2 .line 316 :goto_0 new-instance v4, Ljava/util/HashSet; invoke-direct {v4, v3}, Ljava/util/HashSet;->(I)V if-eqz p0, :cond_2 .line 317 invoke-interface {p0}, Ljava/util/List;->isEmpty()Z move-result v3 if-nez v3, :cond_2 .line 318 invoke-interface {p0}, Ljava/util/List;->iterator()Ljava/util/Iterator; move-result-object p0 :goto_1 invoke-interface {p0}, Ljava/util/Iterator;->hasNext()Z move-result v3 if-eqz v3, :cond_2 invoke-interface {p0}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v3 check-cast v3, Landroid/app/job/JobInfo; .line 319 invoke-static {v3}, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->getWorkGenerationalIdFromJobInfo(Landroid/app/job/JobInfo;)Landroidx/work/impl/model/WorkGenerationalId; move-result-object v5 if-eqz v5, :cond_1 .line 321 invoke-virtual {v5}, Landroidx/work/impl/model/WorkGenerationalId;->getWorkSpecId()Ljava/lang/String; move-result-object v3 invoke-interface {v4, v3}, Ljava/util/Set;->add(Ljava/lang/Object;)Z goto :goto_1 .line 327 :cond_1 invoke-virtual {v3}, Landroid/app/job/JobInfo;->getId()I move-result v3 invoke-static {v0, v3}, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->cancelJobById(Landroid/app/job/JobScheduler;I)V goto :goto_1 .line 332 :cond_2 invoke-interface {v1}, Ljava/util/List;->iterator()Ljava/util/Iterator; move-result-object p0 :cond_3 invoke-interface {p0}, Ljava/util/Iterator;->hasNext()Z move-result v0 if-eqz v0, :cond_4 invoke-interface {p0}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v0 check-cast v0, Ljava/lang/String; .line 333 invoke-interface {v4, v0}, Ljava/util/Set;->contains(Ljava/lang/Object;)Z move-result v0 if-nez v0, :cond_3 .line 334 invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger; move-result-object p0 sget-object v0, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->TAG:Ljava/lang/String; const-string v2, "Reconciling jobs" invoke-virtual {p0, v0, v2}, Landroidx/work/Logger;->debug(Ljava/lang/String;Ljava/lang/String;)V const/4 v2, 0x1 :cond_4 if-eqz v2, :cond_6 .line 341 invoke-virtual {p1}, Landroidx/room/RoomDatabase;->beginTransaction()V .line 343 :try_start_0 invoke-virtual {p1}, Landroidx/work/impl/WorkDatabase;->workSpecDao()Landroidx/work/impl/model/WorkSpecDao; move-result-object p0 .line 344 invoke-interface {v1}, Ljava/util/List;->iterator()Ljava/util/Iterator; move-result-object v0 :goto_2 invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z move-result v1 if-eqz v1, :cond_5 invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v1 check-cast v1, Ljava/lang/String; const-wide/16 v3, -0x1 .line 350 invoke-interface {p0, v1, v3, v4}, Landroidx/work/impl/model/WorkSpecDao;->markWorkSpecScheduled(Ljava/lang/String;J)I goto :goto_2 :catchall_0 move-exception p0 goto :goto_3 .line 352 :cond_5 invoke-virtual {p1}, Landroidx/room/RoomDatabase;->setTransactionSuccessful()V :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 .line 354 invoke-virtual {p1}, Landroidx/room/RoomDatabase;->endTransaction()V goto :goto_4 :goto_3 invoke-virtual {p1}, Landroidx/room/RoomDatabase;->endTransaction()V .line 355 throw p0 :cond_6 :goto_4 return v2 .end method # virtual methods .method public cancel(Ljava/lang/String;)V .locals 3 .param p1 # Ljava/lang/String; .annotation build Landroidx/annotation/NonNull; .end annotation .end param iget-object v0, p0, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->mContext:Landroid/content/Context; iget-object v1, p0, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->mJobScheduler:Landroid/app/job/JobScheduler; .line 235 invoke-static {v0, v1, p1}, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->getPendingJobIds(Landroid/content/Context;Landroid/app/job/JobScheduler;Ljava/lang/String;)Ljava/util/List; move-result-object v0 if-eqz v0, :cond_1 .line 236 invoke-interface {v0}, Ljava/util/List;->isEmpty()Z move-result v1 if-nez v1, :cond_1 .line 237 invoke-interface {v0}, Ljava/util/List;->iterator()Ljava/util/Iterator; move-result-object v0 :goto_0 invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z move-result v1 if-eqz v1, :cond_0 invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v1 check-cast v1, Ljava/lang/Integer; invoke-virtual {v1}, Ljava/lang/Integer;->intValue()I move-result v1 iget-object v2, p0, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->mJobScheduler:Landroid/app/job/JobScheduler; .line 238 invoke-static {v2, v1}, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->cancelJobById(Landroid/app/job/JobScheduler;I)V goto :goto_0 :cond_0 iget-object v0, p0, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->mWorkDatabase:Landroidx/work/impl/WorkDatabase; .line 242 invoke-virtual {v0}, Landroidx/work/impl/WorkDatabase;->systemIdInfoDao()Landroidx/work/impl/model/SystemIdInfoDao; move-result-object v0 invoke-interface {v0, p1}, Landroidx/work/impl/model/SystemIdInfoDao;->removeSystemIdInfo(Ljava/lang/String;)V :cond_1 return-void .end method .method public hasLimitedSchedulingSlots()Z .locals 1 const/4 v0, 0x1 return v0 .end method .method public varargs schedule([Landroidx/work/impl/model/WorkSpec;)V .locals 8 .param p1 # [Landroidx/work/impl/model/WorkSpec; .annotation build Landroidx/annotation/NonNull; .end annotation .end param .line 104 new-instance v0, Landroidx/work/impl/utils/IdGenerator; iget-object v1, p0, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->mWorkDatabase:Landroidx/work/impl/WorkDatabase; invoke-direct {v0, v1}, Landroidx/work/impl/utils/IdGenerator;->(Landroidx/work/impl/WorkDatabase;)V .line 106 array-length v1, p1 const/4 v2, 0x0 :goto_0 if-ge v2, v1, :cond_4 aget-object v3, p1, v2 iget-object v4, p0, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->mWorkDatabase:Landroidx/work/impl/WorkDatabase; .line 107 invoke-virtual {v4}, Landroidx/room/RoomDatabase;->beginTransaction()V :try_start_0 iget-object v4, p0, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->mWorkDatabase:Landroidx/work/impl/WorkDatabase; .line 109 invoke-virtual {v4}, Landroidx/work/impl/WorkDatabase;->workSpecDao()Landroidx/work/impl/model/WorkSpecDao; move-result-object v4 iget-object v5, v3, Landroidx/work/impl/model/WorkSpec;->id:Ljava/lang/String; invoke-interface {v4, v5}, Landroidx/work/impl/model/WorkSpecDao;->getWorkSpec(Ljava/lang/String;)Landroidx/work/impl/model/WorkSpec; move-result-object v4 :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 const-string v5, "Skipping scheduling " if-nez v4, :cond_0 .line 111 :try_start_1 invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger; move-result-object v4 sget-object v6, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->TAG:Ljava/lang/String; new-instance v7, Ljava/lang/StringBuilder; invoke-direct {v7}, Ljava/lang/StringBuilder;->()V invoke-virtual {v7, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; iget-object v3, v3, Landroidx/work/impl/model/WorkSpec;->id:Ljava/lang/String; invoke-virtual {v7, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string v3, " because it\'s no longer in the DB" invoke-virtual {v7, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v7}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v3 invoke-virtual {v4, v6, v3}, Landroidx/work/Logger;->warning(Ljava/lang/String;Ljava/lang/String;)V iget-object v3, p0, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->mWorkDatabase:Landroidx/work/impl/WorkDatabase; .line 118 invoke-virtual {v3}, Landroidx/room/RoomDatabase;->setTransactionSuccessful()V :try_end_1 .catchall {:try_start_1 .. :try_end_1} :catchall_0 :goto_1 iget-object v3, p0, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->mWorkDatabase:Landroidx/work/impl/WorkDatabase; .line 180 invoke-virtual {v3}, Landroidx/room/RoomDatabase;->endTransaction()V goto :goto_3 :catchall_0 move-exception p1 goto :goto_4 .line 120 :cond_0 :try_start_2 iget-object v4, v4, Landroidx/work/impl/model/WorkSpec;->state:Landroidx/work/WorkInfo$State; sget-object v6, Landroidx/work/WorkInfo$State;->ENQUEUED:Landroidx/work/WorkInfo$State; if-eq v4, v6, :cond_1 .line 121 invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger; move-result-object v4 sget-object v6, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->TAG:Ljava/lang/String; new-instance v7, Ljava/lang/StringBuilder; invoke-direct {v7}, Ljava/lang/StringBuilder;->()V invoke-virtual {v7, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; iget-object v3, v3, Landroidx/work/impl/model/WorkSpec;->id:Ljava/lang/String; invoke-virtual {v7, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string v3, " because it is no longer enqueued" invoke-virtual {v7, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v7}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v3 invoke-virtual {v4, v6, v3}, Landroidx/work/Logger;->warning(Ljava/lang/String;Ljava/lang/String;)V iget-object v3, p0, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->mWorkDatabase:Landroidx/work/impl/WorkDatabase; .line 128 invoke-virtual {v3}, Landroidx/room/RoomDatabase;->setTransactionSuccessful()V goto :goto_1 .line 131 :cond_1 invoke-static {v3}, Landroidx/work/impl/model/WorkSpecKt;->generationalId(Landroidx/work/impl/model/WorkSpec;)Landroidx/work/impl/model/WorkGenerationalId; move-result-object v4 iget-object v5, p0, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->mWorkDatabase:Landroidx/work/impl/WorkDatabase; .line 132 invoke-virtual {v5}, Landroidx/work/impl/WorkDatabase;->systemIdInfoDao()Landroidx/work/impl/model/SystemIdInfoDao; move-result-object v5 invoke-interface {v5, v4}, Landroidx/work/impl/model/SystemIdInfoDao;->getSystemIdInfo(Landroidx/work/impl/model/WorkGenerationalId;)Landroidx/work/impl/model/SystemIdInfo; move-result-object v5 if-eqz v5, :cond_2 .line 134 iget v6, v5, Landroidx/work/impl/model/SystemIdInfo;->systemId:I goto :goto_2 :cond_2 iget-object v6, p0, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->mConfiguration:Landroidx/work/Configuration; .line 135 invoke-virtual {v6}, Landroidx/work/Configuration;->getMinJobSchedulerId()I move-result v6 iget-object v7, p0, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->mConfiguration:Landroidx/work/Configuration; .line 136 invoke-virtual {v7}, Landroidx/work/Configuration;->getMaxJobSchedulerId()I move-result v7 .line 134 invoke-virtual {v0, v6, v7}, Landroidx/work/impl/utils/IdGenerator;->nextJobSchedulerIdWithRange(II)I move-result v6 :goto_2 if-nez v5, :cond_3 .line 139 invoke-static {v4, v6}, Landroidx/work/impl/model/SystemIdInfoKt;->systemIdInfo(Landroidx/work/impl/model/WorkGenerationalId;I)Landroidx/work/impl/model/SystemIdInfo; move-result-object v4 iget-object v5, p0, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->mWorkDatabase:Landroidx/work/impl/WorkDatabase; .line 140 invoke-virtual {v5}, Landroidx/work/impl/WorkDatabase;->systemIdInfoDao()Landroidx/work/impl/model/SystemIdInfoDao; move-result-object v5 invoke-interface {v5, v4}, Landroidx/work/impl/model/SystemIdInfoDao;->insertSystemIdInfo(Landroidx/work/impl/model/SystemIdInfo;)V .line 143 :cond_3 invoke-virtual {p0, v3, v6}, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->scheduleInternal(Landroidx/work/impl/model/WorkSpec;I)V iget-object v3, p0, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->mWorkDatabase:Landroidx/work/impl/WorkDatabase; .line 178 invoke-virtual {v3}, Landroidx/room/RoomDatabase;->setTransactionSuccessful()V :try_end_2 .catchall {:try_start_2 .. :try_end_2} :catchall_0 goto :goto_1 :goto_3 add-int/lit8 v2, v2, 0x1 goto/16 :goto_0 :goto_4 iget-object v0, p0, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->mWorkDatabase:Landroidx/work/impl/WorkDatabase; .line 180 invoke-virtual {v0}, Landroidx/room/RoomDatabase;->endTransaction()V .line 181 throw p1 :cond_4 return-void .end method .method public scheduleInternal(Landroidx/work/impl/model/WorkSpec;I)V .locals 5 .param p1 # Landroidx/work/impl/model/WorkSpec; .annotation build Landroidx/annotation/NonNull; .end annotation .end param .annotation build Landroidx/annotation/VisibleForTesting; .end annotation iget-object v0, p0, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->mSystemJobInfoConverter:Landroidx/work/impl/background/systemjob/SystemJobInfoConverter; .line 192 invoke-virtual {v0, p1, p2}, Landroidx/work/impl/background/systemjob/SystemJobInfoConverter;->convert(Landroidx/work/impl/model/WorkSpec;I)Landroid/app/job/JobInfo; move-result-object v0 .line 193 invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger; move-result-object v1 sget-object v2, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->TAG:Ljava/lang/String; new-instance v3, Ljava/lang/StringBuilder; invoke-direct {v3}, Ljava/lang/StringBuilder;->()V const-string v4, "Scheduling work ID " invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; iget-object v4, p1, Landroidx/work/impl/model/WorkSpec;->id:Ljava/lang/String; invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; const-string v4, "Job ID " invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v3, p2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder; invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v3 invoke-virtual {v1, v2, v3}, Landroidx/work/Logger;->debug(Ljava/lang/String;Ljava/lang/String;)V :try_start_0 iget-object v1, p0, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->mJobScheduler:Landroid/app/job/JobScheduler; .line 197 invoke-virtual {v1, v0}, Landroid/app/job/JobScheduler;->schedule(Landroid/app/job/JobInfo;)I move-result v0 if-nez v0, :cond_0 .line 199 invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger; move-result-object v0 new-instance v1, Ljava/lang/StringBuilder; invoke-direct {v1}, Ljava/lang/StringBuilder;->()V const-string v3, "Unable to schedule work ID " invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; iget-object v3, p1, Landroidx/work/impl/model/WorkSpec;->id:Ljava/lang/String; invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v1 invoke-virtual {v0, v2, v1}, Landroidx/work/Logger;->warning(Ljava/lang/String;Ljava/lang/String;)V .line 200 iget-boolean v0, p1, Landroidx/work/impl/model/WorkSpec;->expedited:Z if-eqz v0, :cond_0 iget-object v0, p1, Landroidx/work/impl/model/WorkSpec;->outOfQuotaPolicy:Landroidx/work/OutOfQuotaPolicy; sget-object v1, Landroidx/work/OutOfQuotaPolicy;->RUN_AS_NON_EXPEDITED_WORK_REQUEST:Landroidx/work/OutOfQuotaPolicy; if-ne v0, v1, :cond_0 const/4 v0, 0x0 .line 203 iput-boolean v0, p1, Landroidx/work/impl/model/WorkSpec;->expedited:Z const-string v1, "Scheduling a non-expedited job (work ID %s)" const/4 v3, 0x1 new-array v3, v3, [Ljava/lang/Object; .line 204 iget-object v4, p1, Landroidx/work/impl/model/WorkSpec;->id:Ljava/lang/String; aput-object v4, v3, v0 invoke-static {v1, v3}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String; move-result-object v0 .line 206 invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger; move-result-object v1 invoke-virtual {v1, v2, v0}, Landroidx/work/Logger;->debug(Ljava/lang/String;Ljava/lang/String;)V .line 207 invoke-virtual {p0, p1, p2}, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->scheduleInternal(Landroidx/work/impl/model/WorkSpec;I)V :try_end_0 .catch Ljava/lang/IllegalStateException; {:try_start_0 .. :try_end_0} :catch_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 goto :goto_2 :catchall_0 move-exception p2 goto :goto_0 :catch_0 move-exception p1 goto :goto_1 .line 229 :goto_0 invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger; move-result-object v0 sget-object v1, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->TAG:Ljava/lang/String; new-instance v2, Ljava/lang/StringBuilder; invoke-direct {v2}, Ljava/lang/StringBuilder;->()V const-string v3, "Unable to schedule " invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder; invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p1 invoke-virtual {v0, v1, p1, p2}, Landroidx/work/Logger;->error(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V goto :goto_2 :goto_1 iget-object p2, p0, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->mContext:Landroid/content/Context; iget-object v0, p0, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->mWorkDatabase:Landroidx/work/impl/WorkDatabase; iget-object v1, p0, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->mConfiguration:Landroidx/work/Configuration; .line 213 invoke-static {p2, v0, v1}, Landroidx/work/impl/background/systemjob/JobSchedulerExtKt;->createErrorMessage(Landroid/content/Context;Landroidx/work/impl/WorkDatabase;Landroidx/work/Configuration;)Ljava/lang/String; move-result-object p2 .line 214 invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger; move-result-object v0 sget-object v1, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->TAG:Ljava/lang/String; invoke-virtual {v0, v1, p2}, Landroidx/work/Logger;->error(Ljava/lang/String;Ljava/lang/String;)V .line 216 new-instance v0, Ljava/lang/IllegalStateException; invoke-direct {v0, p2, p1}, Ljava/lang/IllegalStateException;->(Ljava/lang/String;Ljava/lang/Throwable;)V iget-object p1, p0, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->mConfiguration:Landroidx/work/Configuration; .line 219 invoke-virtual {p1}, Landroidx/work/Configuration;->getSchedulingExceptionHandler()Landroidx/core/util/Consumer; move-result-object p1 if-eqz p1, :cond_1 .line 221 invoke-interface {p1, v0}, Landroidx/core/util/Consumer;->accept(Ljava/lang/Object;)V :cond_0 :goto_2 return-void .line 224 :cond_1 throw v0 .end method