Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 60bf6002 authored by android-build-team Robot's avatar android-build-team Robot
Browse files

release-request-7bfcab52-d1c0-4256-9d6b-5b5092bc78ca-for-git_oc-mr1-release-41...

release-request-7bfcab52-d1c0-4256-9d6b-5b5092bc78ca-for-git_oc-mr1-release-4133428 snap-temp-L95800000077479875

Change-Id: Ic5596752a65d17a8199455511738858f22b2cd3c
parents 45fedeb6 5f69d38a
Loading
Loading
Loading
Loading
+6 −0
Original line number Diff line number Diff line
@@ -4208,6 +4208,12 @@ package android.app {
  public class Application extends android.content.ContextWrapper implements android.content.ComponentCallbacks2 {
    ctor public Application();
    method public android.app.Activity instantiateActivity(java.lang.ClassLoader, java.lang.String, android.content.Intent);
    method public android.app.backup.BackupAgent instantiateBackupAgent(java.lang.ClassLoader, java.lang.String);
    method public android.app.Instrumentation instantiateInstrumentation(java.lang.ClassLoader, java.lang.String);
    method public android.content.ContentProvider instantiateProvider(java.lang.ClassLoader, java.lang.String);
    method public android.content.BroadcastReceiver instantiateReceiver(java.lang.ClassLoader, java.lang.String, android.content.Intent);
    method public android.app.Service instantiateService(java.lang.ClassLoader, java.lang.String, android.content.Intent);
    method public void onConfigurationChanged(android.content.res.Configuration);
    method public void onCreate();
    method public void onLowMemory();
+6 −0
Original line number Diff line number Diff line
@@ -4363,6 +4363,12 @@ package android.app {
  public class Application extends android.content.ContextWrapper implements android.content.ComponentCallbacks2 {
    ctor public Application();
    method public android.app.Activity instantiateActivity(java.lang.ClassLoader, java.lang.String, android.content.Intent);
    method public android.app.backup.BackupAgent instantiateBackupAgent(java.lang.ClassLoader, java.lang.String);
    method public android.app.Instrumentation instantiateInstrumentation(java.lang.ClassLoader, java.lang.String);
    method public android.content.ContentProvider instantiateProvider(java.lang.ClassLoader, java.lang.String);
    method public android.content.BroadcastReceiver instantiateReceiver(java.lang.ClassLoader, java.lang.String, android.content.Intent);
    method public android.app.Service instantiateService(java.lang.ClassLoader, java.lang.String, android.content.Intent);
    method public void onConfigurationChanged(android.content.res.Configuration);
    method public void onCreate();
    method public void onLowMemory();
+6 −0
Original line number Diff line number Diff line
@@ -4221,6 +4221,12 @@ package android.app {
  public class Application extends android.content.ContextWrapper implements android.content.ComponentCallbacks2 {
    ctor public Application();
    method public android.app.Activity instantiateActivity(java.lang.ClassLoader, java.lang.String, android.content.Intent);
    method public android.app.backup.BackupAgent instantiateBackupAgent(java.lang.ClassLoader, java.lang.String);
    method public android.app.Instrumentation instantiateInstrumentation(java.lang.ClassLoader, java.lang.String);
    method public android.content.ContentProvider instantiateProvider(java.lang.ClassLoader, java.lang.String);
    method public android.content.BroadcastReceiver instantiateReceiver(java.lang.ClassLoader, java.lang.String, android.content.Intent);
    method public android.app.Service instantiateService(java.lang.ClassLoader, java.lang.String, android.content.Intent);
    method public void onConfigurationChanged(android.content.res.Configuration);
    method public void onCreate();
    method public void onLowMemory();
+1 −1
Original line number Diff line number Diff line
@@ -253,5 +253,5 @@ int main(int argc, char** argv)
    }

    // b/36066697: Avoid running static destructors.
    _exit(1);
    _exit(0);
}
+53 −11
Original line number Diff line number Diff line
@@ -2678,8 +2678,14 @@ public final class ActivityThread {
        Activity activity = null;
        try {
            java.lang.ClassLoader cl = appContext.getClassLoader();
            if (appContext.getApplicationContext() instanceof Application) {
                activity = ((Application) appContext.getApplicationContext())
                        .instantiateActivity(cl, component.getClassName(), r.intent);
            }
            if (activity == null) {
                activity = mInstrumentation.newActivity(
                        cl, component.getClassName(), r.intent);
            }
            StrictMode.incrementExpectedActivityCount(activity.getClass());
            r.intent.setExtrasClassLoader(cl);
            r.intent.prepareToEnterProcess();
@@ -3204,7 +3210,8 @@ public final class ActivityThread {
            data.intent.setExtrasClassLoader(cl);
            data.intent.prepareToEnterProcess();
            data.setExtrasClassLoader(cl);
            receiver = (BroadcastReceiver)cl.loadClass(component).newInstance();
            receiver = instantiate(cl, component, data.intent, app,
                    Application::instantiateReceiver);
        } catch (Exception e) {
            if (DEBUG_BROADCAST) Slog.i(TAG,
                    "Finishing failed broadcast to " + data.intent.getComponent());
@@ -3292,12 +3299,13 @@ public final class ActivityThread {
            } else {
                try {
                    if (DEBUG_BACKUP) Slog.v(TAG, "Initializing agent class " + classname);
                    ContextImpl context = ContextImpl.createAppContext(this, packageInfo);

                    java.lang.ClassLoader cl = packageInfo.getClassLoader();
                    agent = (BackupAgent) cl.loadClass(classname).newInstance();
                    agent = instantiate(cl, classname, context,
                            Application::instantiateBackupAgent);

                    // set up the agent's context
                    ContextImpl context = ContextImpl.createAppContext(this, packageInfo);
                    context.setOuterContext(agent);
                    agent.attach(context);

@@ -3357,9 +3365,12 @@ public final class ActivityThread {
        LoadedApk packageInfo = getPackageInfoNoCheck(
                data.info.applicationInfo, data.compatInfo);
        Service service = null;
        Application app = null;
        try {
            app = packageInfo.makeApplication(false, mInstrumentation);
            java.lang.ClassLoader cl = packageInfo.getClassLoader();
            service = (Service) cl.loadClass(data.info.name).newInstance();
            service = instantiate(cl, data.info.name, data.intent, app,
                    Application::instantiateService);
        } catch (Exception e) {
            if (!mInstrumentation.onException(service, e)) {
                throw new RuntimeException(
@@ -3374,7 +3385,6 @@ public final class ActivityThread {
            ContextImpl context = ContextImpl.createAppContext(this, packageInfo);
            context.setOuterContext(service);

            Application app = packageInfo.makeApplication(false, mInstrumentation);
            service.attach(context, this, data.info.name, data.token, app,
                    ActivityManager.getService());
            service.onCreate();
@@ -5691,8 +5701,8 @@ public final class ActivityThread {

            try {
                final ClassLoader cl = instrContext.getClassLoader();
                mInstrumentation = (Instrumentation)
                    cl.loadClass(data.instrumentationName.getClassName()).newInstance();
                mInstrumentation = instantiate(cl, data.instrumentationName.getClassName(),
                        instrContext, Application::instantiateInstrumentation);
            } catch (Exception e) {
                throw new RuntimeException(
                    "Unable to instantiate instrumentation "
@@ -6237,8 +6247,8 @@ public final class ActivityThread {

            try {
                final java.lang.ClassLoader cl = c.getClassLoader();
                localProvider = (ContentProvider)cl.
                    loadClass(info.name).newInstance();
                localProvider = instantiate(cl, info.name, context,
                        Application::instantiateProvider);
                provider = localProvider.getIContentProvider();
                if (provider == null) {
                    Slog.e(TAG, "Failed to instantiate class " +
@@ -6437,6 +6447,38 @@ public final class ActivityThread {
        }
    }

    private <T> T instantiate(ClassLoader cl, String className, Context c,
            Instantiator<T> instantiator)
            throws ClassNotFoundException, IllegalAccessException, InstantiationException {
        if (c.getApplicationContext() instanceof Application) {
            T a = instantiator.instantiate((Application) c.getApplicationContext(),
                    cl, className);
            if (a != null) return a;
        }
        return (T) cl.loadClass(className).newInstance();
    }

    private <T> T instantiate(ClassLoader cl, String className, Intent intent, Context c,
            IntentInstantiator<T> instantiator)
            throws ClassNotFoundException, IllegalAccessException, InstantiationException {
        if (c.getApplicationContext() instanceof Application) {
            T a = instantiator.instantiate((Application) c.getApplicationContext(),
                    cl, className, intent);
            if (a != null) return a;
        }
        return (T) cl.loadClass(className).newInstance();
    }

    private interface Instantiator<T> {
        T instantiate(Application app, ClassLoader cl, String className)
                throws ClassNotFoundException, IllegalAccessException, InstantiationException;
    }

    private interface IntentInstantiator<T> {
        T instantiate(Application app, ClassLoader cl, String className, Intent intent)
                throws ClassNotFoundException, IllegalAccessException, InstantiationException;
    }

    private static class EventLoggingReporter implements EventLogger.Reporter {
        @Override
        public void report (int code, Object... list) {
Loading