a
554325746@qq.com
2020-01-02 e52632329ef8342a2f692bf58184fc54db3d2b4c
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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
/*
 *  Copyright 2013 The WebRTC Project Authors. All rights reserved.
 *
 *  Use of this source code is governed by a BSD-style license
 *  that can be found in the LICENSE file in the root of the source
 *  tree. An additional intellectual property rights grant can be found
 *  in the file PATENTS.  All contributing project authors may
 *  be found in the AUTHORS file in the root of the source tree.
 */
 
package org.appspot.apprtc;
 
import android.app.Activity;
import android.app.AlertDialog;
import android.content.DialogInterface;
import android.util.Log;
import android.util.TypedValue;
import android.widget.ScrollView;
import android.widget.TextView;
 
import java.io.PrintWriter;
import java.io.StringWriter;
 
/**
 * Singleton helper: install a default unhandled exception handler which shows
 * an informative dialog and kills the app.  Useful for apps whose
 * error-handling consists of throwing RuntimeExceptions.
 * NOTE: almost always more useful to
 * Thread.setDefaultUncaughtExceptionHandler() rather than
 * Thread.setUncaughtExceptionHandler(), to apply to background threads as well.
 */
public class UnhandledExceptionHandler implements Thread.UncaughtExceptionHandler {
    private static final String TAG = "AppRTCMobileActivity";
    private final Activity activity;
 
    public UnhandledExceptionHandler(final Activity activity) {
        this.activity = activity;
    }
 
    // Returns the Message attached to the original Cause of |t|.
    private static String getTopLevelCauseMessage(Throwable t) {
        Throwable topLevelCause = t;
        while (topLevelCause.getCause() != null) {
            topLevelCause = topLevelCause.getCause();
        }
        return topLevelCause.getMessage();
    }
 
    // Returns a human-readable String of the stacktrace in |t|, recursively
    // through all Causes that led to |t|.
    private static String getRecursiveStackTrace(Throwable t) {
        StringWriter writer = new StringWriter();
        t.printStackTrace(new PrintWriter(writer));
        return writer.toString();
    }
 
    @Override
    public void uncaughtException(Thread unusedThread, final Throwable e) {
        e.printStackTrace();
        System.out.println("UnhandledExceptionHandler.uncaughtException " + e.getMessage());
//        activity.runOnUiThread(new Runnable() {
//            @Override
//            public void run() {
//                String title = "Fatal error: " + getTopLevelCauseMessage(e);
//                String msg = getRecursiveStackTrace(e);
//                TextView errorView = new TextView(activity);
//                errorView.setText(msg);
//                errorView.setTextSize(TypedValue.COMPLEX_UNIT_SP, 8);
//                ScrollView scrollingContainer = new ScrollView(activity);
//                scrollingContainer.addView(errorView);
//                Log.e(TAG, title + "\n\n" + msg);
//                DialogInterface.OnClickListener listener = new DialogInterface.OnClickListener() {
//                    @Override
//                    public void onClick(DialogInterface dialog, int which) {
//                        dialog.dismiss();
//                        System.exit(1);
//                    }
//                };
//                AlertDialog.Builder builder = new AlertDialog.Builder(activity);
//                builder.setTitle(title)
//                        .setView(scrollingContainer)
//                        .setPositiveButton("Exit", listener)
//                        .show();
//            }
//        });
    }
}