diff options
author | Uwe Stieber | 2013-06-25 15:27:18 +0000 |
---|---|---|
committer | Uwe Stieber | 2013-06-25 15:28:37 +0000 |
commit | ad7586920214ddbea77ac1722be0103f849c6a49 (patch) | |
tree | 2f64e56e73716ecfebb716eb039daff26c4ad1a6 | |
parent | d8ffd34268b2e7be7bd4120c0ffab4b550030616 (diff) | |
download | org.eclipse.tcf-ad7586920214ddbea77ac1722be0103f849c6a49.tar.gz org.eclipse.tcf-ad7586920214ddbea77ac1722be0103f849c6a49.tar.xz org.eclipse.tcf-ad7586920214ddbea77ac1722be0103f849c6a49.zip |
Target Explorer: Fix runtime models not disposed on disconnect
3 files changed, 71 insertions, 1 deletions
diff --git a/target_explorer/plugins/org.eclipse.tcf.te.tcf.locator/plugin.properties b/target_explorer/plugins/org.eclipse.tcf.te.tcf.locator/plugin.properties index 6d883ec0a..1e6bdd361 100644 --- a/target_explorer/plugins/org.eclipse.tcf.te.tcf.locator/plugin.properties +++ b/target_explorer/plugins/org.eclipse.tcf.te.tcf.locator/plugin.properties @@ -19,4 +19,5 @@ StopSimulatorStep.name=Stop Simulator StartDebuggerStep.name=Start Debugger StopDebuggerStep.name=Stop Debugger SetWaitForReadyStep.name=Set peer waiting state -WaitForReadyStep.name=Wait until peer becomes ready
\ No newline at end of file +WaitForReadyStep.name=Wait until peer becomes ready +SignalPeerDisconnectedStep.name=Signal peer disconnected state diff --git a/target_explorer/plugins/org.eclipse.tcf.te.tcf.locator/plugin.xml b/target_explorer/plugins/org.eclipse.tcf.te.tcf.locator/plugin.xml index 9046ef953..e899a9b47 100644 --- a/target_explorer/plugins/org.eclipse.tcf.te.tcf.locator/plugin.xml +++ b/target_explorer/plugins/org.eclipse.tcf.te.tcf.locator/plugin.xml @@ -159,6 +159,10 @@ id="org.eclipse.tcf.te.tcf.locator.waitForReadyStep" class="org.eclipse.tcf.te.tcf.locator.steps.WaitForReadyStep" label="%WaitForReadyStep.name"/> + <step + id="org.eclipse.tcf.te.tcf.locator.signalPeerDisconnectedStep" + class="org.eclipse.tcf.te.tcf.locator.steps.SignalPeerDisconnectedStep" + label="%SignalPeerDisconnectedStep.name"/> </extension> <!-- Step group contributions --> @@ -178,6 +182,7 @@ <reference id="org.eclipse.tcf.te.tcf.locator.stopDebuggerStep"/> <reference id="org.eclipse.tcf.te.tcf.core.shutDownStep"/> <reference id="org.eclipse.tcf.te.tcf.locator.stopSimulatorStep"/> + <reference id="org.eclipse.tcf.te.tcf.locator.signalPeerDisconnectedStep"/> </references> </stepGroup> diff --git a/target_explorer/plugins/org.eclipse.tcf.te.tcf.locator/src/org/eclipse/tcf/te/tcf/locator/steps/SignalPeerDisconnectedStep.java b/target_explorer/plugins/org.eclipse.tcf.te.tcf.locator/src/org/eclipse/tcf/te/tcf/locator/steps/SignalPeerDisconnectedStep.java new file mode 100644 index 000000000..cbf2a034e --- /dev/null +++ b/target_explorer/plugins/org.eclipse.tcf.te.tcf.locator/src/org/eclipse/tcf/te/tcf/locator/steps/SignalPeerDisconnectedStep.java @@ -0,0 +1,64 @@ +/******************************************************************************* + * Copyright (c) 2013 Wind River Systems, Inc. and others. All rights reserved. + * This program and the accompanying materials are made available under the terms + * of the Eclipse Public License v1.0 which accompanies this distribution, and is + * available at http://www.eclipse.org/legal/epl-v10.html + * + * Contributors: + * Wind River Systems - initial API and implementation + *******************************************************************************/ +package org.eclipse.tcf.te.tcf.locator.steps; + +import org.eclipse.core.runtime.Assert; +import org.eclipse.core.runtime.CoreException; +import org.eclipse.core.runtime.IProgressMonitor; +import org.eclipse.core.runtime.Status; +import org.eclipse.tcf.protocol.Protocol; +import org.eclipse.tcf.te.runtime.interfaces.callback.ICallback; +import org.eclipse.tcf.te.runtime.interfaces.properties.IPropertiesContainer; +import org.eclipse.tcf.te.runtime.stepper.interfaces.IFullQualifiedId; +import org.eclipse.tcf.te.runtime.stepper.interfaces.IStepContext; +import org.eclipse.tcf.te.tcf.locator.interfaces.IModelListener; +import org.eclipse.tcf.te.tcf.locator.interfaces.nodes.ILocatorModel; +import org.eclipse.tcf.te.tcf.locator.interfaces.nodes.IPeerModel; +import org.eclipse.tcf.te.tcf.locator.model.Model; + +/** + * Signal peer disconnected step. + */ +public class SignalPeerDisconnectedStep extends AbstractPeerModelStep { + + /* (non-Javadoc) + * @see org.eclipse.tcf.te.runtime.stepper.interfaces.IStep#validateExecute(org.eclipse.tcf.te.runtime.stepper.interfaces.IStepContext, org.eclipse.tcf.te.runtime.interfaces.properties.IPropertiesContainer, org.eclipse.tcf.te.runtime.stepper.interfaces.IFullQualifiedId, org.eclipse.core.runtime.IProgressMonitor) + */ + @Override + public void validateExecute(IStepContext context, IPropertiesContainer data, IFullQualifiedId fullQualifiedId, IProgressMonitor monitor) throws CoreException { + } + + /* (non-Javadoc) + * @see org.eclipse.tcf.te.runtime.stepper.interfaces.IStep#execute(org.eclipse.tcf.te.runtime.stepper.interfaces.IStepContext, org.eclipse.tcf.te.runtime.interfaces.properties.IPropertiesContainer, org.eclipse.tcf.te.runtime.stepper.interfaces.IFullQualifiedId, org.eclipse.core.runtime.IProgressMonitor, org.eclipse.tcf.te.runtime.interfaces.callback.ICallback) + */ + @Override + public void execute(final IStepContext context, final IPropertiesContainer data, final IFullQualifiedId fullQualifiedId, final IProgressMonitor monitor, final ICallback callback) { + Assert.isNotNull(context); + Assert.isNotNull(data); + Assert.isNotNull(fullQualifiedId); + Assert.isNotNull(monitor); + Assert.isNotNull(callback); + + final IPeerModel peerModel = getActivePeerModelContext(context, data, fullQualifiedId); + if (peerModel != null) { + Protocol.invokeLater(new Runnable() { + @Override + public void run() { + ILocatorModel model = Model.getModel(); + for (IModelListener listener : model.getListener()) { + listener.locatorModelChanged(model, peerModel, false); + } + callback.done(SignalPeerDisconnectedStep.this, Status.OK_STATUS); + } + }); + } + } + +} |