.class public Landroidx/work/impl/utils/ForceStopRunnable; .super Ljava/lang/Object; .source "SourceFile" # interfaces .implements Ljava/lang/Runnable; # annotations .annotation build Landroidx/annotation/RestrictTo; value = { .enum Landroidx/annotation/RestrictTo$Scope;->LIBRARY_GROUP:Landroidx/annotation/RestrictTo$Scope; } .end annotation .annotation system Ldalvik/annotation/MemberClasses; value = { Landroidx/work/impl/utils/ForceStopRunnable$BroadcastReceiver; } .end annotation # static fields .field static final ACTION_FORCE_STOP_RESCHEDULE:Ljava/lang/String; = "ACTION_FORCE_STOP_RESCHEDULE" .annotation build Landroidx/annotation/VisibleForTesting; .end annotation .end field .field private static final ALARM_ID:I = -0x1 .field private static final BACKOFF_DURATION_MS:J = 0x12cL .field static final MAX_ATTEMPTS:I = 0x3 .annotation build Landroidx/annotation/VisibleForTesting; .end annotation .end field .field private static final TAG:Ljava/lang/String; .field private static final TEN_YEARS:J # instance fields .field private final mContext:Landroid/content/Context; .field private final mPreferenceUtils:Landroidx/work/impl/utils/PreferenceUtils; .field private mRetryCount:I .field private final mWorkManager:Landroidx/work/impl/WorkManagerImpl; # direct methods .method static constructor ()V .locals 3 const-string v0, "ForceStopRunnable" .line 78 invoke-static {v0}, Landroidx/work/Logger;->tagWithPrefix(Ljava/lang/String;)Ljava/lang/String; move-result-object v0 sput-object v0, Landroidx/work/impl/utils/ForceStopRunnable;->TAG:Ljava/lang/String; .line 88 sget-object v0, Ljava/util/concurrent/TimeUnit;->DAYS:Ljava/util/concurrent/TimeUnit; const-wide/16 v1, 0xe42 invoke-virtual {v0, v1, v2}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J move-result-wide v0 sput-wide v0, Landroidx/work/impl/utils/ForceStopRunnable;->TEN_YEARS:J return-void .end method .method public constructor (Landroid/content/Context;Landroidx/work/impl/WorkManagerImpl;)V .locals 0 .param p1 # Landroid/content/Context; .annotation build Landroidx/annotation/NonNull; .end annotation .end param .param p2 # Landroidx/work/impl/WorkManagerImpl; .annotation build Landroidx/annotation/NonNull; .end annotation .end param .line 95 invoke-direct {p0}, Ljava/lang/Object;->()V .line 96 invoke-virtual {p1}, Landroid/content/Context;->getApplicationContext()Landroid/content/Context; move-result-object p1 iput-object p1, p0, Landroidx/work/impl/utils/ForceStopRunnable;->mContext:Landroid/content/Context; iput-object p2, p0, Landroidx/work/impl/utils/ForceStopRunnable;->mWorkManager:Landroidx/work/impl/WorkManagerImpl; .line 98 invoke-virtual {p2}, Landroidx/work/impl/WorkManagerImpl;->getPreferenceUtils()Landroidx/work/impl/utils/PreferenceUtils; move-result-object p1 iput-object p1, p0, Landroidx/work/impl/utils/ForceStopRunnable;->mPreferenceUtils:Landroidx/work/impl/utils/PreferenceUtils; const/4 p1, 0x0 iput p1, p0, Landroidx/work/impl/utils/ForceStopRunnable;->mRetryCount:I return-void .end method .method public static getIntent(Landroid/content/Context;)Landroid/content/Intent; .locals 3 .annotation build Landroidx/annotation/VisibleForTesting; .end annotation .line 382 new-instance v0, Landroid/content/Intent; invoke-direct {v0}, Landroid/content/Intent;->()V .line 383 new-instance v1, Landroid/content/ComponentName; const-class v2, Landroidx/work/impl/utils/ForceStopRunnable$BroadcastReceiver; invoke-direct {v1, p0, v2}, Landroid/content/ComponentName;->(Landroid/content/Context;Ljava/lang/Class;)V invoke-virtual {v0, v1}, Landroid/content/Intent;->setComponent(Landroid/content/ComponentName;)Landroid/content/Intent; const-string p0, "ACTION_FORCE_STOP_RESCHEDULE" .line 384 invoke-virtual {v0, p0}, Landroid/content/Intent;->setAction(Ljava/lang/String;)Landroid/content/Intent; return-object v0 .end method .method private static getPendingIntent(Landroid/content/Context;I)Landroid/app/PendingIntent; .locals 2 .line 373 invoke-static {p0}, Landroidx/work/impl/utils/ForceStopRunnable;->getIntent(Landroid/content/Context;)Landroid/content/Intent; move-result-object v0 const/4 v1, -0x1 .line 374 invoke-static {p0, v1, v0, p1}, Landroid/app/PendingIntent;->getBroadcast(Landroid/content/Context;ILandroid/content/Intent;I)Landroid/app/PendingIntent; move-result-object p0 return-object p0 .end method .method public static setAlarm(Landroid/content/Context;)V .locals 5 .annotation build Landroid/annotation/SuppressLint; value = { "ClassVerificationFailure" } .end annotation const-string v0, "alarm" .line 390 invoke-virtual {p0, v0}, Landroid/content/Context;->getSystemService(Ljava/lang/String;)Ljava/lang/Object; move-result-object v0 check-cast v0, Landroid/app/AlarmManager; sget v1, Landroid/os/Build$VERSION;->SDK_INT:I const/16 v2, 0x1f if-lt v1, v2, :cond_0 const/high16 v1, 0xa000000 goto :goto_0 :cond_0 const/high16 v1, 0x8000000 .line 396 :goto_0 invoke-static {p0, v1}, Landroidx/work/impl/utils/ForceStopRunnable;->getPendingIntent(Landroid/content/Context;I)Landroid/app/PendingIntent; move-result-object p0 .line 399 invoke-static {}, Ljava/lang/System;->currentTimeMillis()J move-result-wide v1 sget-wide v3, Landroidx/work/impl/utils/ForceStopRunnable;->TEN_YEARS:J add-long/2addr v1, v3 if-eqz v0, :cond_1 const/4 v3, 0x0 .line 401 invoke-virtual {v0, v3, v1, v2, p0}, Landroid/app/AlarmManager;->setExact(IJLandroid/app/PendingIntent;)V :cond_1 return-void .end method # virtual methods .method public cleanUp()Z .locals 11 .annotation build Landroidx/annotation/VisibleForTesting; .end annotation iget-object v0, p0, Landroidx/work/impl/utils/ForceStopRunnable;->mContext:Landroid/content/Context; iget-object v1, p0, Landroidx/work/impl/utils/ForceStopRunnable;->mWorkManager:Landroidx/work/impl/WorkManagerImpl; .line 292 invoke-virtual {v1}, Landroidx/work/impl/WorkManagerImpl;->getWorkDatabase()Landroidx/work/impl/WorkDatabase; move-result-object v1 .line 291 invoke-static {v0, v1}, Landroidx/work/impl/background/systemjob/SystemJobScheduler;->reconcileJobs(Landroid/content/Context;Landroidx/work/impl/WorkDatabase;)Z move-result v0 iget-object v1, p0, Landroidx/work/impl/utils/ForceStopRunnable;->mWorkManager:Landroidx/work/impl/WorkManagerImpl; .line 295 invoke-virtual {v1}, Landroidx/work/impl/WorkManagerImpl;->getWorkDatabase()Landroidx/work/impl/WorkDatabase; move-result-object v1 .line 296 invoke-virtual {v1}, Landroidx/work/impl/WorkDatabase;->workSpecDao()Landroidx/work/impl/model/WorkSpecDao; move-result-object v2 .line 297 invoke-virtual {v1}, Landroidx/work/impl/WorkDatabase;->workProgressDao()Landroidx/work/impl/model/WorkProgressDao; move-result-object v3 .line 298 invoke-virtual {v1}, Landroidx/room/RoomDatabase;->beginTransaction()V .line 301 :try_start_0 invoke-interface {v2}, Landroidx/work/impl/model/WorkSpecDao;->getRunningWork()Ljava/util/List; move-result-object v4 const/4 v5, 0x0 const/4 v6, 0x1 if-eqz v4, :cond_0 .line 302 invoke-interface {v4}, Ljava/util/List;->isEmpty()Z move-result v7 if-nez v7, :cond_0 move v7, v6 goto :goto_0 :catchall_0 move-exception v0 goto :goto_2 :cond_0 move v7, v5 :goto_0 if-eqz v7, :cond_1 .line 311 invoke-interface {v4}, Ljava/util/List;->iterator()Ljava/util/Iterator; move-result-object v4 :goto_1 invoke-interface {v4}, Ljava/util/Iterator;->hasNext()Z move-result v8 if-eqz v8, :cond_1 invoke-interface {v4}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v8 check-cast v8, Landroidx/work/impl/model/WorkSpec; .line 312 sget-object v9, Landroidx/work/WorkInfo$State;->ENQUEUED:Landroidx/work/WorkInfo$State; iget-object v10, v8, Landroidx/work/impl/model/WorkSpec;->id:Ljava/lang/String; invoke-interface {v2, v9, v10}, Landroidx/work/impl/model/WorkSpecDao;->setState(Landroidx/work/WorkInfo$State;Ljava/lang/String;)I .line 313 iget-object v9, v8, Landroidx/work/impl/model/WorkSpec;->id:Ljava/lang/String; const/16 v10, -0x200 invoke-interface {v2, v9, v10}, Landroidx/work/impl/model/WorkSpecDao;->setStopReason(Ljava/lang/String;I)V .line 314 iget-object v8, v8, Landroidx/work/impl/model/WorkSpec;->id:Ljava/lang/String; const-wide/16 v9, -0x1 invoke-interface {v2, v8, v9, v10}, Landroidx/work/impl/model/WorkSpecDao;->markWorkSpecScheduled(Ljava/lang/String;J)I goto :goto_1 .line 317 :cond_1 invoke-interface {v3}, Landroidx/work/impl/model/WorkProgressDao;->deleteAll()V .line 318 invoke-virtual {v1}, Landroidx/room/RoomDatabase;->setTransactionSuccessful()V :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 .line 320 invoke-virtual {v1}, Landroidx/room/RoomDatabase;->endTransaction()V if-nez v7, :cond_2 if-eqz v0, :cond_3 :cond_2 move v5, v6 :cond_3 return v5 :goto_2 invoke-virtual {v1}, Landroidx/room/RoomDatabase;->endTransaction()V .line 321 throw v0 .end method .method public forceStopRunnable()V .locals 3 .annotation build Landroidx/annotation/VisibleForTesting; .end annotation .line 254 invoke-virtual {p0}, Landroidx/work/impl/utils/ForceStopRunnable;->cleanUp()Z move-result v0 .line 255 invoke-virtual {p0}, Landroidx/work/impl/utils/ForceStopRunnable;->shouldRescheduleWorkers()Z move-result v1 if-eqz v1, :cond_0 .line 256 invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger; move-result-object v0 sget-object v1, Landroidx/work/impl/utils/ForceStopRunnable;->TAG:Ljava/lang/String; const-string v2, "Rescheduling Workers." invoke-virtual {v0, v1, v2}, Landroidx/work/Logger;->debug(Ljava/lang/String;Ljava/lang/String;)V iget-object v0, p0, Landroidx/work/impl/utils/ForceStopRunnable;->mWorkManager:Landroidx/work/impl/WorkManagerImpl; .line 257 invoke-virtual {v0}, Landroidx/work/impl/WorkManagerImpl;->rescheduleEligibleWork()V iget-object v0, p0, Landroidx/work/impl/utils/ForceStopRunnable;->mWorkManager:Landroidx/work/impl/WorkManagerImpl; .line 259 invoke-virtual {v0}, Landroidx/work/impl/WorkManagerImpl;->getPreferenceUtils()Landroidx/work/impl/utils/PreferenceUtils; move-result-object v0 const/4 v1, 0x0 invoke-virtual {v0, v1}, Landroidx/work/impl/utils/PreferenceUtils;->setNeedsReschedule(Z)V goto :goto_0 .line 260 :cond_0 invoke-virtual {p0}, Landroidx/work/impl/utils/ForceStopRunnable;->isForceStopped()Z move-result v1 if-eqz v1, :cond_1 .line 261 invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger; move-result-object v0 sget-object v1, Landroidx/work/impl/utils/ForceStopRunnable;->TAG:Ljava/lang/String; const-string v2, "Application was force-stopped, rescheduling." invoke-virtual {v0, v1, v2}, Landroidx/work/Logger;->debug(Ljava/lang/String;Ljava/lang/String;)V iget-object v0, p0, Landroidx/work/impl/utils/ForceStopRunnable;->mWorkManager:Landroidx/work/impl/WorkManagerImpl; .line 262 invoke-virtual {v0}, Landroidx/work/impl/WorkManagerImpl;->rescheduleEligibleWork()V iget-object v0, p0, Landroidx/work/impl/utils/ForceStopRunnable;->mPreferenceUtils:Landroidx/work/impl/utils/PreferenceUtils; iget-object v1, p0, Landroidx/work/impl/utils/ForceStopRunnable;->mWorkManager:Landroidx/work/impl/WorkManagerImpl; .line 265 invoke-virtual {v1}, Landroidx/work/impl/WorkManagerImpl;->getConfiguration()Landroidx/work/Configuration; move-result-object v1 invoke-virtual {v1}, Landroidx/work/Configuration;->getClock()Landroidx/work/Clock; move-result-object v1 invoke-interface {v1}, Landroidx/work/Clock;->currentTimeMillis()J move-result-wide v1 .line 264 invoke-virtual {v0, v1, v2}, Landroidx/work/impl/utils/PreferenceUtils;->setLastForceStopEventMillis(J)V goto :goto_0 :cond_1 if-eqz v0, :cond_2 .line 267 invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger; move-result-object v0 sget-object v1, Landroidx/work/impl/utils/ForceStopRunnable;->TAG:Ljava/lang/String; const-string v2, "Found unfinished work, scheduling it." invoke-virtual {v0, v1, v2}, Landroidx/work/Logger;->debug(Ljava/lang/String;Ljava/lang/String;)V iget-object v0, p0, Landroidx/work/impl/utils/ForceStopRunnable;->mWorkManager:Landroidx/work/impl/WorkManagerImpl; .line 269 invoke-virtual {v0}, Landroidx/work/impl/WorkManagerImpl;->getConfiguration()Landroidx/work/Configuration; move-result-object v0 iget-object v1, p0, Landroidx/work/impl/utils/ForceStopRunnable;->mWorkManager:Landroidx/work/impl/WorkManagerImpl; .line 270 invoke-virtual {v1}, Landroidx/work/impl/WorkManagerImpl;->getWorkDatabase()Landroidx/work/impl/WorkDatabase; move-result-object v1 iget-object v2, p0, Landroidx/work/impl/utils/ForceStopRunnable;->mWorkManager:Landroidx/work/impl/WorkManagerImpl; .line 271 invoke-virtual {v2}, Landroidx/work/impl/WorkManagerImpl;->getSchedulers()Ljava/util/List; move-result-object v2 .line 268 invoke-static {v0, v1, v2}, Landroidx/work/impl/Schedulers;->schedule(Landroidx/work/Configuration;Landroidx/work/impl/WorkDatabase;Ljava/util/List;)V :cond_2 :goto_0 return-void .end method .method public isForceStopped()Z .locals 9 .annotation build Landroid/annotation/SuppressLint; value = { "ClassVerificationFailure" } .end annotation .annotation build Landroidx/annotation/VisibleForTesting; .end annotation const/4 v0, 0x1 :try_start_0 sget v1, Landroid/os/Build$VERSION;->SDK_INT:I const/16 v2, 0x1f if-lt v1, v2, :cond_0 const/high16 v2, 0x22000000 goto :goto_0 :cond_0 const/high16 v2, 0x20000000 :goto_0 iget-object v3, p0, Landroidx/work/impl/utils/ForceStopRunnable;->mContext:Landroid/content/Context; .line 207 invoke-static {v3, v2}, Landroidx/work/impl/utils/ForceStopRunnable;->getPendingIntent(Landroid/content/Context;I)Landroid/app/PendingIntent; move-result-object v2 const/16 v3, 0x1e const/4 v4, 0x0 if-lt v1, v3, :cond_3 if-eqz v2, :cond_1 .line 211 invoke-virtual {v2}, Landroid/app/PendingIntent;->cancel()V goto :goto_1 :catch_0 move-exception v1 goto :goto_3 :catch_1 move-exception v1 goto :goto_3 :cond_1 :goto_1 iget-object v1, p0, Landroidx/work/impl/utils/ForceStopRunnable;->mContext:Landroid/content/Context; const-string v2, "activity" .line 214 invoke-virtual {v1, v2}, Landroid/content/Context;->getSystemService(Ljava/lang/String;)Ljava/lang/Object; move-result-object v1 check-cast v1, Landroid/app/ActivityManager; const/4 v2, 0x0 .line 216 invoke-static {v1, v2, v4, v4}, Landroidx/work/impl/utils/ForceStopRunnable$$ExternalSyntheticApiModelOutline0;->m(Landroid/app/ActivityManager;Ljava/lang/String;II)Ljava/util/List; move-result-object v1 if-eqz v1, :cond_4 .line 222 invoke-interface {v1}, Ljava/util/List;->isEmpty()Z move-result v2 if-nez v2, :cond_4 iget-object v2, p0, Landroidx/work/impl/utils/ForceStopRunnable;->mPreferenceUtils:Landroidx/work/impl/utils/PreferenceUtils; .line 223 invoke-virtual {v2}, Landroidx/work/impl/utils/PreferenceUtils;->getLastForceStopEventMillis()J move-result-wide v2 move v5, v4 .line 224 :goto_2 invoke-interface {v1}, Ljava/util/List;->size()I move-result v6 if-ge v5, v6, :cond_4 .line 225 invoke-interface {v1, v5}, Ljava/util/List;->get(I)Ljava/lang/Object; move-result-object v6 invoke-static {v6}, Landroidx/work/impl/utils/ForceStopRunnable$$ExternalSyntheticApiModelOutline1;->m(Ljava/lang/Object;)Landroid/app/ApplicationExitInfo; move-result-object v6 .line 226 invoke-static {v6}, Landroidx/work/impl/utils/ForceStopRunnable$$ExternalSyntheticApiModelOutline2;->m(Landroid/app/ApplicationExitInfo;)I move-result v7 const/16 v8, 0xa if-ne v7, v8, :cond_2 .line 227 invoke-static {v6}, Landroidx/work/impl/utils/ForceStopRunnable$$ExternalSyntheticApiModelOutline3;->m(Landroid/app/ApplicationExitInfo;)J move-result-wide v6 cmp-long v6, v6, v2 if-ltz v6, :cond_2 return v0 :cond_2 add-int/lit8 v5, v5, 0x1 goto :goto_2 :cond_3 if-nez v2, :cond_4 iget-object v1, p0, Landroidx/work/impl/utils/ForceStopRunnable;->mContext:Landroid/content/Context; .line 233 invoke-static {v1}, Landroidx/work/impl/utils/ForceStopRunnable;->setAlarm(Landroid/content/Context;)V :try_end_0 .catch Ljava/lang/SecurityException; {:try_start_0 .. :try_end_0} :catch_1 .catch Ljava/lang/IllegalArgumentException; {:try_start_0 .. :try_end_0} :catch_0 return v0 :cond_4 return v4 .line 244 :goto_3 invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger; move-result-object v2 sget-object v3, Landroidx/work/impl/utils/ForceStopRunnable;->TAG:Ljava/lang/String; const-string v4, "Ignoring exception" invoke-virtual {v2, v3, v4, v1}, Landroidx/work/Logger;->warning(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V return v0 .end method .method public multiProcessChecks()Z .locals 5 .annotation build Landroidx/annotation/VisibleForTesting; .end annotation iget-object v0, p0, Landroidx/work/impl/utils/ForceStopRunnable;->mWorkManager:Landroidx/work/impl/WorkManagerImpl; .line 341 invoke-virtual {v0}, Landroidx/work/impl/WorkManagerImpl;->getConfiguration()Landroidx/work/Configuration; move-result-object v0 .line 346 invoke-virtual {v0}, Landroidx/work/Configuration;->getDefaultProcessName()Ljava/lang/String; move-result-object v1 invoke-static {v1}, Landroid/text/TextUtils;->isEmpty(Ljava/lang/CharSequence;)Z move-result v1 if-eqz v1, :cond_0 .line 347 invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger; move-result-object v0 sget-object v1, Landroidx/work/impl/utils/ForceStopRunnable;->TAG:Ljava/lang/String; const-string v2, "The default process name was not specified." invoke-virtual {v0, v1, v2}, Landroidx/work/Logger;->debug(Ljava/lang/String;Ljava/lang/String;)V const/4 v0, 0x1 return v0 :cond_0 iget-object v1, p0, Landroidx/work/impl/utils/ForceStopRunnable;->mContext:Landroid/content/Context; .line 350 invoke-static {v1, v0}, Landroidx/work/impl/utils/ProcessUtils;->isDefaultProcess(Landroid/content/Context;Landroidx/work/Configuration;)Z move-result v0 .line 351 invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger; move-result-object v1 sget-object v2, Landroidx/work/impl/utils/ForceStopRunnable;->TAG:Ljava/lang/String; new-instance v3, Ljava/lang/StringBuilder; invoke-direct {v3}, Ljava/lang/StringBuilder;->()V const-string v4, "Is default app process = " invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(Z)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 return v0 .end method .method public run()V .locals 9 .line 105 :try_start_0 invoke-virtual {p0}, Landroidx/work/impl/utils/ForceStopRunnable;->multiProcessChecks()Z move-result v0 :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 if-nez v0, :cond_0 iget-object v0, p0, Landroidx/work/impl/utils/ForceStopRunnable;->mWorkManager:Landroidx/work/impl/WorkManagerImpl; .line 188 invoke-virtual {v0}, Landroidx/work/impl/WorkManagerImpl;->onForceStopRunnableCompleted()V return-void :cond_0 :goto_0 :try_start_1 iget-object v0, p0, Landroidx/work/impl/utils/ForceStopRunnable;->mContext:Landroid/content/Context; .line 115 invoke-static {v0}, Landroidx/work/impl/WorkDatabasePathHelper;->migrateDatabase(Landroid/content/Context;)V :try_end_1 .catch Landroid/database/sqlite/SQLiteException; {:try_start_1 .. :try_end_1} :catch_8 .catchall {:try_start_1 .. :try_end_1} :catchall_0 .line 134 :try_start_2 invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger; move-result-object v0 sget-object v1, Landroidx/work/impl/utils/ForceStopRunnable;->TAG:Ljava/lang/String; const-string v2, "Performing cleanup operations." invoke-virtual {v0, v1, v2}, Landroidx/work/Logger;->debug(Ljava/lang/String;Ljava/lang/String;)V :try_end_2 .catchall {:try_start_2 .. :try_end_2} :catchall_0 .line 136 :try_start_3 invoke-virtual {p0}, Landroidx/work/impl/utils/ForceStopRunnable;->forceStopRunnable()V :try_end_3 .catch Landroid/database/sqlite/SQLiteAccessPermException; {:try_start_3 .. :try_end_3} :catch_7 .catch Landroid/database/sqlite/SQLiteCantOpenDatabaseException; {:try_start_3 .. :try_end_3} :catch_6 .catch Landroid/database/sqlite/SQLiteConstraintException; {:try_start_3 .. :try_end_3} :catch_5 .catch Landroid/database/sqlite/SQLiteDatabaseCorruptException; {:try_start_3 .. :try_end_3} :catch_4 .catch Landroid/database/sqlite/SQLiteDatabaseLockedException; {:try_start_3 .. :try_end_3} :catch_3 .catch Landroid/database/sqlite/SQLiteDiskIOException; {:try_start_3 .. :try_end_3} :catch_2 .catch Landroid/database/sqlite/SQLiteFullException; {:try_start_3 .. :try_end_3} :catch_1 .catch Landroid/database/sqlite/SQLiteTableLockedException; {:try_start_3 .. :try_end_3} :catch_0 .catchall {:try_start_3 .. :try_end_3} :catchall_0 goto/16 :goto_3 :catchall_0 move-exception v0 goto/16 :goto_4 :catch_0 move-exception v0 goto :goto_1 :catch_1 move-exception v0 goto :goto_1 :catch_2 move-exception v0 goto :goto_1 :catch_3 move-exception v0 goto :goto_1 :catch_4 move-exception v0 goto :goto_1 :catch_5 move-exception v0 goto :goto_1 :catch_6 move-exception v0 goto :goto_1 :catch_7 move-exception v0 :goto_1 :try_start_4 iget v1, p0, Landroidx/work/impl/utils/ForceStopRunnable;->mRetryCount:I add-int/lit8 v1, v1, 0x1 iput v1, p0, Landroidx/work/impl/utils/ForceStopRunnable;->mRetryCount:I const/4 v2, 0x3 if-lt v1, v2, :cond_3 iget-object v1, p0, Landroidx/work/impl/utils/ForceStopRunnable;->mContext:Landroid/content/Context; .line 154 invoke-static {v1}, Landroidx/core/os/UserManagerCompat;->isUserUnlocked(Landroid/content/Context;)Z move-result v1 if-eqz v1, :cond_1 const-string v1, "The file system on the device is in a bad state. WorkManager cannot access the app\'s internal data store." goto :goto_2 :cond_1 const-string v1, "WorkManager can\'t be accessed from direct boot, because credential encrypted storage isn\'t accessible.\nDon\'t access or initialise WorkManager from directAware components. See https://developer.android.com/training/articles/direct-boot" .line 164 :goto_2 invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger; move-result-object v2 sget-object v3, Landroidx/work/impl/utils/ForceStopRunnable;->TAG:Ljava/lang/String; invoke-virtual {v2, v3, v1, v0}, Landroidx/work/Logger;->error(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V .line 165 new-instance v2, Ljava/lang/IllegalStateException; invoke-direct {v2, v1, v0}, Ljava/lang/IllegalStateException;->(Ljava/lang/String;Ljava/lang/Throwable;)V iget-object v0, p0, Landroidx/work/impl/utils/ForceStopRunnable;->mWorkManager:Landroidx/work/impl/WorkManagerImpl; .line 168 invoke-virtual {v0}, Landroidx/work/impl/WorkManagerImpl;->getConfiguration()Landroidx/work/Configuration; move-result-object v0 invoke-virtual {v0}, Landroidx/work/Configuration;->getInitializationExceptionHandler()Landroidx/core/util/Consumer; move-result-object v0 if-eqz v0, :cond_2 .line 170 invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger; move-result-object v1 const-string v4, "Routing exception to the specified exception handler" invoke-virtual {v1, v3, v4, v2}, Landroidx/work/Logger;->debug(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V .line 173 invoke-interface {v0, v2}, Landroidx/core/util/Consumer;->accept(Ljava/lang/Object;)V goto :goto_3 .line 176 :cond_2 throw v2 :cond_3 int-to-long v1, v1 const-wide/16 v3, 0x12c mul-long/2addr v1, v3 .line 180 invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger; move-result-object v5 sget-object v6, Landroidx/work/impl/utils/ForceStopRunnable;->TAG:Ljava/lang/String; new-instance v7, Ljava/lang/StringBuilder; invoke-direct {v7}, Ljava/lang/StringBuilder;->()V const-string v8, "Retrying after " invoke-virtual {v7, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v7, v1, v2}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder; invoke-virtual {v7}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v1 .line 181 invoke-virtual {v5, v6, v1, v0}, Landroidx/work/Logger;->debug(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)V iget v0, p0, Landroidx/work/impl/utils/ForceStopRunnable;->mRetryCount:I int-to-long v0, v0 mul-long/2addr v0, v3 .line 183 invoke-virtual {p0, v0, v1}, Landroidx/work/impl/utils/ForceStopRunnable;->sleep(J)V goto/16 :goto_0 :catch_8 move-exception v0 const-string v1, "Unexpected SQLite exception during migrations" .line 119 invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger; move-result-object v2 sget-object v3, Landroidx/work/impl/utils/ForceStopRunnable;->TAG:Ljava/lang/String; invoke-virtual {v2, v3, v1}, Landroidx/work/Logger;->error(Ljava/lang/String;Ljava/lang/String;)V .line 120 new-instance v2, Ljava/lang/IllegalStateException; invoke-direct {v2, v1, v0}, Ljava/lang/IllegalStateException;->(Ljava/lang/String;Ljava/lang/Throwable;)V iget-object v0, p0, Landroidx/work/impl/utils/ForceStopRunnable;->mWorkManager:Landroidx/work/impl/WorkManagerImpl; .line 123 invoke-virtual {v0}, Landroidx/work/impl/WorkManagerImpl;->getConfiguration()Landroidx/work/Configuration; move-result-object v0 invoke-virtual {v0}, Landroidx/work/Configuration;->getInitializationExceptionHandler()Landroidx/core/util/Consumer; move-result-object v0 if-eqz v0, :cond_4 .line 125 invoke-interface {v0, v2}, Landroidx/core/util/Consumer;->accept(Ljava/lang/Object;)V :try_end_4 .catchall {:try_start_4 .. :try_end_4} :catchall_0 :goto_3 iget-object v0, p0, Landroidx/work/impl/utils/ForceStopRunnable;->mWorkManager:Landroidx/work/impl/WorkManagerImpl; .line 188 invoke-virtual {v0}, Landroidx/work/impl/WorkManagerImpl;->onForceStopRunnableCompleted()V return-void .line 128 :cond_4 :try_start_5 throw v2 :try_end_5 .catchall {:try_start_5 .. :try_end_5} :catchall_0 :goto_4 iget-object v1, p0, Landroidx/work/impl/utils/ForceStopRunnable;->mWorkManager:Landroidx/work/impl/WorkManagerImpl; .line 188 invoke-virtual {v1}, Landroidx/work/impl/WorkManagerImpl;->onForceStopRunnableCompleted()V .line 189 throw v0 .end method .method public shouldRescheduleWorkers()Z .locals 1 .annotation build Landroidx/annotation/VisibleForTesting; .end annotation iget-object v0, p0, Landroidx/work/impl/utils/ForceStopRunnable;->mWorkManager:Landroidx/work/impl/WorkManagerImpl; .line 330 invoke-virtual {v0}, Landroidx/work/impl/WorkManagerImpl;->getPreferenceUtils()Landroidx/work/impl/utils/PreferenceUtils; move-result-object v0 invoke-virtual {v0}, Landroidx/work/impl/utils/PreferenceUtils;->getNeedsReschedule()Z move-result v0 return v0 .end method .method public sleep(J)V .locals 0 .annotation build Landroidx/annotation/VisibleForTesting; .end annotation .line 362 :try_start_0 invoke-static {p1, p2}, Ljava/lang/Thread;->sleep(J)V :try_end_0 .catch Ljava/lang/InterruptedException; {:try_start_0 .. :try_end_0} :catch_0 :catch_0 return-void .end method