blob: 7ed1e4b64f796e400cc1a449a91921eab37a22ac (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
|
package com.xc3fff0e.xmanager;
import android.app.AlarmManager;
import android.app.Application;
import android.app.PendingIntent;
import android.content.Context;
import android.content.Intent;
import android.os.Process;
import android.util.Log;
public class xManager extends Application {
private static Context mApplicationContext;
private Thread.UncaughtExceptionHandler uncaughtExceptionHandler;
public static Context getContext() {
return mApplicationContext;
}
@Override
public void onCreate() {
mApplicationContext = getApplicationContext();
this.uncaughtExceptionHandler = Thread.getDefaultUncaughtExceptionHandler();
Thread.setDefaultUncaughtExceptionHandler(
new Thread.UncaughtExceptionHandler() {
@Override
public void uncaughtException(Thread thread, Throwable throwable) {
Intent intent = new Intent(getApplicationContext(), DebugActivity.class);
intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TASK);
intent.putExtra("error", Log.getStackTraceString(throwable));
PendingIntent pendingIntent =
PendingIntent.getActivity(
getApplicationContext(),
11111,
intent,
PendingIntent.FLAG_ONE_SHOT
);
AlarmManager am = (AlarmManager) getSystemService(Context.ALARM_SERVICE);
am.set(AlarmManager.ELAPSED_REALTIME_WAKEUP, 1000, pendingIntent);
xManagerLogger.broadcastLog(Log.getStackTraceString(throwable));
Process.killProcess(Process.myPid());
System.exit(1);
uncaughtExceptionHandler.uncaughtException(thread, throwable);
}
});
xManagerLogger.startLogging();
super.onCreate();
}
}
|