fix bug 11353 (uncaught exception when parsing version info from buildinfo.txt) RCL_2_4
authortimkelly
Thu, 27 May 2010 13:16:19 -0500
branchRCL_2_4
changeset 1409 46e446d635cc
parent 1400 16a9fd5ca5df
child 1411 7fc85d03006a
fix bug 11353 (uncaught exception when parsing version info from buildinfo.txt)
core/com.nokia.carbide.cpp.sdk.core/src/com/nokia/carbide/cpp/internal/sdk/core/model/SymbianSDK.java
--- a/core/com.nokia.carbide.cpp.sdk.core/src/com/nokia/carbide/cpp/internal/sdk/core/model/SymbianSDK.java	Tue May 25 13:38:07 2010 -0500
+++ b/core/com.nokia.carbide.cpp.sdk.core/src/com/nokia/carbide/cpp/internal/sdk/core/model/SymbianSDK.java	Thu May 27 13:16:19 2010 -0500
@@ -1000,7 +1000,7 @@
 	
 	/**
 	 * Scans the SDK's epoc32\data\buildinfo.txt file and tries to build the Version
-	 * and branch identifiers. This should not be called when a manifest.xml file exits
+	 * and branch identifiers. This should not be called when a manifest.xml file exits.
 	 *
 	 */
 	private void scanSDKForVersionInfo(){
@@ -1009,6 +1009,9 @@
 		if (!bldInfoFile.exists())
 			return;
 		
+		if (getOSVersion().getMajor() == 0)
+			setOSVersion(new Version("9.5.0"));  // Set a default version that will work with all EKA2
+		
 		try {
 			char[] cbuf = new char[(int) bldInfoFile.length()];
 			Reader reader = new FileReader(bldInfoFile);
@@ -1026,11 +1029,15 @@
 					String[] versionTokens = line.split(" ");
 					if (versionTokens.length == 3){
 						
-						if (versionTokens[2].toUpperCase().startsWith("TB92SF") || versionTokens[2].toUpperCase().endsWith("TB92SF")){
+						if (versionTokens[2].toUpperCase().contains("TB92SF")){
 							setOSVersion(new Version("9.5.0"));
 							setSDKVersion(new Version("5.2.0"));
 							break;
-						} else if (versionTokens[2].toUpperCase().startsWith("TB101SF") || versionTokens[2].toUpperCase().endsWith("TB101SF")){
+						} else if (versionTokens[2].toUpperCase().contains("TB101SF")){
+							setOSVersion(new Version("9.6.0"));
+							setSDKVersion(new Version("6.0.0"));
+							break;
+						} else if (versionTokens[2].toUpperCase().contains("TB102SF")){
 							setOSVersion(new Version("9.6.0"));
 							setSDKVersion(new Version("6.0.0"));
 							break;
@@ -1039,24 +1046,6 @@
 							int index = versionTokens[2].lastIndexOf("v");
 							String osVersionString = versionTokens[2].substring(index+1, versionTokens[2].length());
 							
-							if (osVersionString.compareToIgnoreCase("tb91sf") == 0){
-								setOSVersion(new Version("9.4.0"));
-								setSDKVersion(new Version("5.1.0"));
-								break;
-							}
-							
-							if (osVersionString.compareToIgnoreCase("tb92sf") == 0){
-								setOSVersion(new Version("9.5.0"));
-								setSDKVersion(new Version("5.2.0"));
-								break;
-							}
-							
-							if (osVersionString.compareToIgnoreCase("tb101sf") == 0){
-								setOSVersion(new Version("9.6.0"));
-								setSDKVersion(new Version("6.0.0"));
-								break;
-							}
-							
 							if (osVersionString.endsWith(EKA1_A_BRANCH_IDENTIFIER) || 
 							    osVersionString.endsWith(EKA2_B_BRANCH_IDENTIFIER) ||
 							    osVersionString.endsWith(EKA1_S_BRANCH_IDENTIFIER)){
@@ -1068,9 +1057,14 @@
 							}
 							
 							// Set the version, split on alphanumeric to get rid of any junk at the end
-							String[] tempStr = osVersionString.split("[a-zA-Z]");
+							String[] tempStr = osVersionString.split("[a-zA-Z_]");
 							if (tempStr.length != 0){
-								setOSVersion(Version.parseVersion(tempStr[0]));
+								try {
+									setOSVersion(Version.parseVersion(tempStr[0]));
+								} catch (Exception e) {
+									// ignore, default version already set
+									// just catch exception so we move along to the next SDK
+								}
 							}
 						}
 					}