diff options
| author | 2018-03-19 04:02:29 +0000 | |
|---|---|---|
| committer | 2018-03-19 04:02:29 +0000 | |
| commit | ac16fb5d41f1090228e77e86bd5617491a43e9ae (patch) | |
| tree | 19f17933055641b7ca83652f3008735f5af5aec9 | |
| parent | f5d216cc7c727b218f5e1a9c59fd2bc2dcefb4d3 (diff) | |
| parent | 72a86922d472ed130b7c8fbed538359f260d5285 (diff) | |
Merge "Remove Context requirement from updatable" into pi-dev
| -rw-r--r-- | media/java/android/media/update/ApiLoader.java | 64 |
1 files changed, 44 insertions, 20 deletions
diff --git a/media/java/android/media/update/ApiLoader.java b/media/java/android/media/update/ApiLoader.java index 0d190a7c4ebc..cf18bddbb57f 100644 --- a/media/java/android/media/update/ApiLoader.java +++ b/media/java/android/media/update/ApiLoader.java @@ -16,49 +16,73 @@ package android.media.update; -import android.annotation.NonNull; -import android.content.res.Resources; +import android.app.ActivityManager; +import android.app.AppGlobals; import android.content.Context; +import android.content.pm.ApplicationInfo; import android.content.pm.PackageManager; +import android.content.pm.PackageManager.NameNotFoundException; import android.os.Build; +import android.os.RemoteException; +import android.os.UserHandle; + +import com.android.internal.annotations.GuardedBy; + +import dalvik.system.PathClassLoader; + +import java.io.File; /** * @hide */ public final class ApiLoader { - private static Object sMediaLibrary; + @GuardedBy("this") + private static StaticProvider sMediaUpdatable; private static final String UPDATE_PACKAGE = "com.android.media.update"; private static final String UPDATE_CLASS = "com.android.media.update.ApiFactory"; private static final String UPDATE_METHOD = "initialize"; + private static final boolean REGISTER_UPDATE_DEPENDENCY = true; private ApiLoader() { } - public static StaticProvider getProvider(@NonNull Context context) { - if (context == null) { - throw new IllegalArgumentException("context shouldn't be null"); - } + @Deprecated + public static StaticProvider getProvider(Context context) { + return getProvider(); + } + + public static StaticProvider getProvider() { + if (sMediaUpdatable != null) return sMediaUpdatable; + try { - return (StaticProvider) getMediaLibraryImpl(context); - } catch (PackageManager.NameNotFoundException | ReflectiveOperationException e) { + return getMediaUpdatable(); + } catch (RemoteException e) { + throw e.rethrowFromSystemServer(); + } catch (NameNotFoundException | ReflectiveOperationException e) { throw new RuntimeException(e); } } // TODO This method may do I/O; Ensure it does not violate (emit warnings in) strict mode. - private static synchronized Object getMediaLibraryImpl(Context context) - throws PackageManager.NameNotFoundException, ReflectiveOperationException { - if (sMediaLibrary != null) return sMediaLibrary; + private static synchronized StaticProvider getMediaUpdatable() + throws NameNotFoundException, ReflectiveOperationException, RemoteException { + if (sMediaUpdatable != null) return sMediaUpdatable; // TODO Figure out when to use which package (query media update service) int flags = Build.IS_DEBUGGABLE ? 0 : PackageManager.MATCH_FACTORY_ONLY; - Context libContext = context.createApplicationContext( - context.getPackageManager().getPackageInfo(UPDATE_PACKAGE, flags).applicationInfo, - Context.CONTEXT_INCLUDE_CODE | Context.CONTEXT_IGNORE_SECURITY); - sMediaLibrary = libContext.getClassLoader() - .loadClass(UPDATE_CLASS) - .getMethod(UPDATE_METHOD, Resources.class, Resources.Theme.class) - .invoke(null, libContext.getResources(), libContext.getTheme()); - return sMediaLibrary; + flags |= PackageManager.GET_SHARED_LIBRARY_FILES; + ApplicationInfo ai = AppGlobals.getPackageManager().getApplicationInfo( + UPDATE_PACKAGE, flags, UserHandle.myUserId()); + + if (REGISTER_UPDATE_DEPENDENCY) { + // Register a dependency to the updatable in order to be killed during updates + ActivityManager.getService().addPackageDependency(ai.packageName); + } + + PathClassLoader classLoader = new PathClassLoader(ai.sourceDir, + ai.nativeLibraryDir + File.pathSeparator + System.getProperty("java.library.path"), + ClassLoader.getSystemClassLoader().getParent()); + return sMediaUpdatable = (StaticProvider) classLoader.loadClass(UPDATE_CLASS) + .getMethod(UPDATE_METHOD, ApplicationInfo.class).invoke(null, ai); } } |