Improved handling of auto-generated connection name in remote connections wizard. RCL_2_4
authorstechong
Wed, 07 Apr 2010 12:02:59 -0500
branchRCL_2_4
changeset 1167 7a7fb0b5dd0b
parent 1164 a4892a66eacf
child 1168 8e38fdef1cea
Improved handling of auto-generated connection name in remote connections wizard.
connectivity/com.nokia.carbide.remoteConnections/src/com/nokia/carbide/remoteconnections/settings/ui/ConnectionSettingsPage.java
--- a/connectivity/com.nokia.carbide.remoteConnections/src/com/nokia/carbide/remoteconnections/settings/ui/ConnectionSettingsPage.java	Wed Apr 07 09:06:07 2010 -0500
+++ b/connectivity/com.nokia.carbide.remoteConnections/src/com/nokia/carbide/remoteconnections/settings/ui/ConnectionSettingsPage.java	Wed Apr 07 12:02:59 2010 -0500
@@ -129,15 +129,16 @@
 		}
 	}
 
-	private final static TreeNode LOADING_CONTENT_TREENODE = 
+	private static final TreeNode LOADING_CONTENT_TREENODE = 
 		new TreeNode(Messages.getString("ConnectionSettingsPage.GettingDataMessage")); //$NON-NLS-1$
 	private static final TreeNode[] LOADING_CONTENT_INPUT = new TreeNode[] { LOADING_CONTENT_TREENODE };
 	private static final String STATUS_NOT_TESTED = 
 		Messages.getString("ConnectionSettingsPage.NotTestedStatusString"); //$NON-NLS-1$
-	private final static Image FOLDER_ICON_IMG = 
+	private static final Image FOLDER_ICON_IMG = 
 		PlatformUI.getWorkbench().getSharedImages().getImageDescriptor(
 				ISharedImages.IMG_OBJ_FOLDER).createImage();
-	private static final String INITIAL_NAME_FMT = "connection {0}"; //$NON-NLS-1$
+	private static final String CONNECTION_PREFIX = "connection"; //$NON-NLS-1$
+	private static final String INITIAL_NAME_FMT = "{0} {1}"; //$NON-NLS-1$
 	private static final String UID = ".uid"; //$NON-NLS-1$
 	private final SettingsWizard settingsWizard;
 	private IConnectionType connectionType;
@@ -649,12 +650,18 @@
 	}
 
 	public void settingsChanged() {
-		if (!modifiedName && editingUI != null) {
-			String preferredName = editingUI.getSettings().get(IConnectionFactory2.PREFERRED_CONNECTION_NAME);
-			if (preferredName != null) {
-				nameText.setText(preferredName);
-				modifiedName = false;
+		if (!modifiedName) {
+			if (editingUI != null) {
+				String preferredName = editingUI.getSettings().get(IConnectionFactory2.PREFERRED_CONNECTION_NAME);
+				if (preferredName != null) {
+					nameText.setText(getPreferredNameText(preferredName));
+					modifiedName = false;
+					return;
+				}
 			}
+			// when editingUI or preferredName is null
+			nameText.setText(getInitialNameText());
+			modifiedName = false;
 		}
 	}
 
@@ -1067,14 +1074,30 @@
 
 	private String getInitialNameText() {
 		IConnection connectionToEdit = settingsWizard.getConnectionToEdit();
-		if (connectionToEdit != null)
+		if (connectionToEdit != null) {
 			return connectionToEdit.getDisplayName();
+		}
 		
 		long i = 1;
 		while (true) {
-			String name = MessageFormat.format(INITIAL_NAME_FMT, new Object[] { Long.toString(i++) });
-			if (isNameUnique(name))
+			String name = MessageFormat.format(INITIAL_NAME_FMT, CONNECTION_PREFIX, Long.toString(i++));
+			if (isNameUnique(name)) {
 				return name;
+			}
+		}
+	}
+
+	private String getPreferredNameText(String preferredName) {
+		if (isNameUnique(preferredName)) {
+			return preferredName;
+		}
+
+		long i = 1;
+		while (true) {
+			String name = MessageFormat.format(INITIAL_NAME_FMT, preferredName, Long.toString(i++));
+			if (isNameUnique(name)) {
+				return name;
+			}
 		}
 	}