debuggercdi/com.nokia.carbide.trk.support/src/com/nokia/carbide/trk/support/status/ConnectionStatusReconciler.java
author dadubrow
Tue, 16 Feb 2010 11:09:11 -0600
branchRCL_2_4
changeset 965 7942782aa571
parent 932 9eff68f52ec6
child 973 bd54fb1ea34a
permissions -rw-r--r--
remove trace status from reconcile logic
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
860
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
     1
/**
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
     2
* Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
     3
* All rights reserved.
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
     4
* This component and the accompanying materials are made available
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
     5
* under the terms of the License "Eclipse Public License v1.0"
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
     6
* which accompanies this distribution, and is available
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
     8
*
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
     9
* Initial Contributors:
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    11
*
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    12
* Contributors:
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    13
*
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    14
* Description: 
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    15
*
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    16
*/
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    17
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    18
package com.nokia.carbide.trk.support.status;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    19
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    20
import java.util.ArrayList;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    21
import java.util.List;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    22
932
9eff68f52ec6 Fix deadlock when the Select Connection dialog is up, user plugs in a device, and the Remote Connections view is shown
dadubrow
parents: 860
diff changeset
    23
import org.eclipse.swt.widgets.Display;
9eff68f52ec6 Fix deadlock when the Select Connection dialog is up, user plugs in a device, and the Remote Connections view is shown
dadubrow
parents: 860
diff changeset
    24
import org.eclipse.swt.widgets.Shell;
860
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    25
import org.eclipse.ui.PartInitException;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    26
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    27
import com.nokia.carbide.remoteconnections.RemoteConnectionsActivator;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    28
import com.nokia.carbide.remoteconnections.interfaces.IConnectedService;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    29
import com.nokia.carbide.remoteconnections.interfaces.IConnection;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    30
import com.nokia.carbide.remoteconnections.interfaces.IConnectionsManager;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    31
import com.nokia.carbide.remoteconnections.interfaces.AbstractConnection.ConnectionStatus;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    32
import com.nokia.carbide.remoteconnections.interfaces.IConnectedService.IStatus;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    33
import com.nokia.carbide.remoteconnections.interfaces.IConnectedService.IStatusChangedListener;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    34
import com.nokia.carbide.remoteconnections.interfaces.IConnectedService.IStatus.EStatus;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    35
import com.nokia.carbide.remoteconnections.interfaces.IConnectionsManager.IConnectionListener;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    36
import com.nokia.carbide.remoteconnections.internal.api.IConnection2;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    37
import com.nokia.carbide.remoteconnections.internal.api.IConnection2.IConnectionStatus;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    38
import com.nokia.carbide.remoteconnections.internal.api.IConnection2.IConnectionStatus.EConnectionStatus;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    39
import com.nokia.carbide.trk.support.Messages;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    40
import com.nokia.carbide.trk.support.connection.USBConnectionType;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    41
import com.nokia.carbide.trk.support.service.TRKConnectedService;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    42
import com.nokia.carbide.trk.support.service.TracingConnectedService;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    43
import com.nokia.cpp.internal.api.utils.ui.RunRunnableWhenWorkbenchVisibleJob;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    44
import com.nokia.cpp.internal.api.utils.ui.WorkbenchUtils;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    45
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    46
/**
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    47
 * A singleton object that manages the device status of dynamic connections
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    48
 * based on the status of the TRK and Tracing services.
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    49
 */
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    50
public class ConnectionStatusReconciler {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    51
	
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    52
	private static final String CONNECTIONS_VIEW_ID = 
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    53
		"com.nokia.carbide.remoteconnections.view.ConnectionsView"; //$NON-NLS-1$
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    54
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    55
	private class ConnectionListener implements IConnectionListener {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    56
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    57
		public void connectionAdded(IConnection connection) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    58
			addConnection(connection);
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    59
		}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    60
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    61
		public void connectionRemoved(IConnection connection) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    62
			if (connection.equals(userSetCurrentConnection))
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    63
				userSetCurrentConnection = null;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    64
			removeConnection(connection);
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    65
		}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    66
		
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    67
		public void currentConnectionSet(IConnection connection) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    68
			if (connection != null && !connection.equals(reconcilerSetCurrentConnection))
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    69
				userSetCurrentConnection = connection;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    70
		}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    71
		
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    72
	}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    73
	
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    74
	private class ServiceStatusListener implements IStatusChangedListener {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    75
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    76
		public void statusChanged(IStatus status) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    77
			handleServiceStatusChange(status);
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    78
		}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    79
		
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    80
	}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    81
	
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    82
	private static ConnectionStatusReconciler instance;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    83
	private IConnectionsManager manager;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    84
	private IConnectionListener connectionListener;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    85
	private List<IConnection> handledConnections;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    86
	private ServiceStatusListener serviceStatusListener;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    87
	private IConnection reconcilerSetCurrentConnection;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    88
	private IConnection userSetCurrentConnection;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    89
	
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    90
	private ConnectionStatusReconciler() {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    91
		connectionListener = new ConnectionListener();
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    92
		manager = RemoteConnectionsActivator.getConnectionsManager();
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    93
		manager.addConnectionListener(connectionListener);
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    94
		handledConnections = new ArrayList<IConnection>();
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    95
		serviceStatusListener = new ServiceStatusListener();
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    96
	}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    97
	
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    98
	public static ConnectionStatusReconciler getInstance() {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
    99
		if (instance == null)
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   100
			instance = new ConnectionStatusReconciler();
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   101
		
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   102
		return instance;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   103
	}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   104
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   105
	public void dispose() {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   106
		manager.removeConnectionListener(connectionListener);
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   107
		for (IConnection connection : new ArrayList<IConnection>(handledConnections)) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   108
			removeConnection(connection);
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   109
		}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   110
	}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   111
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   112
	private boolean isDynamic(IConnection connection) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   113
		return connection instanceof IConnection2 && ((IConnection2) connection).isDynamic();
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   114
	}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   115
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   116
	private boolean isSysTRK(TRKConnectedService service) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   117
		String value = service.getProperties().get(TRKConnectedService.PROP_SYS_TRK);
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   118
		return Boolean.parseBoolean(value);
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   119
	}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   120
	
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   121
	private void addConnection(IConnection connection) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   122
		handledConnections.add(connection);
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   123
		for (IConnectedService service : manager.getConnectedServices(connection)) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   124
			if (service instanceof TRKConnectedService ||
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   125
					service instanceof TracingConnectedService) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   126
				service.addStatusChangedListener(serviceStatusListener);
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   127
			}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   128
		}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   129
		showConnectionsView();
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   130
	}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   131
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   132
	private void showConnectionsView() {
932
9eff68f52ec6 Fix deadlock when the Select Connection dialog is up, user plugs in a device, and the Remote Connections view is shown
dadubrow
parents: 860
diff changeset
   133
		// avoid deadlock if this called as a result of a launch sequence issuing a "select connection" dialog
9eff68f52ec6 Fix deadlock when the Select Connection dialog is up, user plugs in a device, and the Remote Connections view is shown
dadubrow
parents: 860
diff changeset
   134
		Shell shell = WorkbenchUtils.getActiveShell();
9eff68f52ec6 Fix deadlock when the Select Connection dialog is up, user plugs in a device, and the Remote Connections view is shown
dadubrow
parents: 860
diff changeset
   135
		if (shell == null || !shell.isVisible()) {
9eff68f52ec6 Fix deadlock when the Select Connection dialog is up, user plugs in a device, and the Remote Connections view is shown
dadubrow
parents: 860
diff changeset
   136
			RunRunnableWhenWorkbenchVisibleJob.start(new Runnable() {
9eff68f52ec6 Fix deadlock when the Select Connection dialog is up, user plugs in a device, and the Remote Connections view is shown
dadubrow
parents: 860
diff changeset
   137
				public void run() {
9eff68f52ec6 Fix deadlock when the Select Connection dialog is up, user plugs in a device, and the Remote Connections view is shown
dadubrow
parents: 860
diff changeset
   138
					// try to show the connections view to start service testers
9eff68f52ec6 Fix deadlock when the Select Connection dialog is up, user plugs in a device, and the Remote Connections view is shown
dadubrow
parents: 860
diff changeset
   139
					try {
9eff68f52ec6 Fix deadlock when the Select Connection dialog is up, user plugs in a device, and the Remote Connections view is shown
dadubrow
parents: 860
diff changeset
   140
						WorkbenchUtils.getView(CONNECTIONS_VIEW_ID);
9eff68f52ec6 Fix deadlock when the Select Connection dialog is up, user plugs in a device, and the Remote Connections view is shown
dadubrow
parents: 860
diff changeset
   141
					} catch (PartInitException e) {
9eff68f52ec6 Fix deadlock when the Select Connection dialog is up, user plugs in a device, and the Remote Connections view is shown
dadubrow
parents: 860
diff changeset
   142
					}
860
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   143
				}
932
9eff68f52ec6 Fix deadlock when the Select Connection dialog is up, user plugs in a device, and the Remote Connections view is shown
dadubrow
parents: 860
diff changeset
   144
			});
9eff68f52ec6 Fix deadlock when the Select Connection dialog is up, user plugs in a device, and the Remote Connections view is shown
dadubrow
parents: 860
diff changeset
   145
		} else {
9eff68f52ec6 Fix deadlock when the Select Connection dialog is up, user plugs in a device, and the Remote Connections view is shown
dadubrow
parents: 860
diff changeset
   146
			Display.getDefault().asyncExec(new Runnable() {
9eff68f52ec6 Fix deadlock when the Select Connection dialog is up, user plugs in a device, and the Remote Connections view is shown
dadubrow
parents: 860
diff changeset
   147
				public void run() {
9eff68f52ec6 Fix deadlock when the Select Connection dialog is up, user plugs in a device, and the Remote Connections view is shown
dadubrow
parents: 860
diff changeset
   148
					try {
9eff68f52ec6 Fix deadlock when the Select Connection dialog is up, user plugs in a device, and the Remote Connections view is shown
dadubrow
parents: 860
diff changeset
   149
						WorkbenchUtils.getView(CONNECTIONS_VIEW_ID);
9eff68f52ec6 Fix deadlock when the Select Connection dialog is up, user plugs in a device, and the Remote Connections view is shown
dadubrow
parents: 860
diff changeset
   150
					} catch (PartInitException e) {
9eff68f52ec6 Fix deadlock when the Select Connection dialog is up, user plugs in a device, and the Remote Connections view is shown
dadubrow
parents: 860
diff changeset
   151
					}
9eff68f52ec6 Fix deadlock when the Select Connection dialog is up, user plugs in a device, and the Remote Connections view is shown
dadubrow
parents: 860
diff changeset
   152
				}
9eff68f52ec6 Fix deadlock when the Select Connection dialog is up, user plugs in a device, and the Remote Connections view is shown
dadubrow
parents: 860
diff changeset
   153
			});
9eff68f52ec6 Fix deadlock when the Select Connection dialog is up, user plugs in a device, and the Remote Connections view is shown
dadubrow
parents: 860
diff changeset
   154
		}
860
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   155
	}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   156
	
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   157
	private void reconcileAsCurrent(IConnection connection) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   158
		if (canBeSetToCurrent(connection)) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   159
			if (isReady(connection)) { // set as current
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   160
				reconcilerSetCurrentConnection = connection;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   161
				manager.setCurrentConnection(connection);
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   162
			} else if (isNotReady(connection) && connection.equals(manager.getCurrentConnection())) { 
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   163
				// unset current or set something else current
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   164
				if (isDynamic(connection) && userSetCurrentConnection != null) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   165
					manager.setCurrentConnection(userSetCurrentConnection);
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   166
				}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   167
				else {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   168
					// look for some other existing connection that is ready
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   169
					for (IConnection c : manager.getConnections()) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   170
						if (canBeSetToCurrent(c) && isReady(c)) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   171
							reconcilerSetCurrentConnection = connection;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   172
							manager.setCurrentConnection(connection);
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   173
							return;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   174
						}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   175
					}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   176
					// set to no current connection
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   177
					manager.setCurrentConnection(null);
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   178
				}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   179
			}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   180
		}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   181
	}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   182
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   183
	private boolean isReady(IConnection connection) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   184
		return equalsConnectionStatus(connection, EConnectionStatus.READY);
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   185
	}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   186
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   187
	private boolean isNotReady(IConnection connection) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   188
		return equalsConnectionStatus(connection, EConnectionStatus.NOT_READY);
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   189
	}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   190
	
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   191
	private boolean equalsConnectionStatus(IConnection connection, EConnectionStatus status) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   192
		if (connection instanceof IConnection2) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   193
			IConnectionStatus connectionStatus = ((IConnection2) connection).getStatus();
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   194
			if (connectionStatus != null)
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   195
				return connectionStatus.getEConnectionStatus().equals(status);
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   196
		}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   197
		return false;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   198
	}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   199
	
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   200
	private boolean canBeSetToCurrent(IConnection connection) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   201
		// USB connections for now
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   202
		return USBConnectionType.ID.equals(connection.getConnectionType().getIdentifier());
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   203
	}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   204
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   205
	private void reconcileStatus(IConnection connection) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   206
		if (!isDynamic(connection)) // don't set status for user generated connections
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   207
			return;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   208
		
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   209
		boolean isSysTRK = false;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   210
		EStatus trkStatus = EStatus.UNKNOWN;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   211
		EStatus traceStatus = EStatus.UNKNOWN;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   212
		for (IConnectedService service : manager.getConnectedServices(connection)) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   213
			if (service instanceof TRKConnectedService) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   214
				isSysTRK = isSysTRK((TRKConnectedService) service);
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   215
				trkStatus = service.getStatus().getEStatus();
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   216
			}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   217
			if (service instanceof TracingConnectedService) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   218
				traceStatus = service.getStatus().getEStatus();
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   219
			}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   220
		}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   221
		setConnectionStatus((IConnection2) connection, isSysTRK, trkStatus, traceStatus);
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   222
	}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   223
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   224
	private void setConnectionStatus(IConnection2 connection, boolean isSysTRK, EStatus trkStatus, EStatus traceStatus) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   225
		// use trk status
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   226
		EConnectionStatus connectionStatus = service2ConnectionStatus(trkStatus);
965
7942782aa571 remove trace status from reconcile logic
dadubrow
parents: 932
diff changeset
   227
		// NOTE: removing trace status logic for now
7942782aa571 remove trace status from reconcile logic
dadubrow
parents: 932
diff changeset
   228
//		// if sys trk, tracing also used
7942782aa571 remove trace status from reconcile logic
dadubrow
parents: 932
diff changeset
   229
//		if (isSysTRK && connectionStatus.equals(EConnectionStatus.READY)) {
7942782aa571 remove trace status from reconcile logic
dadubrow
parents: 932
diff changeset
   230
//			connectionStatus = service2ConnectionStatus(traceStatus);
7942782aa571 remove trace status from reconcile logic
dadubrow
parents: 932
diff changeset
   231
//		}
860
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   232
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   233
		String shortDesc = getShortDescriptionForStatus(connectionStatus);
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   234
		StringBuilder longDesc = new StringBuilder(Messages.getString("ConnectionStatusReconciler_TRKServicePrefix")); //$NON-NLS-1$
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   235
		longDesc.append(getServiceStatusString(trkStatus));
965
7942782aa571 remove trace status from reconcile logic
dadubrow
parents: 932
diff changeset
   236
//		if (isSysTRK) {
7942782aa571 remove trace status from reconcile logic
dadubrow
parents: 932
diff changeset
   237
//			longDesc.append(Messages.getString("ConnectionStatusReconciler_TracingServicePrefix")); //$NON-NLS-1$
7942782aa571 remove trace status from reconcile logic
dadubrow
parents: 932
diff changeset
   238
//			longDesc.append(getServiceStatusString(traceStatus));
7942782aa571 remove trace status from reconcile logic
dadubrow
parents: 932
diff changeset
   239
//		}
860
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   240
		
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   241
		connection.setStatus(new ConnectionStatus(connectionStatus, shortDesc, longDesc.toString()));
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   242
	}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   243
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   244
	private String getShortDescriptionForStatus(EConnectionStatus connectionStatus) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   245
		switch (connectionStatus) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   246
			case READY:
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   247
				return Messages.getString("ConnectionStatusReconciler_ReadyLabel"); //$NON-NLS-1$
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   248
			case NOT_READY:
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   249
				return Messages.getString("ConnectionStatusReconciler_NotReadyLabel"); //$NON-NLS-1$
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   250
			case IN_USE:
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   251
				return Messages.getString("ConnectionStatusReconciler_InUseLabel"); //$NON-NLS-1$
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   252
			case IN_USE_DISCONNECTED:
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   253
				return Messages.getString("ConnectionStatusReconciler_DisconnectedLabel"); //$NON-NLS-1$
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   254
			}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   255
		return ""; //$NON-NLS-1$
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   256
	}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   257
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   258
	private String getServiceStatusString(EStatus status) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   259
		switch (status) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   260
			case UP:
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   261
				return Messages.getString("ConnectionStatusReconciler_availableLabel"); //$NON-NLS-1$
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   262
			case DOWN:
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   263
				return Messages.getString("ConnectionStatusReconciler_unavailableLabel"); //$NON-NLS-1$
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   264
			case IN_USE:
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   265
				return Messages.getString("ConnectionStatusReconciler_inUseLabel_lower"); //$NON-NLS-1$
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   266
		}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   267
		return ""; //$NON-NLS-1$
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   268
	}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   269
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   270
	private EConnectionStatus service2ConnectionStatus(EStatus serviceStatus) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   271
		switch (serviceStatus) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   272
			case UP:
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   273
				return EConnectionStatus.READY;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   274
			case DOWN:
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   275
				return EConnectionStatus.NOT_READY;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   276
			case IN_USE:
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   277
				return EConnectionStatus.IN_USE;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   278
		}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   279
		return EConnectionStatus.NONE;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   280
	}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   281
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   282
	private void removeConnection(IConnection connection) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   283
		handledConnections.remove(connection);
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   284
	}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   285
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   286
	private IConnection findConnection(IConnectedService cs) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   287
		for (IConnection connection : handledConnections) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   288
			for (IConnectedService connectedService : manager.getConnectedServices(connection)) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   289
				if (cs.equals(connectedService))
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   290
					return connection;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   291
			}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   292
		}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   293
		return null;
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   294
	}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   295
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   296
	public void handleServiceStatusChange(IStatus status) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   297
		IConnectedService service = status.getConnectedService();
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   298
		IConnection connection = findConnection(service);
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   299
		if (connection instanceof IConnection2) {
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   300
			reconcileStatus((IConnection2) connection);
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   301
		}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   302
		if (connection != null)
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   303
			reconcileAsCurrent(connection);
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   304
	}
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   305
fd6ae4e6e3d9 (no commit message)
dadubrow
parents:
diff changeset
   306
}