From 1ee80243c92c9620ab98b11309501af7581be642 Mon Sep 17 00:00:00 2001 From: Amartya Parijat Date: Wed, 13 Nov 2024 14:30:53 +0100 Subject: [PATCH] Store Edge instance in Environemnt record sync-ly This commit stores the edge instance on creation in the webenvironment record synchronously for the sake of the consistency of the record. contributes to https://github.com/eclipse-platform/eclipse.platform.swt/issues/1592 --- .../win32/org/eclipse/swt/browser/Edge.java | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/bundles/org.eclipse.swt/Eclipse SWT Browser/win32/org/eclipse/swt/browser/Edge.java b/bundles/org.eclipse.swt/Eclipse SWT Browser/win32/org/eclipse/swt/browser/Edge.java index 709da2cafbc..f0cd7de48c7 100644 --- a/bundles/org.eclipse.swt/Eclipse SWT Browser/win32/org/eclipse/swt/browser/Edge.java +++ b/bundles/org.eclipse.swt/Eclipse SWT Browser/win32/org/eclipse/swt/browser/Edge.java @@ -568,6 +568,7 @@ private String getDataDir(Display display) { @Override public void create(Composite parent, int style) { containingEnvironment = createEnvironment(); + containingEnvironment.instances().add(this); long[] ppv = new long[1]; int hr = containingEnvironment.environment().QueryInterface(COM.IID_ICoreWebView2Environment2, ppv); if (hr == COM.S_OK) environment2 = new ICoreWebView2Environment2(ppv[0]); @@ -591,9 +592,11 @@ void setupBrowser(int hr, long pv) { case COM.S_OK: break; case COM.E_WRONG_THREAD: + containingEnvironment.instances().remove(this); error(SWT.ERROR_THREAD_INVALID_ACCESS, hr); break; default: + containingEnvironment.instances().remove(this); error(SWT.ERROR_NO_HANDLES, hr); } long[] ppv = new long[] {pv}; @@ -688,7 +691,6 @@ void setupBrowser(int hr, long pv) { browser.addListener(SWT.Move, this::browserMove); scheduleMouseMovementHandling(); - containingEnvironment.instances().add(this); // Sometimes when the shell of the browser is opened before the browser is // initialized, nothing is drawn on the shell. We need browserResize to force // the shell to draw itself again.