diff options
Diffstat (limited to 'sdkmanager')
2 files changed, 36 insertions, 29 deletions
diff --git a/sdkmanager/libs/sdkuilib/src/com/android/sdkuilib/internal/repository/sdkman2/PackagesDiffLogic.java b/sdkmanager/libs/sdkuilib/src/com/android/sdkuilib/internal/repository/sdkman2/PackagesDiffLogic.java index 944dffb..3d7cdb0 100755 --- a/sdkmanager/libs/sdkuilib/src/com/android/sdkuilib/internal/repository/sdkman2/PackagesDiffLogic.java +++ b/sdkmanager/libs/sdkuilib/src/com/android/sdkuilib/internal/repository/sdkman2/PackagesDiffLogic.java @@ -16,6 +16,7 @@ package com.android.sdkuilib.internal.repository.sdkman2; +import com.android.sdklib.AndroidVersion; import com.android.sdklib.IAndroidTarget; import com.android.sdklib.SdkConstants; import com.android.sdklib.internal.repository.ExtraPackage; @@ -609,7 +610,7 @@ class PackagesDiffLogic { // Sort by API if (pkg instanceof IPackageVersion) { - return ((IPackageVersion) pkg).getVersion().getApiLevel(); + return ((IPackageVersion) pkg).getVersion(); } else if (pkg instanceof ToolPackage || pkg instanceof PlatformToolPackage) { return PkgCategoryApi.KEY_TOOLS; @@ -663,8 +664,11 @@ class PackagesDiffLogic { // Create API category. PkgCategory cat = null; - assert catKey instanceof Integer; - int apiKey = ((Integer) catKey).intValue(); + assert catKey instanceof AndroidVersion; + AndroidVersion key = (AndroidVersion) catKey; + + // We should not be trying to recreate the tools or extra categories. + assert !key.equals(PkgCategoryApi.KEY_TOOLS) && !key.equals(PkgCategoryApi.KEY_EXTRA); // We need a label for the category. // If we have an API level, try to get the info from the SDK Manager. @@ -672,19 +676,16 @@ class PackagesDiffLogic { // locally in the SDK Manager), it's OK we'll try to find the first platform // package available. String platformName = null; - if (apiKey >= 1 && apiKey != PkgCategoryApi.KEY_TOOLS) { - for (IAndroidTarget target : - mUpdaterData.getSdkManager().getTargets()) { - if (target.isPlatform() && - target.getVersion().getApiLevel() == apiKey) { - platformName = target.getVersionName(); - break; - } + for (IAndroidTarget target : + mUpdaterData.getSdkManager().getTargets()) { + if (target.isPlatform() && key.equals(target.getVersion())) { + platformName = target.getVersionName(); + break; } } cat = new PkgCategoryApi( - apiKey, + key, platformName, mUpdaterData.getImageFactory().getImageByName(PackagesPage.ICON_CAT_PLATFORM)); @@ -710,9 +711,11 @@ class PackagesDiffLogic { public int compare(PkgCategory cat1, PkgCategory cat2) { assert cat1 instanceof PkgCategoryApi; assert cat2 instanceof PkgCategoryApi; - int api1 = ((Integer) cat1.getKey()).intValue(); - int api2 = ((Integer) cat2.getKey()).intValue(); - return api2 - api1; + assert cat1.getKey() instanceof AndroidVersion; + assert cat2.getKey() instanceof AndroidVersion; + AndroidVersion v1 = (AndroidVersion) cat1.getKey(); + AndroidVersion v2 = (AndroidVersion) cat2.getKey(); + return v2.compareTo(v1); } }); } diff --git a/sdkmanager/libs/sdkuilib/src/com/android/sdkuilib/internal/repository/sdkman2/PkgCategoryApi.java b/sdkmanager/libs/sdkuilib/src/com/android/sdkuilib/internal/repository/sdkman2/PkgCategoryApi.java index 570883c..5bb4917 100755 --- a/sdkmanager/libs/sdkuilib/src/com/android/sdkuilib/internal/repository/sdkman2/PkgCategoryApi.java +++ b/sdkmanager/libs/sdkuilib/src/com/android/sdkuilib/internal/repository/sdkman2/PkgCategoryApi.java @@ -16,6 +16,8 @@ package com.android.sdkuilib.internal.repository.sdkman2; +import com.android.sdklib.AndroidVersion; + class PkgCategoryApi extends PkgCategory { @@ -23,15 +25,17 @@ class PkgCategoryApi extends PkgCategory { private String mPlatformName; // When sorting by Source, key is the hash of the source's name. - // When storing by API, key is the API level (>=1). Tools and extra have the - // special values so they get naturally sorted the way we want them. - // (Note: don't use max to avoid integers wrapping in comparisons. We can + // When storing by API, key is the AndroidVersion (API level >=1 + optional codename). + // We always want categories in order tools..platforms..extras; to achieve that tools + // and extras have the special values so they get "naturally" sorted the way we want + // them. + // (Note: don't use integer.max to avoid integers wrapping in comparisons. We can // revisit the day we get 2^30 platforms.) - public final static int KEY_TOOLS = Integer.MAX_VALUE / 2; - public final static int KEY_EXTRA = -1; + public final static AndroidVersion KEY_TOOLS = new AndroidVersion(Integer.MAX_VALUE / 2, null);; + public final static AndroidVersion KEY_EXTRA = new AndroidVersion(-1, null); - public PkgCategoryApi(int apiKey, String platformName, Object iconRef) { - super(apiKey, null /*label*/, iconRef); + public PkgCategoryApi(AndroidVersion version, String platformName, Object iconRef) { + super(version, null /*label*/, iconRef); setPlatformName(platformName); } @@ -48,13 +52,13 @@ class PkgCategoryApi extends PkgCategory { } public String getApiLabel() { - int api = ((Integer) getKey()).intValue(); - if (api == KEY_TOOLS) { + AndroidVersion key = (AndroidVersion) getKey(); + if (key.equals(KEY_TOOLS)) { return "TOOLS"; //$NON-NLS-1$ // for internal debug use only - } else if (api == KEY_EXTRA) { + } else if (key.equals(KEY_EXTRA)) { return "EXTRAS"; //$NON-NLS-1$ // for internal debug use only } else { - return String.format("API %1$d", getKey()); + return key.toString(); } } @@ -62,11 +66,11 @@ class PkgCategoryApi extends PkgCategory { public String getLabel() { String label = super.getLabel(); if (label == null) { - int key = ((Integer) getKey()).intValue(); + AndroidVersion key = (AndroidVersion) getKey(); - if (key == KEY_TOOLS) { + if (key.equals(KEY_TOOLS)) { label = "Tools"; - } else if (key == KEY_EXTRA) { + } else if (key.equals(KEY_EXTRA)) { label = "Extras"; } else { if (mPlatformName != null) { |