Files
rr3-apk/smali/androidx/work/impl/utils/ForceStopRunnable.smali
Daniel Elliott f3960ee359 Add Discord APKTool decompilation (Smali source for modding)
- Imported from https://github.com/supermegamestre/Project-Real-Resurrection-3
- APKTool decompilation (Smali bytecode) for modding and rebuilding APK
- Supports both 32-bit (armeabi-v7a) and 64-bit (arm64-v8a) architectures
- Includes full Smali source, resources, and native libraries
- Ready to rebuild APK after modifications with apktool b command
- Added comprehensive README-apktool.md with modding guide

This branch complements the JADX branches:
- Use JADX (main/discord-community) to UNDERSTAND code (readable Java)
- Use APKTool (this branch) to MODIFY and REBUILD APK (editable Smali)

Total: 44,417 files, 538.51 MB Smali source code
2026-02-18 16:13:44 -08:00

1054 lines
29 KiB
Smali

.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 <clinit>()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 <init>(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;-><init>()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;-><init>()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;-><init>(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;-><init>()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;-><init>(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;-><init>()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;-><init>(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