Merge change 27106 into eclair

* changes:
  Use reflection to figure out a readable string from install error code.
This commit is contained in:
Android (Google) Code Review
2009-09-25 17:15:10 -04:00

View File

@@ -34,6 +34,8 @@ import android.os.RemoteException;
import android.os.ServiceManager;
import java.io.File;
import java.lang.reflect.Field;
import java.lang.reflect.Modifier;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
@@ -42,21 +44,21 @@ import java.util.WeakHashMap;
public final class Pm {
IPackageManager mPm;
private WeakHashMap<String, Resources> mResourceCache
= new WeakHashMap<String, Resources>();
private String[] mArgs;
private int mNextArg;
private String mCurArgData;
private static final String PM_NOT_RUNNING_ERR =
private static final String PM_NOT_RUNNING_ERR =
"Error: Could not access the Package Manager. Is the system running?";
public static void main(String[] args) {
new Pm().run(args);
}
public void run(String[] args) {
boolean validCommand = false;
if (args.length < 1) {
@@ -73,37 +75,37 @@ public final class Pm {
mArgs = args;
String op = args[0];
mNextArg = 1;
if ("list".equals(op)) {
runList();
return;
}
if ("path".equals(op)) {
runPath();
return;
}
if ("install".equals(op)) {
runInstall();
return;
}
if ("uninstall".equals(op)) {
runUninstall();
return;
}
if ("enable".equals(op)) {
runSetEnabledSetting(PackageManager.COMPONENT_ENABLED_STATE_ENABLED);
return;
}
if ("disable".equals(op)) {
runSetEnabledSetting(PackageManager.COMPONENT_ENABLED_STATE_DISABLED);
return;
}
try {
if (args.length == 1) {
if (args[0].equalsIgnoreCase("-l")) {
@@ -128,10 +130,10 @@ public final class Pm {
}
}
}
/**
* Execute the list sub-command.
*
*
* pm list [package | packages]
* pm list permission-groups
* pm list permissions
@@ -157,7 +159,7 @@ public final class Pm {
showUsage();
}
}
/**
* Lists all the installed packages.
*/
@@ -182,10 +184,10 @@ public final class Pm {
showUsage();
return;
}
try {
List<PackageInfo> packages = mPm.getInstalledPackages(0 /* all */);
int count = packages.size();
for (int p = 0 ; p < count ; p++) {
PackageInfo info = packages.get(p);
@@ -201,10 +203,10 @@ public final class Pm {
System.err.println(PM_NOT_RUNNING_ERR);
}
}
/**
* Lists all of the installed instrumentation, or all for a given package
*
*
* pm list instrumentation [package] [-f]
*/
private void runListInstrumentation() {
@@ -260,14 +262,14 @@ public final class Pm {
System.err.println(PM_NOT_RUNNING_ERR);
}
}
/**
* Lists all the known permission groups.
*/
private void runListPermissionGroups() {
try {
List<PermissionGroupInfo> pgs = mPm.getAllPermissionGroups(0);
int count = pgs.size();
for (int p = 0 ; p < count ; p++) {
PermissionGroupInfo pgi = pgs.get(p);
@@ -279,7 +281,7 @@ public final class Pm {
System.err.println(PM_NOT_RUNNING_ERR);
}
}
private String loadText(PackageItemInfo pii, int res, CharSequence nonLocalized) {
if (nonLocalized != null) {
return nonLocalized.toString();
@@ -290,7 +292,7 @@ public final class Pm {
}
return null;
}
/**
* Lists all the permissions in a group.
*/
@@ -321,7 +323,7 @@ public final class Pm {
return;
}
}
String grp = nextOption();
ArrayList<String> groupList = new ArrayList<String>();
if (groups) {
@@ -334,7 +336,7 @@ public final class Pm {
} else {
groupList.add(grp);
}
if (dangerousOnly) {
System.out.println("Dangerous Permissions:");
System.out.println("");
@@ -365,7 +367,7 @@ public final class Pm {
System.err.println(PM_NOT_RUNNING_ERR);
}
}
private void doListPermissions(ArrayList<String> groupList,
boolean groups, boolean labels, boolean summary,
int startProtectionLevel, int endProtectionLevel)
@@ -385,7 +387,7 @@ public final class Pm {
pgi.nonLocalizedLabel) + ": ");
} else {
System.out.print(pgi.name + ": ");
}
} else {
System.out.println((labels ? "+ " : "")
@@ -468,13 +470,13 @@ public final class Pm {
}
}
}
if (summary) {
System.out.println("");
}
}
}
private void runPath() {
String pkg = nextArg();
if (pkg == null) {
@@ -484,7 +486,7 @@ public final class Pm {
}
displayPackageFilePath(pkg);
}
class PackageInstallObserver extends IPackageInstallObserver.Stub {
boolean finished;
int result;
@@ -497,95 +499,40 @@ public final class Pm {
}
}
}
/**
* Converts a failure code into a string by using reflection to find a matching constant
* in PackageManager.
*/
private String installFailureToString(int result) {
String s;
switch (result) {
case PackageManager.INSTALL_FAILED_ALREADY_EXISTS:
s = "INSTALL_FAILED_ALREADY_EXISTS";
break;
case PackageManager.INSTALL_FAILED_INVALID_APK:
s = "INSTALL_FAILED_INVALID_APK";
break;
case PackageManager.INSTALL_FAILED_INVALID_URI:
s = "INSTALL_FAILED_INVALID_URI";
break;
case PackageManager.INSTALL_FAILED_INSUFFICIENT_STORAGE:
s = "INSTALL_FAILED_INSUFFICIENT_STORAGE";
break;
case PackageManager.INSTALL_FAILED_DUPLICATE_PACKAGE:
s = "INSTALL_FAILED_DUPLICATE_PACKAGE";
break;
case PackageManager.INSTALL_FAILED_NO_SHARED_USER:
s = "INSTALL_FAILED_NO_SHARED_USER";
break;
case PackageManager.INSTALL_FAILED_UPDATE_INCOMPATIBLE:
s = "INSTALL_FAILED_UPDATE_INCOMPATIBLE";
break;
case PackageManager.INSTALL_FAILED_SHARED_USER_INCOMPATIBLE:
s = "INSTALL_FAILED_SHARED_USER_INCOMPATIBLE";
break;
case PackageManager.INSTALL_FAILED_MISSING_SHARED_LIBRARY:
s = "INSTALL_FAILED_MISSING_SHARED_LIBRARY";
break;
case PackageManager.INSTALL_FAILED_DEXOPT:
s = "INSTALL_FAILED_DEXOPT";
break;
case PackageManager.INSTALL_FAILED_OLDER_SDK:
s = "INSTALL_FAILED_OLDER_SDK";
break;
case PackageManager.INSTALL_FAILED_CONFLICTING_PROVIDER:
s = "INSTALL_FAILED_CONFLICTING_PROVIDER";
break;
case PackageManager.INSTALL_FAILED_NEWER_SDK:
s = "INSTALL_FAILED_NEWER_SDK";
break;
case PackageManager.INSTALL_FAILED_TEST_ONLY:
s = "INSTALL_FAILED_TEST_ONLY";
break;
case PackageManager.INSTALL_FAILED_CPU_ABI_INCOMPATIBLE:
s = "INSTALL_FAILED_CPU_ABI_INCOMPATIBLE";
break;
case PackageManager.INSTALL_FAILED_MISSING_FEATURE:
s = "INSTALL_FAILED_MISSING_FEATURE";
break;
case PackageManager.INSTALL_PARSE_FAILED_NOT_APK:
s = "INSTALL_PARSE_FAILED_NOT_APK";
break;
case PackageManager.INSTALL_PARSE_FAILED_BAD_MANIFEST:
s = "INSTALL_PARSE_FAILED_BAD_MANIFEST";
break;
case PackageManager.INSTALL_PARSE_FAILED_UNEXPECTED_EXCEPTION:
s = "INSTALL_PARSE_FAILED_UNEXPECTED_EXCEPTION";
break;
case PackageManager.INSTALL_PARSE_FAILED_NO_CERTIFICATES:
s = "INSTALL_PARSE_FAILED_NO_CERTIFICATES";
break;
case PackageManager.INSTALL_PARSE_FAILED_INCONSISTENT_CERTIFICATES:
s = "INSTALL_PARSE_FAILED_INCONSISTENT_CERTIFICATES";
break;
case PackageManager.INSTALL_PARSE_FAILED_CERTIFICATE_ENCODING:
s = "INSTALL_PARSE_FAILED_CERTIFICATE_ENCODING";
break;
case PackageManager.INSTALL_PARSE_FAILED_BAD_PACKAGE_NAME:
s = "INSTALL_PARSE_FAILED_BAD_PACKAGE_NAME";
break;
case PackageManager.INSTALL_PARSE_FAILED_BAD_SHARED_USER_ID:
s = "INSTALL_PARSE_FAILED_BAD_SHARED_USER_ID";
break;
case PackageManager.INSTALL_PARSE_FAILED_MANIFEST_MALFORMED:
s = "INSTALL_PARSE_FAILED_MANIFEST_MALFORMED";
break;
case PackageManager.INSTALL_PARSE_FAILED_MANIFEST_EMPTY:
s = "INSTALL_PARSE_FAILED_MANIFEST_EMPTY";
break;
default:
s = Integer.toString(result);
break;
Field[] fields = PackageManager.class.getFields();
for (Field f: fields) {
if (f.getType() == int.class) {
int modifiers = f.getModifiers();
// only look at public final static fields.
if (((modifiers & Modifier.FINAL) != 0) &&
((modifiers & Modifier.PUBLIC) != 0) &&
((modifiers & Modifier.STATIC) != 0)) {
String fieldName = f.getName();
if (fieldName.startsWith("INSTALL_FAILED_") ||
fieldName.startsWith("INSTALL_PARSE_FAILED_")) {
// get the int value and compare it to result.
try {
if (result == f.getInt(null)) {
return fieldName;
}
} catch (IllegalAccessException e) {
// this shouldn't happen since we only look for public static fields.
}
}
}
}
}
return s;
// couldn't find a matching constant? return the value
return Integer.toString(result);
}
private void runInstall() {
int installFlags = 0;
String installerPackageName = null;
@@ -624,7 +571,7 @@ public final class Pm {
try {
mPm.installPackage(Uri.fromFile(new File(apkFilePath)), obs, installFlags,
installerPackageName);
synchronized (obs) {
while (!obs.finished) {
try {
@@ -645,11 +592,11 @@ public final class Pm {
System.err.println(PM_NOT_RUNNING_ERR);
}
}
class PackageDeleteObserver extends IPackageDeleteObserver.Stub {
boolean finished;
boolean result;
public void packageDeleted(boolean succeeded) {
synchronized (this) {
finished = true;
@@ -658,7 +605,7 @@ public final class Pm {
}
}
}
private void runUninstall() {
int unInstallFlags = 0;
@@ -712,7 +659,7 @@ public final class Pm {
}
return "unknown";
}
private void runSetEnabledSetting(int state) {
String pkg = nextArg();
if (pkg == null) {
@@ -760,11 +707,11 @@ public final class Pm {
System.err.println(PM_NOT_RUNNING_ERR);
}
}
private Resources getResources(PackageItemInfo pii) {
Resources res = mResourceCache.get(pii.packageName);
if (res != null) return res;
try {
ApplicationInfo ai = mPm.getApplicationInfo(pii.packageName, 0);
AssetManager am = new AssetManager();
@@ -778,7 +725,7 @@ public final class Pm {
return null;
}
}
private String nextOption() {
if (mNextArg >= mArgs.length) {
return null;
@@ -830,7 +777,7 @@ public final class Pm {
System.err.println(" pm list packages [-f]");
System.err.println(" pm list permission-groups");
System.err.println(" pm list permissions [-g] [-f] [-d] [-u] [GROUP]");
System.err.println(" pm list instrumentation [-f] [TARGET-PACKAGE]");
System.err.println(" pm list instrumentation [-f] [TARGET-PACKAGE]");
System.err.println(" pm path PACKAGE");
System.err.println(" pm install [-l] [-r] [-t] [-i INSTALLER_PACKAGE_NAME] PATH");
System.err.println(" pm uninstall [-k] PACKAGE");