Don't hard crash if you get a null stack trace in Android
Summary: If stacktrace-parser can't parse a stack trace, it'll return null. This can cause us to accidentally enter a crash loop where whenever you start your app, you load the last JS bundle you had, get a crash, and then hard crash trying to print the stack trace. Reviewed By: frantic Differential Revision: D3528141 fbshipit-source-id: 1146f43bc40492bfa79b6a1c0f81092383896164
This commit is contained in:
parent
2537157d99
commit
b5c3550857
|
@ -9,6 +9,8 @@
|
||||||
|
|
||||||
package com.facebook.react.devsupport;
|
package com.facebook.react.devsupport;
|
||||||
|
|
||||||
|
import javax.annotation.Nullable;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
|
|
||||||
import com.facebook.react.bridge.ReadableArray;
|
import com.facebook.react.bridge.ReadableArray;
|
||||||
|
@ -91,9 +93,10 @@ public class StackTraceHelper {
|
||||||
* Convert a JavaScript stack trace (see {@code parseErrorStack} JS module) to an array of
|
* Convert a JavaScript stack trace (see {@code parseErrorStack} JS module) to an array of
|
||||||
* {@link StackFrame}s.
|
* {@link StackFrame}s.
|
||||||
*/
|
*/
|
||||||
public static StackFrame[] convertJsStackTrace(ReadableArray stack) {
|
public static StackFrame[] convertJsStackTrace(@Nullable ReadableArray stack) {
|
||||||
StackFrame[] result = new StackFrame[stack.size()];
|
int size = stack != null ? stack.size() : 0;
|
||||||
for (int i = 0; i < stack.size(); i++) {
|
StackFrame[] result = new StackFrame[size];
|
||||||
|
for (int i = 0; i < size; i++) {
|
||||||
ReadableMap frame = stack.getMap(i);
|
ReadableMap frame = stack.getMap(i);
|
||||||
String methodName = frame.getString("methodName");
|
String methodName = frame.getString("methodName");
|
||||||
String fileName = frame.getString("file");
|
String fileName = frame.getString("file");
|
||||||
|
|
Loading…
Reference in New Issue