Add decompiled APK source code (JADX)

- 28,932 files
- Full Java source code
- Smali files
- Resources

Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>
This commit is contained in:
2026-02-18 14:52:23 -08:00
parent cc210a65ea
commit f9d20bb3fc
26991 changed files with 2541449 additions and 0 deletions

View File

@@ -0,0 +1,127 @@
package com.github.anrwatchdog;
import android.os.Debug;
import android.os.Handler;
import android.os.Looper;
import android.util.Log;
/* loaded from: classes2.dex */
public class ANRWatchDog extends Thread {
public ANRInterceptor _anrInterceptor;
public ANRListener _anrListener;
public boolean _ignoreDebugger;
public InterruptionListener _interruptionListener;
public boolean _logThreadsWithoutStackTrace;
public String _namePrefix;
public volatile boolean _reported;
public volatile long _tick;
public final Runnable _ticker;
public final int _timeoutInterval;
public final Handler _uiHandler;
public static final ANRListener DEFAULT_ANR_LISTENER = new ANRListener() { // from class: com.github.anrwatchdog.ANRWatchDog.1
@Override // com.github.anrwatchdog.ANRWatchDog.ANRListener
public void onAppNotResponding(ANRError aNRError) {
throw aNRError;
}
};
public static final ANRInterceptor DEFAULT_ANR_INTERCEPTOR = new ANRInterceptor() { // from class: com.github.anrwatchdog.ANRWatchDog.2
@Override // com.github.anrwatchdog.ANRWatchDog.ANRInterceptor
public long intercept(long j) {
return 0L;
}
};
public static final InterruptionListener DEFAULT_INTERRUPTION_LISTENER = new InterruptionListener() { // from class: com.github.anrwatchdog.ANRWatchDog.3
@Override // com.github.anrwatchdog.ANRWatchDog.InterruptionListener
public void onInterrupted(InterruptedException interruptedException) {
Log.w("ANRWatchdog", "Interrupted: " + interruptedException.getMessage());
}
};
public interface ANRInterceptor {
long intercept(long j);
}
public interface ANRListener {
void onAppNotResponding(ANRError aNRError);
}
public interface InterruptionListener {
void onInterrupted(InterruptedException interruptedException);
}
public ANRWatchDog setANRListener(ANRListener aNRListener) {
if (aNRListener == null) {
this._anrListener = DEFAULT_ANR_LISTENER;
} else {
this._anrListener = aNRListener;
}
return this;
}
public ANRWatchDog setIgnoreDebugger(boolean z) {
this._ignoreDebugger = z;
return this;
}
public ANRWatchDog() {
this(5000);
}
public ANRWatchDog(int i) {
this._anrListener = DEFAULT_ANR_LISTENER;
this._anrInterceptor = DEFAULT_ANR_INTERCEPTOR;
this._interruptionListener = DEFAULT_INTERRUPTION_LISTENER;
this._uiHandler = new Handler(Looper.getMainLooper());
this._namePrefix = "";
this._logThreadsWithoutStackTrace = false;
this._ignoreDebugger = false;
this._tick = 0L;
this._reported = false;
this._ticker = new Runnable() { // from class: com.github.anrwatchdog.ANRWatchDog.4
@Override // java.lang.Runnable
public void run() {
ANRWatchDog.this._tick = 0L;
ANRWatchDog.this._reported = false;
}
};
this._timeoutInterval = i;
}
@Override // java.lang.Thread, java.lang.Runnable
public void run() {
ANRError NewMainOnly;
setName("|ANR-WatchDog|");
long j = this._timeoutInterval;
while (!isInterrupted()) {
boolean z = this._tick == 0;
this._tick += j;
if (z) {
this._uiHandler.post(this._ticker);
}
try {
Thread.sleep(j);
if (this._tick != 0 && !this._reported) {
if (!this._ignoreDebugger && (Debug.isDebuggerConnected() || Debug.waitingForDebugger())) {
Log.w("ANRWatchdog", "An ANR was detected but ignored because the debugger is connected (you can prevent this with setIgnoreDebugger(true))");
this._reported = true;
} else {
j = this._anrInterceptor.intercept(this._tick);
if (j <= 0) {
if (this._namePrefix != null) {
NewMainOnly = ANRError.New(this._tick, this._namePrefix, this._logThreadsWithoutStackTrace);
} else {
NewMainOnly = ANRError.NewMainOnly(this._tick);
}
this._anrListener.onAppNotResponding(NewMainOnly);
j = this._timeoutInterval;
this._reported = true;
}
}
}
} catch (InterruptedException e) {
this._interruptionListener.onInterrupted(e);
return;
}
}
}
}