- 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
1054 lines
29 KiB
Smali
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
|