From 77b7840fa1e8f6a481658f94836de0432e25f257 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Christoph=20L=C3=A4ubrich?= Date: Fri, 27 Dec 2024 08:46:07 +0100 Subject: [PATCH] Fail if a workspace is disposed outside the manager Currently one can obtain a workspace baseline and dispose it leading to hard to track errors. This now fails if someone tries to dispose the baseline without using the manager. --- .../org.eclipse.pde.api.tools/META-INF/MANIFEST.MF | 2 +- .../pde/api/tools/internal/ApiBaselineManager.java | 14 +++++++------- .../tools/internal/model/WorkspaceBaseline.java | 8 ++++++++ 3 files changed, 16 insertions(+), 8 deletions(-) diff --git a/apitools/org.eclipse.pde.api.tools/META-INF/MANIFEST.MF b/apitools/org.eclipse.pde.api.tools/META-INF/MANIFEST.MF index 7fbad0b9c6..73b6266936 100644 --- a/apitools/org.eclipse.pde.api.tools/META-INF/MANIFEST.MF +++ b/apitools/org.eclipse.pde.api.tools/META-INF/MANIFEST.MF @@ -2,7 +2,7 @@ Manifest-Version: 1.0 Bundle-ManifestVersion: 2 Bundle-Name: %pluginName Bundle-SymbolicName: org.eclipse.pde.api.tools;singleton:=true -Bundle-Version: 1.3.600.qualifier +Bundle-Version: 1.3.700.qualifier Bundle-Vendor: %providerName Bundle-Localization: plugin Require-Bundle: org.eclipse.core.runtime;bundle-version="[3.29.0,4.0.0)", diff --git a/apitools/org.eclipse.pde.api.tools/src/org/eclipse/pde/api/tools/internal/ApiBaselineManager.java b/apitools/org.eclipse.pde.api.tools/src/org/eclipse/pde/api/tools/internal/ApiBaselineManager.java index 1b99c12069..fb3f671519 100644 --- a/apitools/org.eclipse.pde.api.tools/src/org/eclipse/pde/api/tools/internal/ApiBaselineManager.java +++ b/apitools/org.eclipse.pde.api.tools/src/org/eclipse/pde/api/tools/internal/ApiBaselineManager.java @@ -128,7 +128,7 @@ public final class ApiBaselineManager implements IApiBaselineManager, ISaveParti /** * The current workspace baseline */ - private volatile IApiBaseline workspacebaseline; + private volatile WorkspaceBaseline workspacebaseline; /** * The default save location for persisting the cache from this manager. @@ -548,7 +548,7 @@ public void stop() { } synchronized (this) { if (workspacebaseline != null) { - workspacebaseline.dispose(); + workspacebaseline.disposeInternal(); } } if (handlecache != null) { @@ -620,12 +620,12 @@ public IApiBaseline getWorkspaceBaseline() { * the next request. */ public void disposeWorkspaceBaseline() { - final IApiBaseline originalBaseline = workspacebaseline; + final WorkspaceBaseline originalBaseline = workspacebaseline; if (originalBaseline == null) { return; } IJobFunction runnable = m -> { - IApiBaseline oldBaseline = null; + WorkspaceBaseline oldBaseline = null; synchronized (ApiBaselineManager.this) { if (workspacebaseline != null && originalBaseline == workspacebaseline) { if (ApiPlugin.DEBUG_BASELINE_MANAGER) { @@ -637,7 +637,7 @@ public void disposeWorkspaceBaseline() { } } if (oldBaseline != null) { - oldBaseline.dispose(); + oldBaseline.disposeInternal(); } return Status.OK_STATUS; }; @@ -681,9 +681,9 @@ public boolean isConflicting(ISchedulingRule rule) { * * @return a new workspace {@link IApiBaseline} or null */ - private IApiBaseline createWorkspaceBaseline() throws CoreException { + private WorkspaceBaseline createWorkspaceBaseline() throws CoreException { long time = System.currentTimeMillis(); - IApiBaseline baseline = new WorkspaceBaseline(); + WorkspaceBaseline baseline = new WorkspaceBaseline(); try { // populate it with only projects that are API aware List models = Arrays.asList(PluginRegistry.getWorkspaceModels()); diff --git a/apitools/org.eclipse.pde.api.tools/src/org/eclipse/pde/api/tools/internal/model/WorkspaceBaseline.java b/apitools/org.eclipse.pde.api.tools/src/org/eclipse/pde/api/tools/internal/model/WorkspaceBaseline.java index 1d99260328..7416f78b59 100644 --- a/apitools/org.eclipse.pde.api.tools/src/org/eclipse/pde/api/tools/internal/model/WorkspaceBaseline.java +++ b/apitools/org.eclipse.pde.api.tools/src/org/eclipse/pde/api/tools/internal/model/WorkspaceBaseline.java @@ -52,6 +52,14 @@ public WorkspaceBaseline() { @Override public void dispose() { + throw new UnsupportedOperationException( + "ApiBaselineManager.disposeWorkspaceBaseline() must be used to dispose the workspace baseline"); //$NON-NLS-1$ + } + + /** + * Only public for technical reasons do not call directly! + */ + public void disposeInternal() { doDispose(); mismatch.clear(); }