[ToA]Cache system gender to reduce unnecessary IPC
Bug: 312324895 Test: atest TermsOfAddressNotSpecifiedControllerTest atest TermsOfAddressNeutralControllerTest atest TermsOfAddressMasculineControllerTest atest TermsOfAddressFeminineControllerTest Change-Id: Idee2cc1ece673092c94307b8812f032f7826c16a
This commit is contained in:
@@ -16,9 +16,9 @@
|
|||||||
|
|
||||||
package com.android.settings.localepicker;
|
package com.android.settings.localepicker;
|
||||||
|
|
||||||
import android.app.GrammaticalInflectionManager;
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
|
||||||
|
import androidx.annotation.NonNull;
|
||||||
import androidx.preference.PreferenceScreen;
|
import androidx.preference.PreferenceScreen;
|
||||||
|
|
||||||
import com.android.settings.core.BasePreferenceController;
|
import com.android.settings.core.BasePreferenceController;
|
||||||
@@ -35,13 +35,15 @@ public abstract class TermsOfAddressBaseController extends BasePreferenceControl
|
|||||||
private PreferenceScreen mPreferenceScreen;
|
private PreferenceScreen mPreferenceScreen;
|
||||||
private MetricsFeatureProvider mMetricsFeatureProvider;
|
private MetricsFeatureProvider mMetricsFeatureProvider;
|
||||||
private TickButtonPreference mPreference;
|
private TickButtonPreference mPreference;
|
||||||
private GrammaticalInflectionManager mGrammaticalInflectionManager;
|
private TermsOfAddressHelper mTermsOfAddressHelper;
|
||||||
|
|
||||||
public TermsOfAddressBaseController(Context context, String preferenceKey) {
|
public TermsOfAddressBaseController(Context context, String preferenceKey) {
|
||||||
super(context, preferenceKey);
|
super(context, preferenceKey);
|
||||||
mMetricsFeatureProvider = FeatureFactory.getFeatureFactory().getMetricsFeatureProvider();
|
mMetricsFeatureProvider = FeatureFactory.getFeatureFactory().getMetricsFeatureProvider();
|
||||||
mGrammaticalInflectionManager = context.getSystemService(
|
}
|
||||||
GrammaticalInflectionManager.class);
|
|
||||||
|
public void setTermsOfAddressHelper(@NonNull TermsOfAddressHelper termsOfAddressHelper) {
|
||||||
|
mTermsOfAddressHelper = termsOfAddressHelper;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -52,7 +54,7 @@ public abstract class TermsOfAddressBaseController extends BasePreferenceControl
|
|||||||
mPreference.setOnPreferenceClickListener(clickedPref -> {
|
mPreference.setOnPreferenceClickListener(clickedPref -> {
|
||||||
sExecutor.execute(
|
sExecutor.execute(
|
||||||
() -> {
|
() -> {
|
||||||
mGrammaticalInflectionManager.setSystemWideGrammaticalGender(
|
mTermsOfAddressHelper.setSystemGrammaticalGender(
|
||||||
getGrammaticalGenderType());
|
getGrammaticalGenderType());
|
||||||
});
|
});
|
||||||
setSelected(mPreference);
|
setSelected(mPreference);
|
||||||
@@ -74,8 +76,7 @@ public abstract class TermsOfAddressBaseController extends BasePreferenceControl
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
mPreference.setSelected(
|
mPreference.setSelected(
|
||||||
mGrammaticalInflectionManager.getSystemGrammaticalGender()
|
mTermsOfAddressHelper.getSystemGrammaticalGender() == getGrammaticalGenderType());
|
||||||
== getGrammaticalGenderType());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -22,18 +22,10 @@ import android.content.Context;
|
|||||||
import com.android.settings.R;
|
import com.android.settings.R;
|
||||||
import com.android.settings.dashboard.DashboardFragment;
|
import com.android.settings.dashboard.DashboardFragment;
|
||||||
import com.android.settings.search.BaseSearchIndexProvider;
|
import com.android.settings.search.BaseSearchIndexProvider;
|
||||||
import com.android.settingslib.core.AbstractPreferenceController;
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
public class TermsOfAddressFragment extends DashboardFragment {
|
public class TermsOfAddressFragment extends DashboardFragment {
|
||||||
|
|
||||||
private static final String LOG_TAG = "TermsOfAddressFragment";
|
private static final String LOG_TAG = "TermsOfAddressFragment";
|
||||||
private static final String KEY_NOT_SPECIFIED = "key_terms_of_address_not_specified";
|
|
||||||
private static final String KEY_FEMININE = "key_terms_of_address_feminine";
|
|
||||||
private static final String KEY_MASCULINE = "key_terms_of_address_masculine";
|
|
||||||
private static final String KEY_NEUTRAL = "key_terms_of_address_neutral";
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected String getLogTag() {
|
protected String getLogTag() {
|
||||||
@@ -51,13 +43,14 @@ public class TermsOfAddressFragment extends DashboardFragment {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected List<AbstractPreferenceController> createPreferenceControllers(Context context) {
|
public void onAttach(Context context) {
|
||||||
final List<AbstractPreferenceController> controllers = new ArrayList<>();
|
super.onAttach(context);
|
||||||
controllers.add(new TermsOfAddressNotSpecifiedController(context, KEY_NOT_SPECIFIED));
|
TermsOfAddressHelper termsOfAddressHelper = new TermsOfAddressHelper(context);
|
||||||
controllers.add(new TermsOfAddressFeminineController(context, KEY_FEMININE));
|
use(TermsOfAddressNotSpecifiedController.class).setTermsOfAddressHelper(
|
||||||
controllers.add(new TermsOfAddressMasculineController(context, KEY_MASCULINE));
|
termsOfAddressHelper);
|
||||||
controllers.add(new TermsOfAddressNeutralController(context, KEY_NEUTRAL));
|
use(TermsOfAddressFeminineController.class).setTermsOfAddressHelper(termsOfAddressHelper);
|
||||||
return controllers;
|
use(TermsOfAddressMasculineController.class).setTermsOfAddressHelper(termsOfAddressHelper);
|
||||||
|
use(TermsOfAddressNeutralController.class).setTermsOfAddressHelper(termsOfAddressHelper);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static final BaseSearchIndexProvider SEARCH_INDEX_DATA_PROVIDER =
|
public static final BaseSearchIndexProvider SEARCH_INDEX_DATA_PROVIDER =
|
||||||
|
|||||||
@@ -0,0 +1,54 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2024 The Android Open Source Project
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package com.android.settings.localepicker;
|
||||||
|
|
||||||
|
import android.app.GrammaticalInflectionManager;
|
||||||
|
import android.content.Context;
|
||||||
|
|
||||||
|
import androidx.annotation.NonNull;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A helper used to get, set, and cache system grammatical gender.
|
||||||
|
*/
|
||||||
|
public class TermsOfAddressHelper {
|
||||||
|
|
||||||
|
private int mSystemGrammaticalGender;
|
||||||
|
private GrammaticalInflectionManager mGrammaticalInflectionManager;
|
||||||
|
|
||||||
|
public TermsOfAddressHelper(@NonNull Context context) {
|
||||||
|
mGrammaticalInflectionManager = context.getSystemService(
|
||||||
|
GrammaticalInflectionManager.class);
|
||||||
|
mSystemGrammaticalGender = mGrammaticalInflectionManager.getSystemGrammaticalGender();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* set system grammatical gender
|
||||||
|
*
|
||||||
|
* @param gender system grammatical gender
|
||||||
|
*/
|
||||||
|
public void setSystemGrammaticalGender(int gender) {
|
||||||
|
mGrammaticalInflectionManager.setSystemWideGrammaticalGender(gender);
|
||||||
|
mSystemGrammaticalGender = gender;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* get system grammatical gender
|
||||||
|
*/
|
||||||
|
public int getSystemGrammaticalGender() {
|
||||||
|
return mSystemGrammaticalGender;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -18,8 +18,6 @@ package com.android.settings.localepicker;
|
|||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
import static org.junit.Assert.assertFalse;
|
|
||||||
import static org.junit.Assert.assertTrue;
|
|
||||||
import static org.mockito.Mockito.spy;
|
import static org.mockito.Mockito.spy;
|
||||||
|
|
||||||
import android.app.GrammaticalInflectionManager;
|
import android.app.GrammaticalInflectionManager;
|
||||||
@@ -27,16 +25,14 @@ import android.content.Context;
|
|||||||
import android.content.res.Configuration;
|
import android.content.res.Configuration;
|
||||||
import android.os.Looper;
|
import android.os.Looper;
|
||||||
|
|
||||||
import com.android.settings.widget.TickButtonPreference;
|
|
||||||
|
|
||||||
import androidx.preference.PreferenceManager;
|
|
||||||
import androidx.preference.Preference;
|
|
||||||
import androidx.preference.PreferenceCategory;
|
import androidx.preference.PreferenceCategory;
|
||||||
|
import androidx.preference.PreferenceManager;
|
||||||
import androidx.preference.PreferenceScreen;
|
import androidx.preference.PreferenceScreen;
|
||||||
import androidx.test.core.app.ApplicationProvider;
|
import androidx.test.core.app.ApplicationProvider;
|
||||||
import androidx.test.ext.junit.runners.AndroidJUnit4;
|
import androidx.test.ext.junit.runners.AndroidJUnit4;
|
||||||
|
|
||||||
import org.junit.After;
|
import com.android.settings.widget.TickButtonPreference;
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
@@ -91,6 +87,7 @@ public class TermsOfAddressFeminineControllerTest {
|
|||||||
mPreferenceScreen.addPreference(mMasculinePreference);
|
mPreferenceScreen.addPreference(mMasculinePreference);
|
||||||
mPreferenceScreen.addPreference(mNeutralPreference);
|
mPreferenceScreen.addPreference(mNeutralPreference);
|
||||||
mController = new TermsOfAddressFeminineController(mContext, KEY_FEMININE);
|
mController = new TermsOfAddressFeminineController(mContext, KEY_FEMININE);
|
||||||
|
mController.setTermsOfAddressHelper(new TermsOfAddressHelper(mContext));
|
||||||
mController.displayPreference(mPreferenceScreen);
|
mController.displayPreference(mPreferenceScreen);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -18,8 +18,6 @@ package com.android.settings.localepicker;
|
|||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
import static org.junit.Assert.assertFalse;
|
|
||||||
import static org.junit.Assert.assertTrue;
|
|
||||||
import static org.mockito.Mockito.spy;
|
import static org.mockito.Mockito.spy;
|
||||||
|
|
||||||
import android.app.GrammaticalInflectionManager;
|
import android.app.GrammaticalInflectionManager;
|
||||||
@@ -27,16 +25,14 @@ import android.content.Context;
|
|||||||
import android.content.res.Configuration;
|
import android.content.res.Configuration;
|
||||||
import android.os.Looper;
|
import android.os.Looper;
|
||||||
|
|
||||||
import com.android.settings.widget.TickButtonPreference;
|
|
||||||
|
|
||||||
import androidx.preference.PreferenceManager;
|
|
||||||
import androidx.preference.Preference;
|
|
||||||
import androidx.preference.PreferenceCategory;
|
import androidx.preference.PreferenceCategory;
|
||||||
|
import androidx.preference.PreferenceManager;
|
||||||
import androidx.preference.PreferenceScreen;
|
import androidx.preference.PreferenceScreen;
|
||||||
import androidx.test.core.app.ApplicationProvider;
|
import androidx.test.core.app.ApplicationProvider;
|
||||||
import androidx.test.ext.junit.runners.AndroidJUnit4;
|
import androidx.test.ext.junit.runners.AndroidJUnit4;
|
||||||
|
|
||||||
import org.junit.After;
|
import com.android.settings.widget.TickButtonPreference;
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
@@ -91,6 +87,7 @@ public class TermsOfAddressMasculineControllerTest {
|
|||||||
mPreferenceScreen.addPreference(mMasculinePreference);
|
mPreferenceScreen.addPreference(mMasculinePreference);
|
||||||
mPreferenceScreen.addPreference(mNeutralPreference);
|
mPreferenceScreen.addPreference(mNeutralPreference);
|
||||||
mController = new TermsOfAddressMasculineController(mContext, KEY_MASCULINE);
|
mController = new TermsOfAddressMasculineController(mContext, KEY_MASCULINE);
|
||||||
|
mController.setTermsOfAddressHelper(new TermsOfAddressHelper(mContext));
|
||||||
mController.displayPreference(mPreferenceScreen);
|
mController.displayPreference(mPreferenceScreen);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -18,8 +18,6 @@ package com.android.settings.localepicker;
|
|||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
import static org.junit.Assert.assertFalse;
|
|
||||||
import static org.junit.Assert.assertTrue;
|
|
||||||
import static org.mockito.Mockito.spy;
|
import static org.mockito.Mockito.spy;
|
||||||
|
|
||||||
import android.app.GrammaticalInflectionManager;
|
import android.app.GrammaticalInflectionManager;
|
||||||
@@ -27,16 +25,14 @@ import android.content.Context;
|
|||||||
import android.content.res.Configuration;
|
import android.content.res.Configuration;
|
||||||
import android.os.Looper;
|
import android.os.Looper;
|
||||||
|
|
||||||
import com.android.settings.widget.TickButtonPreference;
|
|
||||||
|
|
||||||
import androidx.preference.PreferenceManager;
|
|
||||||
import androidx.preference.Preference;
|
|
||||||
import androidx.preference.PreferenceCategory;
|
import androidx.preference.PreferenceCategory;
|
||||||
|
import androidx.preference.PreferenceManager;
|
||||||
import androidx.preference.PreferenceScreen;
|
import androidx.preference.PreferenceScreen;
|
||||||
import androidx.test.core.app.ApplicationProvider;
|
import androidx.test.core.app.ApplicationProvider;
|
||||||
import androidx.test.ext.junit.runners.AndroidJUnit4;
|
import androidx.test.ext.junit.runners.AndroidJUnit4;
|
||||||
|
|
||||||
import org.junit.After;
|
import com.android.settings.widget.TickButtonPreference;
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
@@ -91,11 +87,12 @@ public class TermsOfAddressNeutralControllerTest {
|
|||||||
mPreferenceScreen.addPreference(mMasculinePreference);
|
mPreferenceScreen.addPreference(mMasculinePreference);
|
||||||
mPreferenceScreen.addPreference(mNeutralPreference);
|
mPreferenceScreen.addPreference(mNeutralPreference);
|
||||||
mController = new TermsOfAddressNeutralController(mContext, KEY_NEUTRAL);
|
mController = new TermsOfAddressNeutralController(mContext, KEY_NEUTRAL);
|
||||||
|
mController.setTermsOfAddressHelper(new TermsOfAddressHelper(mContext));
|
||||||
mController.displayPreference(mPreferenceScreen);
|
mController.displayPreference(mPreferenceScreen);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void displayPreference_setGrammaticalGenderIsNotSpecified_NotSpecifiedIsSelected() {
|
public void displayPreference_setGrammaticalGenderIsNotSpecified_NeutralIsSelected() {
|
||||||
TickButtonPreference selectedPreference =
|
TickButtonPreference selectedPreference =
|
||||||
(TickButtonPreference) mPreferenceScreen.getPreference(4);
|
(TickButtonPreference) mPreferenceScreen.getPreference(4);
|
||||||
selectedPreference.performClick();
|
selectedPreference.performClick();
|
||||||
|
|||||||
@@ -18,8 +18,6 @@ package com.android.settings.localepicker;
|
|||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
|
||||||
import static org.junit.Assert.assertFalse;
|
|
||||||
import static org.junit.Assert.assertTrue;
|
|
||||||
import static org.mockito.Mockito.spy;
|
import static org.mockito.Mockito.spy;
|
||||||
|
|
||||||
import android.app.GrammaticalInflectionManager;
|
import android.app.GrammaticalInflectionManager;
|
||||||
@@ -27,16 +25,14 @@ import android.content.Context;
|
|||||||
import android.content.res.Configuration;
|
import android.content.res.Configuration;
|
||||||
import android.os.Looper;
|
import android.os.Looper;
|
||||||
|
|
||||||
import com.android.settings.widget.TickButtonPreference;
|
|
||||||
|
|
||||||
import androidx.preference.PreferenceManager;
|
|
||||||
import androidx.preference.Preference;
|
|
||||||
import androidx.preference.PreferenceCategory;
|
import androidx.preference.PreferenceCategory;
|
||||||
|
import androidx.preference.PreferenceManager;
|
||||||
import androidx.preference.PreferenceScreen;
|
import androidx.preference.PreferenceScreen;
|
||||||
import androidx.test.core.app.ApplicationProvider;
|
import androidx.test.core.app.ApplicationProvider;
|
||||||
import androidx.test.ext.junit.runners.AndroidJUnit4;
|
import androidx.test.ext.junit.runners.AndroidJUnit4;
|
||||||
|
|
||||||
import org.junit.After;
|
import com.android.settings.widget.TickButtonPreference;
|
||||||
|
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.junit.runner.RunWith;
|
import org.junit.runner.RunWith;
|
||||||
@@ -91,6 +87,7 @@ public class TermsOfAddressNotSpecifiedControllerTest {
|
|||||||
mPreferenceScreen.addPreference(mMasculinePreference);
|
mPreferenceScreen.addPreference(mMasculinePreference);
|
||||||
mPreferenceScreen.addPreference(mNeutralPreference);
|
mPreferenceScreen.addPreference(mNeutralPreference);
|
||||||
mController = new TermsOfAddressNotSpecifiedController(mContext, KEY_NOT_SPECIFIED);
|
mController = new TermsOfAddressNotSpecifiedController(mContext, KEY_NOT_SPECIFIED);
|
||||||
|
mController.setTermsOfAddressHelper(new TermsOfAddressHelper(mContext));
|
||||||
mController.displayPreference(mPreferenceScreen);
|
mController.displayPreference(mPreferenceScreen);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user