Merge "Add query dynamic indexable data to SettingsSearchIndexablesProvider"
This commit is contained in:
@@ -102,7 +102,7 @@ public class SettingsSearchIndexablesProvider extends SearchIndexablesProvider {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Cursor queryXmlResources(String[] projection) {
|
public Cursor queryXmlResources(String[] projection) {
|
||||||
MatrixCursor cursor = new MatrixCursor(INDEXABLES_XML_RES_COLUMNS);
|
final MatrixCursor cursor = new MatrixCursor(INDEXABLES_XML_RES_COLUMNS);
|
||||||
final List<SearchIndexableResource> resources =
|
final List<SearchIndexableResource> resources =
|
||||||
getSearchIndexableResourcesFromProvider(getContext());
|
getSearchIndexableResourcesFromProvider(getContext());
|
||||||
for (SearchIndexableResource val : resources) {
|
for (SearchIndexableResource val : resources) {
|
||||||
@@ -125,7 +125,7 @@ public class SettingsSearchIndexablesProvider extends SearchIndexablesProvider {
|
|||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public Cursor queryRawData(String[] projection) {
|
public Cursor queryRawData(String[] projection) {
|
||||||
MatrixCursor cursor = new MatrixCursor(INDEXABLES_RAW_COLUMNS);
|
final MatrixCursor cursor = new MatrixCursor(INDEXABLES_RAW_COLUMNS);
|
||||||
final List<SearchIndexableRaw> raws = getSearchIndexableRawFromProvider(getContext());
|
final List<SearchIndexableRaw> raws = getSearchIndexableRawFromProvider(getContext());
|
||||||
for (SearchIndexableRaw val : raws) {
|
for (SearchIndexableRaw val : raws) {
|
||||||
Object[] ref = new Object[INDEXABLES_RAW_COLUMNS.length];
|
Object[] ref = new Object[INDEXABLES_RAW_COLUMNS.length];
|
||||||
@@ -155,7 +155,7 @@ public class SettingsSearchIndexablesProvider extends SearchIndexablesProvider {
|
|||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public Cursor queryNonIndexableKeys(String[] projection) {
|
public Cursor queryNonIndexableKeys(String[] projection) {
|
||||||
MatrixCursor cursor = new MatrixCursor(NON_INDEXABLES_KEYS_COLUMNS);
|
final MatrixCursor cursor = new MatrixCursor(NON_INDEXABLES_KEYS_COLUMNS);
|
||||||
final List<String> nonIndexableKeys = getNonIndexableKeysFromProvider(getContext());
|
final List<String> nonIndexableKeys = getNonIndexableKeysFromProvider(getContext());
|
||||||
for (String nik : nonIndexableKeys) {
|
for (String nik : nonIndexableKeys) {
|
||||||
final Object[] ref = new Object[NON_INDEXABLES_KEYS_COLUMNS.length];
|
final Object[] ref = new Object[NON_INDEXABLES_KEYS_COLUMNS.length];
|
||||||
@@ -174,27 +174,29 @@ public class SettingsSearchIndexablesProvider extends SearchIndexablesProvider {
|
|||||||
@Override
|
@Override
|
||||||
public Cursor queryDynamicRawData(String[] projection) {
|
public Cursor queryDynamicRawData(String[] projection) {
|
||||||
final Context context = getContext();
|
final Context context = getContext();
|
||||||
final DashboardFeatureProvider dashboardFeatureProvider =
|
final List<SearchIndexableRaw> rawList = new ArrayList<>();
|
||||||
FeatureFactory.getFactory(context).getDashboardFeatureProvider(context);
|
rawList.addAll(getDynamicSearchIndexableRawFromProvider(context));
|
||||||
|
rawList.addAll(getInjectionIndexableRawData(context));
|
||||||
|
|
||||||
final MatrixCursor cursor = new MatrixCursor(INDEXABLES_RAW_COLUMNS);
|
final MatrixCursor cursor = new MatrixCursor(INDEXABLES_RAW_COLUMNS);
|
||||||
for (DashboardCategory category : dashboardFeatureProvider.getAllCategories()) {
|
for (SearchIndexableRaw raw : rawList) {
|
||||||
for (Tile tile : category.getTiles()) {
|
Object[] ref = new Object[INDEXABLES_RAW_COLUMNS.length];
|
||||||
final String packageName = tile.getPackageName();
|
ref[COLUMN_INDEX_RAW_TITLE] = raw.title;
|
||||||
if (context.getPackageName().equals(packageName)) {
|
ref[COLUMN_INDEX_RAW_SUMMARY_ON] = raw.summaryOn;
|
||||||
continue;
|
ref[COLUMN_INDEX_RAW_SUMMARY_OFF] = raw.summaryOff;
|
||||||
}
|
ref[COLUMN_INDEX_RAW_ENTRIES] = raw.entries;
|
||||||
final Object[] ref = new Object[INDEXABLES_RAW_COLUMNS.length];
|
ref[COLUMN_INDEX_RAW_KEYWORDS] = raw.keywords;
|
||||||
ref[COLUMN_INDEX_RAW_TITLE] = tile.getTitle(context);
|
ref[COLUMN_INDEX_RAW_SCREEN_TITLE] = raw.screenTitle;
|
||||||
ref[COLUMN_INDEX_RAW_SUMMARY_ON] = tile.getSummary(context);
|
ref[COLUMN_INDEX_RAW_CLASS_NAME] = raw.className;
|
||||||
ref[COLUMN_INDEX_RAW_SUMMARY_OFF] = tile.getSummary(context);
|
ref[COLUMN_INDEX_RAW_ICON_RESID] = raw.iconResId;
|
||||||
ref[COLUMN_INDEX_RAW_KEY] = dashboardFeatureProvider.getDashboardKeyForTile(
|
ref[COLUMN_INDEX_RAW_INTENT_ACTION] = raw.intentAction;
|
||||||
tile);
|
ref[COLUMN_INDEX_RAW_INTENT_TARGET_PACKAGE] = raw.intentTargetPackage;
|
||||||
ref[COLUMN_INDEX_RAW_CLASS_NAME] = CATEGORY_KEY_TO_PARENT_MAP.get(
|
ref[COLUMN_INDEX_RAW_INTENT_TARGET_CLASS] = raw.intentTargetClass;
|
||||||
tile.getCategory());
|
ref[COLUMN_INDEX_RAW_KEY] = raw.key;
|
||||||
cursor.addRow(ref);
|
ref[COLUMN_INDEX_RAW_USER_ID] = raw.userId;
|
||||||
}
|
cursor.addRow(ref);
|
||||||
}
|
}
|
||||||
|
|
||||||
return cursor;
|
return cursor;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -258,14 +260,13 @@ public class SettingsSearchIndexablesProvider extends SearchIndexablesProvider {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private List<String> getNonIndexableKeysFromProvider(Context context) {
|
private List<String> getNonIndexableKeysFromProvider(Context context) {
|
||||||
final Collection<Class> values = FeatureFactory.getFactory(context)
|
final Collection<Class> values = getIndexableProviderValues(context);
|
||||||
.getSearchFeatureProvider().getSearchIndexableResources().getProviderValues();
|
|
||||||
final List<String> nonIndexableKeys = new ArrayList<>();
|
final List<String> nonIndexableKeys = new ArrayList<>();
|
||||||
|
|
||||||
for (Class<?> clazz : values) {
|
for (Class<?> clazz : values) {
|
||||||
final long startTime = System.currentTimeMillis();
|
final long startTime = System.currentTimeMillis();
|
||||||
Indexable.SearchIndexProvider provider = DatabaseIndexingUtils.getSearchIndexProvider(
|
final Indexable.SearchIndexProvider provider =
|
||||||
clazz);
|
DatabaseIndexingUtils.getSearchIndexProvider(clazz);
|
||||||
|
|
||||||
List<String> providerNonIndexableKeys;
|
List<String> providerNonIndexableKeys;
|
||||||
try {
|
try {
|
||||||
@@ -309,14 +310,12 @@ public class SettingsSearchIndexablesProvider extends SearchIndexablesProvider {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private List<SearchIndexableResource> getSearchIndexableResourcesFromProvider(Context context) {
|
private List<SearchIndexableResource> getSearchIndexableResourcesFromProvider(Context context) {
|
||||||
Collection<Class> values = FeatureFactory.getFactory(context)
|
final Collection<Class> values = getIndexableProviderValues(context);
|
||||||
.getSearchFeatureProvider().getSearchIndexableResources().getProviderValues();
|
final List<SearchIndexableResource> resourceList = new ArrayList<>();
|
||||||
List<SearchIndexableResource> resourceList = new ArrayList<>();
|
|
||||||
|
|
||||||
for (Class<?> clazz : values) {
|
for (Class<?> clazz : values) {
|
||||||
Indexable.SearchIndexProvider provider = DatabaseIndexingUtils.getSearchIndexProvider(
|
final Indexable.SearchIndexProvider provider =
|
||||||
clazz);
|
DatabaseIndexingUtils.getSearchIndexProvider(clazz);
|
||||||
|
|
||||||
final List<SearchIndexableResource> resList =
|
final List<SearchIndexableResource> resList =
|
||||||
provider.getXmlResourcesToIndex(context, true);
|
provider.getXmlResourcesToIndex(context, true);
|
||||||
|
|
||||||
@@ -337,15 +336,14 @@ public class SettingsSearchIndexablesProvider extends SearchIndexablesProvider {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private List<SearchIndexableRaw> getSearchIndexableRawFromProvider(Context context) {
|
private List<SearchIndexableRaw> getSearchIndexableRawFromProvider(Context context) {
|
||||||
final Collection<Class> values = FeatureFactory.getFactory(context)
|
final Collection<Class> values = getIndexableProviderValues(context);
|
||||||
.getSearchFeatureProvider().getSearchIndexableResources().getProviderValues();
|
|
||||||
final List<SearchIndexableRaw> rawList = new ArrayList<>();
|
final List<SearchIndexableRaw> rawList = new ArrayList<>();
|
||||||
|
|
||||||
for (Class<?> clazz : values) {
|
for (Class<?> clazz : values) {
|
||||||
Indexable.SearchIndexProvider provider = DatabaseIndexingUtils.getSearchIndexProvider(
|
final Indexable.SearchIndexProvider provider =
|
||||||
clazz);
|
DatabaseIndexingUtils.getSearchIndexProvider(clazz);
|
||||||
final List<SearchIndexableRaw> providerRaws = provider.getRawDataToIndex(context,
|
final List<SearchIndexableRaw> providerRaws =
|
||||||
true /* enabled */);
|
provider.getRawDataToIndex(context, true /* enabled */);
|
||||||
|
|
||||||
if (providerRaws == null) {
|
if (providerRaws == null) {
|
||||||
continue;
|
continue;
|
||||||
@@ -362,4 +360,59 @@ public class SettingsSearchIndexablesProvider extends SearchIndexablesProvider {
|
|||||||
|
|
||||||
return rawList;
|
return rawList;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private List<SearchIndexableRaw> getDynamicSearchIndexableRawFromProvider(Context context) {
|
||||||
|
final Collection<Class> values = getIndexableProviderValues(context);
|
||||||
|
final List<SearchIndexableRaw> rawList = new ArrayList<>();
|
||||||
|
|
||||||
|
for (Class<?> clazz : values) {
|
||||||
|
final Indexable.SearchIndexProvider provider =
|
||||||
|
DatabaseIndexingUtils.getSearchIndexProvider(clazz);
|
||||||
|
final List<SearchIndexableRaw> providerRaws =
|
||||||
|
provider.getDynamicRawDataToIndex(context, true /* enabled */);
|
||||||
|
|
||||||
|
if (providerRaws == null) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (SearchIndexableRaw raw : providerRaws) {
|
||||||
|
// The classname and intent information comes from the PreIndexData
|
||||||
|
// This will be more clear when provider conversion is done at PreIndex time.
|
||||||
|
raw.className = clazz.getName();
|
||||||
|
|
||||||
|
}
|
||||||
|
rawList.addAll(providerRaws);
|
||||||
|
}
|
||||||
|
|
||||||
|
return rawList;
|
||||||
|
}
|
||||||
|
|
||||||
|
private List<SearchIndexableRaw> getInjectionIndexableRawData(Context context) {
|
||||||
|
final DashboardFeatureProvider dashboardFeatureProvider =
|
||||||
|
FeatureFactory.getFactory(context).getDashboardFeatureProvider(context);
|
||||||
|
|
||||||
|
final List<SearchIndexableRaw> rawList = new ArrayList<>();
|
||||||
|
for (DashboardCategory category : dashboardFeatureProvider.getAllCategories()) {
|
||||||
|
for (Tile tile : category.getTiles()) {
|
||||||
|
final String packageName = tile.getPackageName();
|
||||||
|
if (context.getPackageName().equals(packageName)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
final SearchIndexableRaw raw = new SearchIndexableRaw(context);
|
||||||
|
raw.title = tile.getTitle(context).toString();
|
||||||
|
raw.summaryOn = tile.getSummary(context).toString();
|
||||||
|
raw.summaryOff = tile.getSummary(context).toString();
|
||||||
|
raw.keywords = dashboardFeatureProvider.getDashboardKeyForTile(tile);
|
||||||
|
raw.className = CATEGORY_KEY_TO_PARENT_MAP.get(tile.getCategory());
|
||||||
|
rawList.add(raw);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return rawList;
|
||||||
|
}
|
||||||
|
|
||||||
|
private Collection<Class> getIndexableProviderValues(Context context) {
|
||||||
|
return FeatureFactory.getFactory(context)
|
||||||
|
.getSearchFeatureProvider().getSearchIndexableResources().getProviderValues();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user