summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDmitri Plotnikov <dplotnikov@google.com>2011-02-10 16:49:29 -0800
committerDmitri Plotnikov <dplotnikov@google.com>2011-02-10 16:49:29 -0800
commit7ba290f5de7f116ec0eaac30980ffef2878d2b64 (patch)
tree21e7b9e983fa2547b5bbb04cc5a3baf1967468d6
parent197411a6cc3f81b94a34ca207f267d43d8548f04 (diff)
downloadpackages_providers_ContactsProvider-7ba290f5de7f116ec0eaac30980ffef2878d2b64.zip
packages_providers_ContactsProvider-7ba290f5de7f116ec0eaac30980ffef2878d2b64.tar.gz
packages_providers_ContactsProvider-7ba290f5de7f116ec0eaac30980ffef2878d2b64.tar.bz2
Full text search: optimizing index use
Bug: 2078420 Change-Id: Ibf4ebdd03934d68402d123bb39c6a061c609e3e9
-rw-r--r--src/com/android/providers/contacts/ContactsProvider2.java39
1 files changed, 13 insertions, 26 deletions
diff --git a/src/com/android/providers/contacts/ContactsProvider2.java b/src/com/android/providers/contacts/ContactsProvider2.java
index e281ba7..9edbd2e 100644
--- a/src/com/android/providers/contacts/ContactsProvider2.java
+++ b/src/com/android/providers/contacts/ContactsProvider2.java
@@ -3385,8 +3385,8 @@ public class ContactsProvider2 extends SQLiteContentProvider implements OnAccoun
if (uri.getPathSegments().size() > 2) {
filterParam = uri.getLastPathSegment();
}
- setTablesAndProjectionMapForContactsWithSnippet(qb, uri, projection, filterParam);
- appendLocalDirectorySelectionIfNeeded(qb, directoryId);
+ setTablesAndProjectionMapForContactsWithSnippet(
+ qb, uri, projection, filterParam, directoryId);
break;
}
@@ -4323,7 +4323,9 @@ public class ContactsProvider2 extends SQLiteContentProvider implements OnAccoun
private void setTablesAndProjectionMapForContacts(SQLiteQueryBuilder qb, Uri uri,
String[] projection) {
StringBuilder sb = new StringBuilder();
- appendContactsTables(sb, uri, projection);
+ sb.append(mDbHelper.getContactView(shouldExcludeRestrictedData(uri)));
+ appendContactPresenceJoin(sb, projection, Contacts._ID);
+ appendContactStatusUpdateJoin(sb, projection, ContactsColumns.LAST_STATUS_UPDATE_ID);
qb.setTables(sb.toString());
qb.setProjectionMap(sContactsProjectionMap);
}
@@ -4333,19 +4335,22 @@ public class ContactsProvider2 extends SQLiteContentProvider implements OnAccoun
* contact and joins that with other contacts tables.
*/
private void setTablesAndProjectionMapForContactsWithSnippet(SQLiteQueryBuilder qb, Uri uri,
- String[] projection, String filter) {
+ String[] projection, String filter, long directoryId) {
+
+ StringBuilder sb = new StringBuilder();
+ sb.append(mDbHelper.getContactView(shouldExcludeRestrictedData(uri)));
if (filter != null) {
filter = filter.trim();
}
- StringBuilder sb = new StringBuilder();
- appendContactsTables(sb, uri, projection);
- if (TextUtils.isEmpty(filter)) {
+ if (TextUtils.isEmpty(filter) || directoryId != Directory.DEFAULT) {
sb.append(" JOIN (SELECT NULL AS " + SearchSnippetColumns.SNIPPET + ") WHERE 0");
} else {
appendSearchIndexJoin(sb, uri, projection, filter);
}
+ appendContactPresenceJoin(sb, projection, Contacts._ID);
+ appendContactStatusUpdateJoin(sb, projection, ContactsColumns.LAST_STATUS_UPDATE_ID);
qb.setTables(sb.toString());
qb.setProjectionMap(sContactsProjectionWithSnippetMap);
}
@@ -4490,27 +4495,9 @@ public class ContactsProvider2 extends SQLiteContentProvider implements OnAccoun
sb.append(")");
}
- private void appendContactsTables(StringBuilder sb, Uri uri, String[] projection) {
- boolean excludeRestrictedData = false;
- String requestingPackage = getQueryParameter(uri,
- ContactsContract.REQUESTING_PACKAGE_PARAM_KEY);
- if (requestingPackage != null) {
- excludeRestrictedData = !mDbHelper.hasAccessToRestrictedData(requestingPackage);
- }
- sb.append(mDbHelper.getContactView(excludeRestrictedData));
- appendContactPresenceJoin(sb, projection, Contacts._ID);
- appendContactStatusUpdateJoin(sb, projection, ContactsColumns.LAST_STATUS_UPDATE_ID);
- }
-
private void setTablesAndProjectionMapForRawContacts(SQLiteQueryBuilder qb, Uri uri) {
StringBuilder sb = new StringBuilder();
- boolean excludeRestrictedData = false;
- String requestingPackage = getQueryParameter(uri,
- ContactsContract.REQUESTING_PACKAGE_PARAM_KEY);
- if (requestingPackage != null) {
- excludeRestrictedData = !mDbHelper.hasAccessToRestrictedData(requestingPackage);
- }
- sb.append(mDbHelper.getRawContactView(excludeRestrictedData));
+ sb.append(mDbHelper.getRawContactView(shouldExcludeRestrictedData(uri)));
qb.setTables(sb.toString());
qb.setProjectionMap(sRawContactsProjectionMap);
appendAccountFromParameter(qb, uri);