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

Commit 46b3a135 authored by TreeHugger Robot's avatar TreeHugger Robot Committed by Android (Google) Code Review
Browse files

Merge "Remove reflection for a couple of methods" into ub-launcher3-dorval

parents ce44516d 8eaa8e64
Loading
Loading
Loading
Loading
+2 −14
Original line number Diff line number Diff line
@@ -16,17 +16,12 @@

package com.android.launcher3.compat;

import android.appwidget.AppWidgetManager;
import android.appwidget.AppWidgetProviderInfo;
import android.content.Context;
import android.os.UserHandle;
import android.support.annotation.NonNull;
import android.support.annotation.Nullable;
import android.util.Log;

import com.android.launcher3.util.PackageUserKey;

import java.lang.reflect.InvocationTargetException;
import java.util.List;

class AppWidgetManagerCompatVO extends AppWidgetManagerCompatVL {
@@ -40,14 +35,7 @@ class AppWidgetManagerCompatVO extends AppWidgetManagerCompatVL {
        if (packageUser == null) {
            return super.getAllProviders(null);
        }
        // TODO: don't use reflection once API and sdk are ready.
        try {
            return (List<AppWidgetProviderInfo>) AppWidgetManager.class.getMethod(
                    "getInstalledProvidersForPackage", String.class, UserHandle.class)
                    .invoke(mAppWidgetManager, packageUser.mPackageName, packageUser.mUser);
        } catch (IllegalAccessException | InvocationTargetException | NoSuchMethodException e) {
            Log.e("AppWidgetManagerCompat", "Failed to call new API", e);
        }
        return super.getAllProviders(packageUser);
        return mAppWidgetManager.getInstalledProvidersForPackage(packageUser.mPackageName,
                packageUser.mUser);
    }
}
+1 −15
Original line number Diff line number Diff line
@@ -25,7 +25,6 @@ import android.graphics.drawable.Drawable;
import android.graphics.drawable.Icon;
import android.os.Bundle;
import android.service.notification.StatusBarNotification;
import android.util.Log;
import android.view.View;

import com.android.launcher3.Launcher;
@@ -66,20 +65,7 @@ public class NotificationInfo implements View.OnClickListener {
        title = notification.extras.getCharSequence(Notification.EXTRA_TITLE);
        text = notification.extras.getCharSequence(Notification.EXTRA_TEXT);

        // TODO(b/36855196): use getBadgeIconType() without reflection
        int badgeIcon = Notification.BADGE_ICON_NONE;
        try {
            badgeIcon = (int) Notification.class.getMethod("getBadgeIconType").invoke(notification);
        } catch (Exception e) {
            Log.w("NotificationInfo", "getBadgeIconType() failed", e);
            // Try the old name, getBadgeIcon(), instead.
            try {
                badgeIcon = (int) Notification.class.getMethod("getBadgeIcon").invoke(notification);
            } catch (Exception e1) {
                Log.e("NotificationInfo", "getBadgeIcon() failed", e);
            }
        }
        mBadgeIcon = badgeIcon;
        mBadgeIcon = notification.getBadgeIconType();
        // Load the icon. Since it is backed by ashmem, we won't copy the entire bitmap
        // into our process as long as we don't touch it and it exists in systemui.
        Icon icon = mBadgeIcon == Notification.BADGE_ICON_SMALL ? null : notification.getLargeIcon();