![electron-roller[bot]](/assets/img/avatar_default.png) 193e162ec6
			
		
	
	
	
	
	193e162ec6* chore: bump chromium in DEPS to 124.0.6355.0 * 5341411: view-transition: Ensure resources are cleaned up in all cases. https://chromium-review.googlesource.com/c/chromium/src/+/5341411 * chore: fixup patch indices * 5354013: Return nullopt on error from ProcessMetrics CPU measurements https://chromium-review.googlesource.com/c/chromium/src/+/5354013 * chore: bump chromium in DEPS to 124.0.6357.0 * chore: update patches * 5368769: Reland "[mojo] Use large worker for mojom_parser action" https://chromium-review.googlesource.com/c/chromium/src/+/5368769 * 5336171: [Extensions] Introduce a CoreExtensionsRendererAPIProvider https://chromium-review.googlesource.com/c/chromium/src/+/5336171 * 5367334: [FS Shortcut] Refactor ExclusiveAccessManager https://chromium-review.googlesource.com/c/chromium/src/+/5367334 * 5354161: Rename GeolocationManager to GeolocationSystemPermissionManager https://chromium-review.googlesource.com/c/chromium/src/+/5354161 * fixup: [Extensions] Introduce a CoreExtensionsRendererAPIProvider * chore: bump chromium in DEPS to 124.0.6359.0 * chore: update patches * 5371370: [Extensions] Move core NativeHandler registration https://chromium-review.googlesource.com/c/chromium/src/+/5371370 * 5370702: [Extensions] Introduce ShellExtensionsRendererAPIProvider https://chromium-review.googlesource.com/c/chromium/src/+/5370702 --------- Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> Co-authored-by: PatchUp <73610968+patchup[bot]@users.noreply.github.com> Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org>
		
			
				
	
	
		
			77 lines
		
	
	
	
		
			3.5 KiB
			
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			77 lines
		
	
	
	
		
			3.5 KiB
			
		
	
	
	
		
			Diff
		
	
	
	
	
	
| From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
 | |
| From: Cheng Zhao <zcbenz@gmail.com>
 | |
| Date: Thu, 20 Sep 2018 17:45:03 -0700
 | |
| Subject: blink_local_frame.patch
 | |
| 
 | |
| According to electron/electron#3699, it is unreliable to use |unload|
 | |
| event for process.exit('exit'), so we have to do that in
 | |
| willReleaseScriptContext.
 | |
| 
 | |
| Refs changes in:
 | |
| * https://codereview.chromium.org/1657583002
 | |
| * https://chromium-review.googlesource.com/c/chromium/src/+/2596880
 | |
| * https://chromium-review.googlesource.com/c/chromium/src/+/2597169
 | |
| 
 | |
| This patch reverts the changes to fix associated crashes in Electron.
 | |
| 
 | |
| diff --git a/third_party/blink/renderer/core/frame/frame.cc b/third_party/blink/renderer/core/frame/frame.cc
 | |
| index 0a742bbbd5e8e1eb3610cc32f785f779e8907e75..26967019244d409dadf4533405d4d5d27c75b73c 100644
 | |
| --- a/third_party/blink/renderer/core/frame/frame.cc
 | |
| +++ b/third_party/blink/renderer/core/frame/frame.cc
 | |
| @@ -125,14 +125,6 @@ bool Frame::Detach(FrameDetachType type) {
 | |
|  
 | |
|    DCHECK(!IsDetached());
 | |
|  
 | |
| -  // TODO(dcheng): FocusController::FrameDetached() *should* fire JS events,
 | |
| -  // hence the above check for `client_` being null. However, when this was
 | |
| -  // previously placed before the `FrameDetached()` call, nothing crashes, which
 | |
| -  // is suspicious. Investigate if we really don't need to fire JS events--and
 | |
| -  // if we don't, move `forbid_scripts` up to be instantiated sooner and
 | |
| -  // simplify this code.
 | |
| -  ScriptForbiddenScope forbid_scripts;
 | |
| -
 | |
|    if (type == FrameDetachType::kRemove) {
 | |
|      if (provisional_frame_) {
 | |
|        provisional_frame_->Detach(FrameDetachType::kRemove);
 | |
| @@ -156,6 +148,14 @@ bool Frame::Detach(FrameDetachType type) {
 | |
|      GetWindowProxyManager()->ClearForSwap();
 | |
|    }
 | |
|  
 | |
| +  // TODO(dcheng): FocusController::FrameDetached() *should* fire JS events,
 | |
| +  // hence the above check for `client_` being null. However, when this was
 | |
| +  // previously placed before the `FrameDetached()` call, nothing crashes, which
 | |
| +  // is suspicious. Investigate if we really don't need to fire JS events--and
 | |
| +  // if we don't, move `forbid_scripts` up to be instantiated sooner and
 | |
| +  // simplify this code.
 | |
| +  ScriptForbiddenScope forbid_scripts;
 | |
| +
 | |
|    // After this, we must no longer talk to the client since this clears
 | |
|    // its owning reference back to our owning LocalFrame.
 | |
|    client_->Detached(type);
 | |
| diff --git a/third_party/blink/renderer/core/frame/local_frame.cc b/third_party/blink/renderer/core/frame/local_frame.cc
 | |
| index 81e90b80d4ff25c7003e4e98f071848be98280d6..92cfe0001933cd18ecb7384ead1dda26f563e62b 100644
 | |
| --- a/third_party/blink/renderer/core/frame/local_frame.cc
 | |
| +++ b/third_party/blink/renderer/core/frame/local_frame.cc
 | |
| @@ -684,10 +684,6 @@ bool LocalFrame::DetachImpl(FrameDetachType type) {
 | |
|    }
 | |
|    DCHECK(!view_ || !view_->IsAttached());
 | |
|  
 | |
| -  // This is the earliest that scripting can be disabled:
 | |
| -  // - FrameLoader::Detach() can fire XHR abort events
 | |
| -  // - Document::Shutdown() can dispose plugins which can run script.
 | |
| -  ScriptForbiddenScope forbid_script;
 | |
|    if (!Client())
 | |
|      return false;
 | |
|  
 | |
| @@ -738,6 +734,11 @@ bool LocalFrame::DetachImpl(FrameDetachType type) {
 | |
|    DCHECK(!view_->IsAttached());
 | |
|    Client()->WillBeDetached();
 | |
|  
 | |
| +  // This is the earliest that scripting can be disabled:
 | |
| +  // - FrameLoader::Detach() can fire XHR abort events
 | |
| +  // - Document::Shutdown() can dispose plugins which can run script.
 | |
| +  ScriptForbiddenScope forbid_script;
 | |
| +
 | |
|    // TODO(crbug.com/729196): Trace why LocalFrameView::DetachFromLayout crashes.
 | |
|    CHECK(!view_->IsAttached());
 | |
|    SetView(nullptr);
 |