From ec6e66268829e09df3f2b9d68500e672d35a8008 Mon Sep 17 00:00:00 2001 From: Jeff Sharkey Date: Fri, 14 Sep 2012 13:01:17 -0700 Subject: Treat cache storage usage as available space. Bug: 7123160 Change-Id: I1b3f36622be557d7c47f1452832f67da40893a02 --- .../settings/deviceinfo/StorageMeasurement.java | 43 ++++++++++++++-------- .../StorageVolumePreferenceCategory.java | 6 ++- 2 files changed, 33 insertions(+), 16 deletions(-) (limited to 'src') diff --git a/src/com/android/settings/deviceinfo/StorageMeasurement.java b/src/com/android/settings/deviceinfo/StorageMeasurement.java index 50238f3..772ac0d 100644 --- a/src/com/android/settings/deviceinfo/StorageMeasurement.java +++ b/src/com/android/settings/deviceinfo/StorageMeasurement.java @@ -96,6 +96,9 @@ public class StorageMeasurement { } public static class MeasurementDetails { + public long totalSize; + public long availSize; + /** * Total apps disk usage. *

@@ -111,6 +114,11 @@ public class StorageMeasurement { public long appsSize; /** + * Total cache disk usage by apps. + */ + public long cacheSize; + + /** * Total media disk usage, categorized by types such as * {@link Environment#DIRECTORY_MUSIC}. *

@@ -237,34 +245,36 @@ public class StorageMeasurement { } private void addStatsLocked(PackageStats stats) { - final long externalSize = stats.externalCodeSize + stats.externalDataSize - + stats.externalCacheSize + stats.externalMediaSize; - if (mIsInternal) { - final long codeSize; - final long dataSize; + long codeSize = stats.codeSize; + long dataSize = stats.dataSize; + long cacheSize = stats.cacheSize; if (Environment.isExternalStorageEmulated()) { - // OBB is shared on emulated storage, so count once as code, - // and data includes emulated storage. - codeSize = stats.codeSize + stats.externalObbSize; - dataSize = stats.dataSize + externalSize; - } else { - codeSize = stats.codeSize; - dataSize = stats.dataSize; + // Include emulated storage when measuring internal. OBB is + // shared on emulated storage, so treat as code. + codeSize += stats.externalCodeSize + stats.externalObbSize; + dataSize += stats.externalDataSize + stats.externalMediaSize; + cacheSize += stats.externalCacheSize; } - // Include code and combined data for current user + // Count code and data for current user if (stats.userHandle == mCurrentUser) { mDetails.appsSize += codeSize; mDetails.appsSize += dataSize; } - // Include combined data for user summary + // User summary only includes data (code is only counted once + // for the current user) addValue(mDetails.usersSize, stats.userHandle, dataSize); + // Include cache for all users + mDetails.cacheSize += cacheSize; + } else { // Physical storage; only count external sizes - mDetails.appsSize += externalSize + stats.externalObbSize; + mDetails.appsSize += stats.externalCodeSize + stats.externalDataSize + + stats.externalMediaSize + stats.externalObbSize; + mDetails.cacheSize += stats.externalCacheSize; } } } @@ -389,6 +399,9 @@ public class StorageMeasurement { final MeasurementDetails details = new MeasurementDetails(); final Message finished = obtainMessage(MSG_COMPLETED, details); + details.totalSize = mTotalSize; + details.availSize = mAvailSize; + final UserManager userManager = (UserManager) context.getSystemService( Context.USER_SERVICE); final List users = userManager.getUsers(); diff --git a/src/com/android/settings/deviceinfo/StorageVolumePreferenceCategory.java b/src/com/android/settings/deviceinfo/StorageVolumePreferenceCategory.java index 469dbc7..44d40a0 100644 --- a/src/com/android/settings/deviceinfo/StorageVolumePreferenceCategory.java +++ b/src/com/android/settings/deviceinfo/StorageVolumePreferenceCategory.java @@ -312,6 +312,10 @@ public class StorageVolumePreferenceCategory extends PreferenceCategory { final boolean showDetails = mVolume == null || mVolume.isPrimary(); if (!showDetails) return; + // Count caches as available space, since system manages them + mItemTotal.setSummary(formatSize(details.totalSize)); + mItemAvailable.setSummary(formatSize(details.availSize + details.cacheSize)); + mUsageBarPreference.clear(); updatePreference(mItemApps, details.appsSize); @@ -326,7 +330,7 @@ public class StorageVolumePreferenceCategory extends PreferenceCategory { updatePreference(mItemMusic, musicSize); final long downloadsSize = totalValues(details.mediaSize, Environment.DIRECTORY_DOWNLOADS); - updatePreference(mItemDownloads, musicSize); + updatePreference(mItemDownloads, downloadsSize); updatePreference(mItemMisc, details.miscSize); -- cgit v1.1