|
@@ -15,28 +15,32 @@ This patch should not be upstreamed, and can be removed in Electron 15 and
|
|
|
beyond once we identify the cause of the crash.
|
|
|
|
|
|
diff --git a/gin/wrappable.cc b/gin/wrappable.cc
|
|
|
-index fe07eb94a8e679859bba6d76ff0d6ee86bd0c67e..d0066fca501eae5be4177440b44dbecc8e34c897 100644
|
|
|
+index fe07eb94a8e679859bba6d76ff0d6ee86bd0c67e..ecb0aa2c4ec57e1814f4c94194e775440f4e35ee 100644
|
|
|
--- a/gin/wrappable.cc
|
|
|
+++ b/gin/wrappable.cc
|
|
|
-@@ -8,6 +8,10 @@
|
|
|
+@@ -8,6 +8,11 @@
|
|
|
#include "gin/object_template_builder.h"
|
|
|
#include "gin/per_isolate_data.h"
|
|
|
|
|
|
+#if !defined(MAS_BUILD)
|
|
|
++#include "components/crash/core/common/crash_key.h"
|
|
|
+#include "electron/shell/common/crash_keys.h"
|
|
|
+#endif
|
|
|
+
|
|
|
namespace gin {
|
|
|
|
|
|
WrappableBase::WrappableBase() = default;
|
|
|
-@@ -36,6 +40,12 @@ void WrappableBase::FirstWeakCallback(
|
|
|
+@@ -36,6 +41,15 @@ void WrappableBase::FirstWeakCallback(
|
|
|
void WrappableBase::SecondWeakCallback(
|
|
|
const v8::WeakCallbackInfo<WrappableBase>& data) {
|
|
|
WrappableBase* wrappable = data.GetParameter();
|
|
|
+
|
|
|
+#if !defined(MAS_BUILD)
|
|
|
-+ WrapperInfo* info = static_cast<WrapperInfo*>(data.GetInternalField(0));
|
|
|
-+ electron::crash_keys::SetCrashKeyForGinWrappable(info);
|
|
|
++ WrapperInfo* wrapperInfo = static_cast<WrapperInfo*>(data.GetInternalField(0));
|
|
|
++ std::string location = electron::crash_keys::GetCrashValueForGinWrappable(wrapperInfo);
|
|
|
++
|
|
|
++ static crash_reporter::CrashKeyString<32> crash_key("gin-wrappable-fatal.location");
|
|
|
++ crash_reporter::ScopedCrashKeyString auto_clear(&crash_key, location);
|
|
|
+#endif
|
|
|
+
|
|
|
delete wrappable;
|