From 1a18c6db3d210f808e1e6f6ce1692e7e1843c59f Mon Sep 17 00:00:00 2001 From: Praveen S K Date: Thu, 22 Feb 2024 13:15:35 +0530 Subject: [PATCH] Improve 'EditorStack' detection in CTabRendering Enhance tab identification by including a check for tabs located within the editor area, even when the 'EditorStack' tag is absent. --- .../workbench/renderers/swt/CTabRendering.java | 16 +++++++++++++--- 1 file changed, 13 insertions(+), 3 deletions(-) diff --git a/bundles/org.eclipse.e4.ui.workbench.renderers.swt/src/org/eclipse/e4/ui/workbench/renderers/swt/CTabRendering.java b/bundles/org.eclipse.e4.ui.workbench.renderers.swt/src/org/eclipse/e4/ui/workbench/renderers/swt/CTabRendering.java index e57a897f41e..158fc1f13d2 100644 --- a/bundles/org.eclipse.e4.ui.workbench.renderers.swt/src/org/eclipse/e4/ui/workbench/renderers/swt/CTabRendering.java +++ b/bundles/org.eclipse.e4.ui.workbench.renderers.swt/src/org/eclipse/e4/ui/workbench/renderers/swt/CTabRendering.java @@ -27,7 +27,11 @@ import org.eclipse.core.runtime.preferences.InstanceScope; import org.eclipse.e4.ui.internal.css.swt.ICTabRendering; import org.eclipse.e4.ui.internal.workbench.swt.AbstractPartRenderer; +import org.eclipse.e4.ui.model.application.ui.MContext; import org.eclipse.e4.ui.model.application.ui.MUIElement; +import org.eclipse.e4.ui.workbench.modeling.EModelService; +import org.eclipse.emf.ecore.EObject; +import org.eclipse.emf.ecore.util.EcoreUtil; import org.eclipse.swt.SWT; import org.eclipse.swt.custom.CTabFolder; import org.eclipse.swt.custom.CTabFolderRenderer; @@ -89,8 +93,6 @@ public class CTabRendering extends CTabFolderRenderer implements ICTabRendering, private static int MIN_VIEW_CHARS = 1; private static int MAX_VIEW_CHARS = 9999; - private static final String EditorTag = "EditorStack"; //$NON-NLS-1$ - // Constants for circle drawing static enum CirclePart { LEFT_TOP, LEFT_BOTTOM, RIGHT_TOP, RIGHT_BOTTOM; @@ -1330,7 +1332,15 @@ private IEclipsePreferences getSwtRendererPreferences() { private boolean isPartOfEditorStack() { MUIElement element = (MUIElement) parent.getData(AbstractPartRenderer.OWNING_ME); - return element != null && element.getTags().contains(EditorTag); + EObject root = EcoreUtil.getRootContainer((EObject) element, true); + if (root instanceof MContext context) { + EModelService eModelService = context.getContext().get(EModelService.class); + if (eModelService != null) { + int location = eModelService.getElementLocation(element); + return (location & EModelService.IN_SHARED_AREA) != 0; + } + } + return false; } private boolean getHideIconsForViewTabsPreference() {