am 0f9daab7: Manage apps "third party" and "on sd card" filters were swapped.

Merge commit '0f9daab75f1557722b6e687a68eebfd5d28cbc51' into gingerbread-plus-aosp

* commit '0f9daab75f1557722b6e687a68eebfd5d28cbc51':
  Manage apps "third party" and "on sd card" filters were swapped.
This commit is contained in:
Dianne Hackborn
2010-07-30 15:25:29 -07:00
committed by Android Git Automerger
2 changed files with 233 additions and 244 deletions

View File

@@ -68,6 +68,10 @@ public class ApplicationsState {
final long id; final long id;
long size; long size;
long cacheSize;
long codeSize;
long dataSize;
String getNormalizedLabel() { String getNormalizedLabel() {
if (normalizedLabel != null) { if (normalizedLabel != null) {
return normalizedLabel; return normalizedLabel;
@@ -116,7 +120,9 @@ public class ApplicationsState {
public static final AppFilter THIRD_PARTY_FILTER = new AppFilter() { public static final AppFilter THIRD_PARTY_FILTER = new AppFilter() {
@Override @Override
public boolean filterApp(ApplicationInfo info) { public boolean filterApp(ApplicationInfo info) {
if ((info.flags & ApplicationInfo.FLAG_EXTERNAL_STORAGE) != 0) { if ((info.flags & ApplicationInfo.FLAG_UPDATED_SYSTEM_APP) != 0) {
return true;
} else if ((info.flags & ApplicationInfo.FLAG_SYSTEM) == 0) {
return true; return true;
} }
return false; return false;
@@ -126,9 +132,7 @@ public class ApplicationsState {
public static final AppFilter ON_SD_CARD_FILTER = new AppFilter() { public static final AppFilter ON_SD_CARD_FILTER = new AppFilter() {
@Override @Override
public boolean filterApp(ApplicationInfo info) { public boolean filterApp(ApplicationInfo info) {
if ((info.flags & ApplicationInfo.FLAG_UPDATED_SYSTEM_APP) != 0) { if ((info.flags & ApplicationInfo.FLAG_EXTERNAL_STORAGE) != 0) {
return true;
} else if ((info.flags & ApplicationInfo.FLAG_SYSTEM) == 0) {
return true; return true;
} }
return false; return false;
@@ -195,9 +199,10 @@ public class ApplicationsState {
// Ignore // Ignore
return; return;
} }
boolean avail = Intent.ACTION_EXTERNAL_APPLICATIONS_AVAILABLE.equals(actionStr);
for (String pkgName : pkgList) { for (String pkgName : pkgList) {
removePackage(pkgName); if (avail) addPackage(pkgName);
addPackage(pkgName); else removePackage(pkgName);
} }
} }
} }
@@ -316,6 +321,22 @@ public class ApplicationsState {
return filteredApps; return filteredApps;
} }
AppEntry getEntry(String packageName) {
synchronized (mEntriesMap) {
AppEntry entry = mEntriesMap.get(packageName);
if (entry == null) {
for (int i=0; i<mApplications.size(); i++) {
ApplicationInfo info = mApplications.get(i);
if (packageName.equals(info.packageName)) {
entry = getEntryLocked(info);
break;
}
}
}
return entry;
}
}
void ensureIcon(AppEntry entry) { void ensureIcon(AppEntry entry) {
if (entry.icon != null) { if (entry.icon != null) {
return; return;
@@ -442,8 +463,14 @@ public class ApplicationsState {
entry.sizeStale = false; entry.sizeStale = false;
entry.sizeLoadStart = 0; entry.sizeLoadStart = 0;
long newSize = getTotalSize(stats); long newSize = getTotalSize(stats);
if (entry.size != newSize) { if (entry.size != newSize ||
entry.cacheSize != stats.cacheSize ||
entry.codeSize != stats.codeSize ||
entry.dataSize != stats.dataSize) {
entry.size = newSize; entry.size = newSize;
entry.cacheSize = stats.cacheSize;
entry.codeSize = stats.codeSize;
entry.dataSize = stats.dataSize;
entry.sizeStr = getSizeStr(entry.size); entry.sizeStr = getSizeStr(entry.size);
if (DEBUG) Log.i(TAG, "Set size of " + entry.label + " " + entry if (DEBUG) Log.i(TAG, "Set size of " + entry.label + " " + entry
+ ": " + entry.sizeStr); + ": " + entry.sizeStr);

View File

@@ -18,9 +18,6 @@ package com.android.settings.applications;
import com.android.internal.content.PackageHelper; import com.android.internal.content.PackageHelper;
import com.android.settings.R; import com.android.settings.R;
import com.android.settings.R.id;
import com.android.settings.R.layout;
import com.android.settings.R.string;
import android.app.Activity; import android.app.Activity;
import android.app.ActivityManager; import android.app.ActivityManager;
@@ -35,22 +32,17 @@ import android.content.pm.ApplicationInfo;
import android.content.pm.IPackageDataObserver; import android.content.pm.IPackageDataObserver;
import android.content.pm.IPackageManager; import android.content.pm.IPackageManager;
import android.content.pm.IPackageMoveObserver; import android.content.pm.IPackageMoveObserver;
import android.content.pm.IPackageStatsObserver;
import android.content.pm.PackageInfo; import android.content.pm.PackageInfo;
import android.content.pm.PackageManager; import android.content.pm.PackageManager;
import android.content.pm.PackageParser;
import android.content.pm.PackageStats;
import android.content.pm.ResolveInfo; import android.content.pm.ResolveInfo;
import android.content.pm.PackageManager.NameNotFoundException; import android.content.pm.PackageManager.NameNotFoundException;
import android.net.Uri; import android.net.Uri;
import android.os.AsyncTask; import android.os.AsyncTask;
import android.os.Bundle; import android.os.Bundle;
import android.os.Handler; import android.os.Handler;
import android.os.IBinder;
import android.os.Message; import android.os.Message;
import android.os.RemoteException; import android.os.RemoteException;
import android.os.ServiceManager; import android.os.ServiceManager;
import android.os.storage.IMountService;
import android.text.format.Formatter; import android.text.format.Formatter;
import android.util.Log; import android.util.Log;
@@ -74,9 +66,14 @@ import android.widget.TextView;
* For non-system applications, there is no option to clear data. Instead there is an option to * For non-system applications, there is no option to clear data. Instead there is an option to
* uninstall the application. * uninstall the application.
*/ */
public class InstalledAppDetails extends Activity implements View.OnClickListener { public class InstalledAppDetails extends Activity
implements View.OnClickListener, ApplicationsState.Callbacks {
private static final String TAG="InstalledAppDetails"; private static final String TAG="InstalledAppDetails";
private ApplicationInfo mAppInfo;
private PackageManager mPm;
private ApplicationsState mState;
private ApplicationsState.AppEntry mAppEntry;
private PackageInfo mPackageInfo;
private Button mUninstallButton; private Button mUninstallButton;
private boolean mMoveInProgress = false; private boolean mMoveInProgress = false;
private boolean mUpdatedSysApp = false; private boolean mUpdatedSysApp = false;
@@ -86,7 +83,6 @@ public class InstalledAppDetails extends Activity implements View.OnClickListene
private TextView mTotalSize; private TextView mTotalSize;
private TextView mAppSize; private TextView mAppSize;
private TextView mDataSize; private TextView mDataSize;
private PkgSizeObserver mSizeObserver;
private ClearUserDataObserver mClearDataObserver; private ClearUserDataObserver mClearDataObserver;
// Views related to cache info // Views related to cache info
private TextView mCacheSize; private TextView mCacheSize;
@@ -97,18 +93,20 @@ public class InstalledAppDetails extends Activity implements View.OnClickListene
private Button mMoveAppButton; private Button mMoveAppButton;
private int mMoveErrorCode; private int mMoveErrorCode;
PackageStats mSizeInfo;
private PackageManager mPm;
private PackageMoveObserver mPackageMoveObserver; private PackageMoveObserver mPackageMoveObserver;
private boolean mHaveSizes = false;
private long mLastCodeSize = -1;
private long mLastDataSize = -1;
private long mLastCacheSize = -1;
private long mLastTotalSize = -1;
//internal constants used in Handler //internal constants used in Handler
private static final int OP_SUCCESSFUL = 1; private static final int OP_SUCCESSFUL = 1;
private static final int OP_FAILED = 2; private static final int OP_FAILED = 2;
private static final int CLEAR_USER_DATA = 1; private static final int CLEAR_USER_DATA = 1;
private static final int GET_PKG_SIZE = 2;
private static final int CLEAR_CACHE = 3; private static final int CLEAR_CACHE = 3;
private static final int PACKAGE_MOVE = 4; private static final int PACKAGE_MOVE = 4;
private static final String ATTR_PACKAGE_STATS="PackageStats";
// invalid size value used initially and also when size retrieval through PackageManager // invalid size value used initially and also when size retrieval through PackageManager
// fails for whatever reason // fails for whatever reason
@@ -137,12 +135,9 @@ public class InstalledAppDetails extends Activity implements View.OnClickListene
case CLEAR_USER_DATA: case CLEAR_USER_DATA:
processClearMsg(msg); processClearMsg(msg);
break; break;
case GET_PKG_SIZE:
refreshSizeInfo(msg);
break;
case CLEAR_CACHE: case CLEAR_CACHE:
// Refresh size info // Refresh size info
mPm.getPackageSizeInfo(mAppInfo.packageName, mSizeObserver); mState.requestSize(mAppEntry.info.packageName);
break; break;
case PACKAGE_MOVE: case PACKAGE_MOVE:
processMoveMsg(msg); processMoveMsg(msg);
@@ -161,17 +156,6 @@ public class InstalledAppDetails extends Activity implements View.OnClickListene
} }
} }
class PkgSizeObserver extends IPackageStatsObserver.Stub {
public void onGetStatsCompleted(PackageStats pStats, boolean succeeded) {
Message msg = mHandler.obtainMessage(GET_PKG_SIZE);
Bundle data = new Bundle();
data.putParcelable(ATTR_PACKAGE_STATS, pStats);
msg.setData(data);
mHandler.sendMessage(msg);
}
}
class ClearCacheObserver extends IPackageDataObserver.Stub { class ClearCacheObserver extends IPackageDataObserver.Stub {
public void onRemoveCompleted(final String packageName, final boolean succeeded) { public void onRemoveCompleted(final String packageName, final boolean succeeded) {
final Message msg = mHandler.obtainMessage(CLEAR_CACHE); final Message msg = mHandler.obtainMessage(CLEAR_CACHE);
@@ -196,7 +180,7 @@ public class InstalledAppDetails extends Activity implements View.OnClickListene
} }
private void initDataButtons() { private void initDataButtons() {
if (mAppInfo.manageSpaceActivityName != null) { if (mAppEntry.info.manageSpaceActivityName != null) {
mClearDataButton.setText(R.string.manage_space_text); mClearDataButton.setText(R.string.manage_space_text);
} else { } else {
mClearDataButton.setText(R.string.clear_user_data_text); mClearDataButton.setText(R.string.clear_user_data_text);
@@ -223,34 +207,25 @@ public class InstalledAppDetails extends Activity implements View.OnClickListene
} }
private void initMoveButton() { private void initMoveButton() {
String pkgName = mAppInfo.packageName;
boolean dataOnly = false; boolean dataOnly = false;
ApplicationInfo info1 = null; dataOnly = (mPackageInfo == null) && (mAppEntry != null);
PackageInfo pkgInfo = null;
try {
info1 = mPm.getApplicationInfo(pkgName, 0);
pkgInfo = mPm.getPackageInfo(mAppInfo.packageName,
PackageManager.GET_UNINSTALLED_PACKAGES);
} catch (NameNotFoundException e) {
}
dataOnly = (info1 == null) && (mAppInfo != null);
boolean moveDisable = true; boolean moveDisable = true;
if (dataOnly) { if (dataOnly) {
mMoveAppButton.setText(R.string.move_app); mMoveAppButton.setText(R.string.move_app);
} else if ((mAppInfo.flags & ApplicationInfo.FLAG_EXTERNAL_STORAGE) != 0) { } else if ((mAppEntry.info.flags & ApplicationInfo.FLAG_EXTERNAL_STORAGE) != 0) {
mMoveAppButton.setText(R.string.move_app_to_internal); mMoveAppButton.setText(R.string.move_app_to_internal);
// Always let apps move to internal storage from sdcard. // Always let apps move to internal storage from sdcard.
moveDisable = false; moveDisable = false;
} else { } else {
mMoveAppButton.setText(R.string.move_app_to_sdcard); mMoveAppButton.setText(R.string.move_app_to_sdcard);
if ((mAppInfo.flags & ApplicationInfo.FLAG_FORWARD_LOCK) == 0 && if ((mAppEntry.info.flags & ApplicationInfo.FLAG_FORWARD_LOCK) == 0 &&
(mAppInfo.flags & ApplicationInfo.FLAG_SYSTEM) == 0 && (mAppEntry.info.flags & ApplicationInfo.FLAG_SYSTEM) == 0 &&
pkgInfo != null) { mPackageInfo != null) {
if (pkgInfo.installLocation == PackageInfo.INSTALL_LOCATION_PREFER_EXTERNAL || if (mPackageInfo.installLocation == PackageInfo.INSTALL_LOCATION_PREFER_EXTERNAL ||
pkgInfo.installLocation == PackageInfo.INSTALL_LOCATION_AUTO) { mPackageInfo.installLocation == PackageInfo.INSTALL_LOCATION_AUTO) {
moveDisable = false; moveDisable = false;
} else if (pkgInfo.installLocation == PackageInfo.INSTALL_LOCATION_UNSPECIFIED) { } else if (mPackageInfo.installLocation
== PackageInfo.INSTALL_LOCATION_UNSPECIFIED) {
IPackageManager ipm = IPackageManager.Stub.asInterface( IPackageManager ipm = IPackageManager.Stub.asInterface(
ServiceManager.getService("package")); ServiceManager.getService("package"));
int loc; int loc;
@@ -277,32 +252,29 @@ public class InstalledAppDetails extends Activity implements View.OnClickListene
} }
private void initUninstallButtons() { private void initUninstallButtons() {
mUpdatedSysApp = (mAppInfo.flags & ApplicationInfo.FLAG_UPDATED_SYSTEM_APP) != 0; mUpdatedSysApp = (mAppEntry.info.flags & ApplicationInfo.FLAG_UPDATED_SYSTEM_APP) != 0;
boolean enabled = true; boolean enabled = true;
if (mUpdatedSysApp) { if (mUpdatedSysApp) {
mUninstallButton.setText(R.string.app_factory_reset); mUninstallButton.setText(R.string.app_factory_reset);
} else { } else {
if ((mAppInfo.flags & ApplicationInfo.FLAG_SYSTEM) != 0) { if ((mAppEntry.info.flags & ApplicationInfo.FLAG_SYSTEM) != 0) {
enabled = false; enabled = false;
try { try {
// Try to prevent the user from bricking their phone // Try to prevent the user from bricking their phone
// by not allowing disabling of apps signed with the // by not allowing disabling of apps signed with the
// system cert and any launcher app in the system. // system cert and any launcher app in the system.
PackageInfo pi = mPm.getPackageInfo(mAppInfo.packageName,
PackageManager.GET_DISABLED_COMPONENTS |
PackageManager.GET_UNINSTALLED_PACKAGES |
PackageManager.GET_SIGNATURES);
PackageInfo sys = mPm.getPackageInfo("android", PackageInfo sys = mPm.getPackageInfo("android",
PackageManager.GET_SIGNATURES); PackageManager.GET_SIGNATURES);
Intent intent = new Intent(Intent.ACTION_MAIN); Intent intent = new Intent(Intent.ACTION_MAIN);
intent.addCategory(Intent.CATEGORY_HOME); intent.addCategory(Intent.CATEGORY_HOME);
intent.setPackage(mAppInfo.packageName); intent.setPackage(mAppEntry.info.packageName);
List<ResolveInfo> homes = mPm.queryIntentActivities(intent, 0); List<ResolveInfo> homes = mPm.queryIntentActivities(intent, 0);
if ((homes != null && homes.size() > 0) if ((homes != null && homes.size() > 0) ||
|| sys.signatures[0].equals(pi.signatures[0])) { (mPackageInfo != null &&
sys.signatures[0].equals(mPackageInfo.signatures[0]))) {
// Disable button for core system applications. // Disable button for core system applications.
mUninstallButton.setText(R.string.disable_text); mUninstallButton.setText(R.string.disable_text);
} else if (mAppInfo.enabled) { } else if (mAppEntry.info.enabled) {
mUninstallButton.setText(R.string.disable_text); mUninstallButton.setText(R.string.disable_text);
enabled = true; enabled = true;
} else { } else {
@@ -323,49 +295,22 @@ public class InstalledAppDetails extends Activity implements View.OnClickListene
} }
} }
private boolean initAppInfo(String packageName) {
try {
mAppInfo = mPm.getApplicationInfo(packageName,
PackageManager.GET_UNINSTALLED_PACKAGES);
return true;
} catch (NameNotFoundException e) {
Log.e(TAG, "Exception when retrieving package: " + packageName, e);
showDialogInner(DLG_APP_NOT_FOUND);
return false;
}
}
/** Called when the activity is first created. */ /** Called when the activity is first created. */
@Override @Override
protected void onCreate(Bundle icicle) { protected void onCreate(Bundle icicle) {
super.onCreate(icicle); super.onCreate(icicle);
// Get package manager mState = ApplicationsState.getInstance(getApplication());
mPm = getPackageManager(); mPm = getPackageManager();
// Get application's name from intent
Intent intent = getIntent();
final String packageName = intent.getData().getSchemeSpecificPart();
if (! initAppInfo(packageName)) {
return; // could not find package, finish called
}
// Try retrieving package stats again
CharSequence totalSizeStr, appSizeStr, dataSizeStr;
mComputingStr = getText(R.string.computing_size);
totalSizeStr = appSizeStr = dataSizeStr = mComputingStr;
if(localLOGV) Log.i(TAG, "Have to compute package sizes");
mSizeObserver = new PkgSizeObserver();
setContentView(R.layout.installed_app_details); setContentView(R.layout.installed_app_details);
//TODO download str and download url
mComputingStr = getText(R.string.computing_size);
// Set default values on sizes // Set default values on sizes
mTotalSize = (TextView)findViewById(R.id.total_size_text); mTotalSize = (TextView)findViewById(R.id.total_size_text);
mTotalSize.setText(totalSizeStr);
mAppSize = (TextView)findViewById(R.id.application_size_text); mAppSize = (TextView)findViewById(R.id.application_size_text);
mAppSize.setText(appSizeStr);
mDataSize = (TextView)findViewById(R.id.data_size_text); mDataSize = (TextView)findViewById(R.id.data_size_text);
mDataSize.setText(dataSizeStr);
// Get Control button panel // Get Control button panel
View btnPanel = findViewById(R.id.control_buttons_panel); View btnPanel = findViewById(R.id.control_buttons_panel);
@@ -381,49 +326,20 @@ public class InstalledAppDetails extends Activity implements View.OnClickListene
// Cache section // Cache section
mCacheSize = (TextView) findViewById(R.id.cache_size_text); mCacheSize = (TextView) findViewById(R.id.cache_size_text);
mCacheSize.setText(mComputingStr);
mClearCacheButton = (Button) findViewById(R.id.clear_cache_button); mClearCacheButton = (Button) findViewById(R.id.clear_cache_button);
// Get list of preferred activities
mActivitiesButton = (Button)findViewById(R.id.clear_activities_button); mActivitiesButton = (Button)findViewById(R.id.clear_activities_button);
List<ComponentName> prefActList = new ArrayList<ComponentName>();
// Intent list cannot be null. so pass empty list
List<IntentFilter> intentList = new ArrayList<IntentFilter>();
mPm.getPreferredActivities(intentList, prefActList, packageName);
if(localLOGV) Log.i(TAG, "Have "+prefActList.size()+" number of activities in prefered list");
TextView autoLaunchView = (TextView)findViewById(R.id.auto_launch);
if(prefActList.size() <= 0) {
// Disable clear activities button
autoLaunchView.setText(R.string.auto_launch_disable_text);
mActivitiesButton.setEnabled(false);
} else {
autoLaunchView.setText(R.string.auto_launch_enable_text);
mActivitiesButton.setOnClickListener(this);
}
// Security permissions section
LinearLayout permsView = (LinearLayout) findViewById(R.id.permissions_section);
AppSecurityPermissions asp = new AppSecurityPermissions(this, packageName);
if(asp.getPermissionCount() > 0) {
permsView.setVisibility(View.VISIBLE);
// Make the security sections header visible
LinearLayout securityList = (LinearLayout) permsView.findViewById(
R.id.security_settings_list);
securityList.addView(asp.getPermissionsView());
} else {
permsView.setVisibility(View.GONE);
}
} }
// Utility method to set applicaiton label and icon. // Utility method to set applicaiton label and icon.
private void setAppLabelAndIcon(PackageInfo pkgInfo) { private void setAppLabelAndIcon(PackageInfo pkgInfo) {
View appSnippet = findViewById(R.id.app_snippet); View appSnippet = findViewById(R.id.app_snippet);
ImageView icon = (ImageView) appSnippet.findViewById(R.id.app_icon); ImageView icon = (ImageView) appSnippet.findViewById(R.id.app_icon);
icon.setImageDrawable(mAppInfo.loadIcon(mPm)); mState.ensureIcon(mAppEntry);
icon.setImageDrawable(mAppEntry.icon);
// Set application name. // Set application name.
TextView label = (TextView) appSnippet.findViewById(R.id.app_name); TextView label = (TextView) appSnippet.findViewById(R.id.app_name);
label.setText(mAppInfo.loadLabel(mPm)); label.setText(mAppEntry.label);
// Version number of application // Version number of application
mAppVersion = (TextView) appSnippet.findViewById(R.id.app_size); mAppVersion = (TextView) appSnippet.findViewById(R.id.app_size);
@@ -440,33 +356,103 @@ public class InstalledAppDetails extends Activity implements View.OnClickListene
public void onResume() { public void onResume() {
super.onResume(); super.onResume();
if (mAppInfo == null) { mState.resume(this);
if (!refreshUi()) {
setIntentAndFinish(true, true); setIntentAndFinish(true, true);
return; // onCreate must have failed, make sure to exit
} }
if (! initAppInfo(mAppInfo.packageName)) {
return; // could not find package, finish called
} }
PackageInfo pkgInfo = null; @Override
public void onPause() {
super.onPause();
mState.pause();
}
@Override
public void onAllSizesComputed() {
}
@Override
public void onPackageIconChanged() {
}
@Override
public void onPackageListChanged() {
refreshUi();
}
@Override
public void onPackageSizeChanged(String packageName) {
if (packageName.equals(mAppEntry.info.packageName)) {
refreshSizeInfo();
}
}
@Override
public void onRunningStateChanged(boolean running) {
}
private boolean refreshUi() {
if (mMoveInProgress) {
return true;
}
Intent intent = getIntent();
final String packageName = intent.getData().getSchemeSpecificPart();
mAppEntry = mState.getEntry(packageName);
if (mAppEntry == null) {
return false; // onCreate must have failed, make sure to exit
}
// Get application info again to refresh changed properties of application // Get application info again to refresh changed properties of application
try { try {
pkgInfo = mPm.getPackageInfo(mAppInfo.packageName, mPackageInfo = mPm.getPackageInfo(mAppEntry.info.packageName,
PackageManager.GET_UNINSTALLED_PACKAGES); PackageManager.GET_DISABLED_COMPONENTS |
PackageManager.GET_UNINSTALLED_PACKAGES |
PackageManager.GET_SIGNATURES);
} catch (NameNotFoundException e) { } catch (NameNotFoundException e) {
Log.e(TAG, "Exception when retrieving package:" + mAppInfo.packageName, e); Log.e(TAG, "Exception when retrieving package:" + mAppEntry.info.packageName, e);
showDialogInner(DLG_APP_NOT_FOUND); return false; // onCreate must have failed, make sure to exit
return; // could not find package, finish called }
// Get list of preferred activities
List<ComponentName> prefActList = new ArrayList<ComponentName>();
// Intent list cannot be null. so pass empty list
List<IntentFilter> intentList = new ArrayList<IntentFilter>();
mPm.getPreferredActivities(intentList, prefActList, packageName);
if(localLOGV) Log.i(TAG, "Have "+prefActList.size()+" number of activities in prefered list");
TextView autoLaunchView = (TextView)findViewById(R.id.auto_launch);
if (prefActList.size() <= 0) {
// Disable clear activities button
autoLaunchView.setText(R.string.auto_launch_disable_text);
mActivitiesButton.setEnabled(false);
} else {
autoLaunchView.setText(R.string.auto_launch_enable_text);
mActivitiesButton.setEnabled(true);
mActivitiesButton.setOnClickListener(this);
}
// Security permissions section
LinearLayout permsView = (LinearLayout) findViewById(R.id.permissions_section);
AppSecurityPermissions asp = new AppSecurityPermissions(this, packageName);
if (asp.getPermissionCount() > 0) {
permsView.setVisibility(View.VISIBLE);
// Make the security sections header visible
LinearLayout securityList = (LinearLayout) permsView.findViewById(
R.id.security_settings_list);
securityList.removeAllViews();
securityList.addView(asp.getPermissionsView());
} else {
permsView.setVisibility(View.GONE);
} }
checkForceStop(); checkForceStop();
setAppLabelAndIcon(pkgInfo); setAppLabelAndIcon(mPackageInfo);
refreshButtons(); refreshButtons();
refreshSizeInfo();
// Refresh size info return true;
if (mAppInfo != null && mAppInfo.packageName != null) {
mPm.getPackageSizeInfo(mAppInfo.packageName, mSizeObserver);
}
} }
private void setIntentAndFinish(boolean finish, boolean appChanged) { private void setIntentAndFinish(boolean finish, boolean appChanged) {
@@ -479,62 +465,52 @@ public class InstalledAppDetails extends Activity implements View.OnClickListene
} }
} }
/* private void refreshSizeInfo() {
* Private method to handle get size info notification from observer when if (mAppEntry.size == ApplicationsState.SIZE_INVALID
* the async operation from PackageManager is complete. The current user data || mAppEntry.size == ApplicationsState.SIZE_UNKNOWN) {
* info has to be refreshed in the manage applications screen as well as the current screen. mLastCodeSize = mLastDataSize = mLastCacheSize = mLastTotalSize = -1;
*/ if (!mHaveSizes) {
private void refreshSizeInfo(Message msg) { mAppSize.setText(mComputingStr);
boolean changed = false; mDataSize.setText(mComputingStr);
PackageStats newPs = msg.getData().getParcelable(ATTR_PACKAGE_STATS); mCacheSize.setText(mComputingStr);
long newTot = newPs.cacheSize+newPs.codeSize+newPs.dataSize; mTotalSize.setText(mComputingStr);
if(mSizeInfo == null) {
mSizeInfo = newPs;
String str = getSizeStr(newTot);
mTotalSize.setText(str);
mAppSize.setText(getSizeStr(newPs.codeSize));
mDataSize.setText(getSizeStr(newPs.dataSize));
mCacheSize.setText(getSizeStr(newPs.cacheSize));
} else {
long oldTot = mSizeInfo.cacheSize+mSizeInfo.codeSize+mSizeInfo.dataSize;
if(newTot != oldTot) {
String str = getSizeStr(newTot);
mTotalSize.setText(str);
changed = true;
} }
if(newPs.codeSize != mSizeInfo.codeSize) {
mAppSize.setText(getSizeStr(newPs.codeSize));
changed = true;
}
if(newPs.dataSize != mSizeInfo.dataSize) {
mDataSize.setText(getSizeStr(newPs.dataSize));
changed = true;
}
if(newPs.cacheSize != mSizeInfo.cacheSize) {
mCacheSize.setText(getSizeStr(newPs.cacheSize));
changed = true;
}
if(changed) {
mSizeInfo = newPs;
}
}
// If data size is zero disable clear data button
if (newPs.dataSize == 0) {
mClearDataButton.setEnabled(false); mClearDataButton.setEnabled(false);
mClearCacheButton.setEnabled(false);
} else {
mHaveSizes = true;
if (mLastCodeSize != mAppEntry.codeSize) {
mLastCodeSize = mAppEntry.codeSize;
mAppSize.setText(getSizeStr(mAppEntry.codeSize));
} }
long data = mSizeInfo.dataSize; if (mLastDataSize != mAppEntry.dataSize) {
refreshCacheInfo(newPs.cacheSize); mLastDataSize = mAppEntry.dataSize;
mDataSize.setText(getSizeStr(mAppEntry.dataSize));
}
if (mLastCacheSize != mAppEntry.cacheSize) {
mLastCacheSize = mAppEntry.cacheSize;
mCacheSize.setText(getSizeStr(mAppEntry.cacheSize));
}
if (mLastTotalSize != mAppEntry.size) {
mLastTotalSize = mAppEntry.size;
mTotalSize.setText(getSizeStr(mAppEntry.size));
} }
private void refreshCacheInfo(long cacheSize) { if (mAppEntry.dataSize <= 0) {
// Set cache info mClearDataButton.setEnabled(false);
mCacheSize.setText(getSizeStr(cacheSize)); } else {
if (cacheSize <= 0) { mClearDataButton.setEnabled(true);
mClearDataButton.setOnClickListener(this);
}
if (mAppEntry.cacheSize <= 0) {
mClearCacheButton.setEnabled(false); mClearCacheButton.setEnabled(false);
} else { } else {
mClearCacheButton.setEnabled(true);
mClearCacheButton.setOnClickListener(this); mClearCacheButton.setOnClickListener(this);
} }
} }
}
/* /*
* Private method to handle clear message notification from observer when * Private method to handle clear message notification from observer when
@@ -542,11 +518,11 @@ public class InstalledAppDetails extends Activity implements View.OnClickListene
*/ */
private void processClearMsg(Message msg) { private void processClearMsg(Message msg) {
int result = msg.arg1; int result = msg.arg1;
String packageName = mAppInfo.packageName; String packageName = mAppEntry.info.packageName;
mClearDataButton.setText(R.string.clear_user_data_text); mClearDataButton.setText(R.string.clear_user_data_text);
if(result == OP_SUCCESSFUL) { if(result == OP_SUCCESSFUL) {
Log.i(TAG, "Cleared user data for package : "+packageName); Log.i(TAG, "Cleared user data for package : "+packageName);
mPm.getPackageSizeInfo(packageName, mSizeObserver); mState.requestSize(mAppEntry.info.packageName);
} else { } else {
mClearDataButton.setEnabled(true); mClearDataButton.setEnabled(true);
} }
@@ -567,23 +543,18 @@ public class InstalledAppDetails extends Activity implements View.OnClickListene
private void processMoveMsg(Message msg) { private void processMoveMsg(Message msg) {
int result = msg.arg1; int result = msg.arg1;
String packageName = mAppInfo.packageName; String packageName = mAppEntry.info.packageName;
// Refresh the button attributes. // Refresh the button attributes.
mMoveInProgress = false; mMoveInProgress = false;
if (result == PackageManager.MOVE_SUCCEEDED) { if (result == PackageManager.MOVE_SUCCEEDED) {
Log.i(TAG, "Moved resources for " + packageName); Log.i(TAG, "Moved resources for " + packageName);
// Refresh size information again. // Refresh size information again.
mPm.getPackageSizeInfo(packageName, mSizeObserver); mState.requestSize(mAppEntry.info.packageName);
} else { } else {
mMoveErrorCode = result; mMoveErrorCode = result;
showDialogInner(DLG_MOVE_FAILED); showDialogInner(DLG_MOVE_FAILED);
} }
refreshUi();
if (! initAppInfo(packageName)) {
return; // could not find package, finish called
}
refreshButtons();
} }
/* /*
@@ -593,7 +564,7 @@ public class InstalledAppDetails extends Activity implements View.OnClickListene
private void initiateClearUserData() { private void initiateClearUserData() {
mClearDataButton.setEnabled(false); mClearDataButton.setEnabled(false);
// Invoke uninstall or clear user data based on sysPackage // Invoke uninstall or clear user data based on sysPackage
String packageName = mAppInfo.packageName; String packageName = mAppEntry.info.packageName;
Log.i(TAG, "Clearing user data for package : " + packageName); Log.i(TAG, "Clearing user data for package : " + packageName);
if (mClearDataObserver == null) { if (mClearDataObserver == null) {
mClearDataObserver = new ClearUserDataObserver(); mClearDataObserver = new ClearUserDataObserver();
@@ -640,7 +611,7 @@ public class InstalledAppDetails extends Activity implements View.OnClickListene
new DialogInterface.OnClickListener() { new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int which) { public void onClick(DialogInterface dialog, int which) {
// Clear user data here // Clear user data here
uninstallPkg(mAppInfo.packageName); uninstallPkg(mAppEntry.info.packageName);
} }
}) })
.setNegativeButton(R.string.dlg_cancel, null) .setNegativeButton(R.string.dlg_cancel, null)
@@ -681,7 +652,7 @@ public class InstalledAppDetails extends Activity implements View.OnClickListene
new DialogInterface.OnClickListener() { new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int which) { public void onClick(DialogInterface dialog, int which) {
// Force stop // Force stop
forceStopPackage(mAppInfo.packageName); forceStopPackage(mAppEntry.info.packageName);
} }
}) })
.setNegativeButton(R.string.dlg_cancel, null) .setNegativeButton(R.string.dlg_cancel, null)
@@ -724,9 +695,9 @@ public class InstalledAppDetails extends Activity implements View.OnClickListene
private void checkForceStop() { private void checkForceStop() {
Intent intent = new Intent(Intent.ACTION_QUERY_PACKAGE_RESTART, Intent intent = new Intent(Intent.ACTION_QUERY_PACKAGE_RESTART,
Uri.fromParts("package", mAppInfo.packageName, null)); Uri.fromParts("package", mAppEntry.info.packageName, null));
intent.putExtra(Intent.EXTRA_PACKAGES, new String[] { mAppInfo.packageName }); intent.putExtra(Intent.EXTRA_PACKAGES, new String[] { mAppEntry.info.packageName });
intent.putExtra(Intent.EXTRA_UID, mAppInfo.uid); intent.putExtra(Intent.EXTRA_UID, mAppEntry.info.uid);
sendOrderedBroadcast(intent, null, mCheckKillProcessesReceiver, null, sendOrderedBroadcast(intent, null, mCheckKillProcessesReceiver, null,
Activity.RESULT_CANCELED, null, null); Activity.RESULT_CANCELED, null, null);
} }
@@ -749,16 +720,6 @@ public class InstalledAppDetails extends Activity implements View.OnClickListene
mPm.setApplicationEnabledSetting(mInfo.packageName, mState, 0); mPm.setApplicationEnabledSetting(mInfo.packageName, mState, 0);
return null; return null;
} }
@Override
protected void onPostExecute(Object result) {
InstalledAppDetails activity = mActivity.get();
if (activity != null) {
activity.initAppInfo(mInfo.packageName);
activity.checkForceStop();
activity.refreshButtons();
}
}
} }
/* /*
@@ -766,13 +727,13 @@ public class InstalledAppDetails extends Activity implements View.OnClickListene
* @see android.view.View.OnClickListener#onClick(android.view.View) * @see android.view.View.OnClickListener#onClick(android.view.View)
*/ */
public void onClick(View v) { public void onClick(View v) {
String packageName = mAppInfo.packageName; String packageName = mAppEntry.info.packageName;
if(v == mUninstallButton) { if(v == mUninstallButton) {
if (mUpdatedSysApp) { if (mUpdatedSysApp) {
showDialogInner(DLG_FACTORY_RESET); showDialogInner(DLG_FACTORY_RESET);
} else { } else {
if ((mAppInfo.flags & ApplicationInfo.FLAG_SYSTEM) != 0) { if ((mAppEntry.info.flags & ApplicationInfo.FLAG_SYSTEM) != 0) {
new DisableChanger(this, mAppInfo, mAppInfo.enabled ? new DisableChanger(this, mAppEntry.info, mAppEntry.info.enabled ?
PackageManager.COMPONENT_ENABLED_STATE_DISABLED PackageManager.COMPONENT_ENABLED_STATE_DISABLED
: PackageManager.COMPONENT_ENABLED_STATE_DEFAULT).execute((Object)null); : PackageManager.COMPONENT_ENABLED_STATE_DEFAULT).execute((Object)null);
} else { } else {
@@ -783,9 +744,10 @@ public class InstalledAppDetails extends Activity implements View.OnClickListene
mPm.clearPackagePreferredActivities(packageName); mPm.clearPackagePreferredActivities(packageName);
mActivitiesButton.setEnabled(false); mActivitiesButton.setEnabled(false);
} else if(v == mClearDataButton) { } else if(v == mClearDataButton) {
if (mAppInfo.manageSpaceActivityName != null) { if (mAppEntry.info.manageSpaceActivityName != null) {
Intent intent = new Intent(Intent.ACTION_DEFAULT); Intent intent = new Intent(Intent.ACTION_DEFAULT);
intent.setClassName(mAppInfo.packageName, mAppInfo.manageSpaceActivityName); intent.setClassName(mAppEntry.info.packageName,
mAppEntry.info.manageSpaceActivityName);
startActivityForResult(intent, -1); startActivityForResult(intent, -1);
} else { } else {
showDialogInner(DLG_CLEAR_DATA); showDialogInner(DLG_CLEAR_DATA);
@@ -803,11 +765,11 @@ public class InstalledAppDetails extends Activity implements View.OnClickListene
if (mPackageMoveObserver == null) { if (mPackageMoveObserver == null) {
mPackageMoveObserver = new PackageMoveObserver(); mPackageMoveObserver = new PackageMoveObserver();
} }
int moveFlags = (mAppInfo.flags & ApplicationInfo.FLAG_EXTERNAL_STORAGE) != 0 ? int moveFlags = (mAppEntry.info.flags & ApplicationInfo.FLAG_EXTERNAL_STORAGE) != 0 ?
PackageManager.MOVE_INTERNAL : PackageManager.MOVE_EXTERNAL_MEDIA; PackageManager.MOVE_INTERNAL : PackageManager.MOVE_EXTERNAL_MEDIA;
mMoveInProgress = true; mMoveInProgress = true;
refreshButtons(); refreshButtons();
mPm.movePackage(mAppInfo.packageName, mPackageMoveObserver, moveFlags); mPm.movePackage(mAppEntry.info.packageName, mPackageMoveObserver, moveFlags);
} }
} }
} }