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

Commit c6636f9a authored by Treehugger Robot's avatar Treehugger Robot Committed by Android (Google) Code Review
Browse files

Merge "Add a method to get controllers with same parent class type." into main

parents 63469da6 253cb874
Loading
Loading
Loading
Loading
+7 −0
Original line number Diff line number Diff line
@@ -348,6 +348,13 @@ public abstract class DashboardFragment extends SettingsPreferenceFragment
        return null;
    }

    /** Returns grouped controllers of input type T. */
    protected <T extends AbstractPreferenceController> List<AbstractPreferenceController> useGroup(
            Class<T> clazz) {
        return mPreferenceControllers.values().stream().flatMap(Collection::stream).filter(
                controller -> clazz.isInstance(controller)).toList();
    }

    /** Returns all controllers of type T. */
    protected <T extends AbstractPreferenceController> List<T> useAll(Class<T> clazz) {
        return (List<T>) mPreferenceControllers.getOrDefault(clazz, Collections.emptyList());
+4 −6
Original line number Diff line number Diff line
@@ -334,12 +334,10 @@ public class MobileNetworkSettings extends AbstractMobileNetworkSettings impleme
            convertToEsimPreferenceController.init(mSubId, mSubscriptionInfoEntity);
        }

        List<AbstractSubscriptionPreferenceController> subscriptionPreferenceControllers =
                useAll(AbstractSubscriptionPreferenceController.class);
        for (AbstractSubscriptionPreferenceController controller :
                subscriptionPreferenceControllers) {
            controller.init(mSubId);
        }
        List<AbstractPreferenceController> subscriptionPreferenceControllers =
                useGroup(AbstractSubscriptionPreferenceController.class);
        subscriptionPreferenceControllers.forEach(
                controller -> ((AbstractSubscriptionPreferenceController) controller).init(mSubId));
    }

    @Override