summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGeorge Mount <mount@google.com>2013-04-11 20:52:32 +0000
committerAndroid (Google) Code Review <android-gerrit@google.com>2013-04-11 20:52:32 +0000
commitd6d4cccf7d4393fc90d2b8504873894c714aec2d (patch)
tree6b451a4ebc9154933c4e4e95f747336d4ea3976f
parent966f219a6bd36c4ddb8d07259fa31097a441745e (diff)
parent6e19729992bb98f77a72d34ce330d2e2c0910c68 (diff)
downloadandroid_packages_apps_Snap-d6d4cccf7d4393fc90d2b8504873894c714aec2d.tar.gz
android_packages_apps_Snap-d6d4cccf7d4393fc90d2b8504873894c714aec2d.tar.bz2
android_packages_apps_Snap-d6d4cccf7d4393fc90d2b8504873894c714aec2d.zip
Merge "Add _COUNT support for PhotoProvider to help performance of All Photos." into gb-ub-photos-bryce
-rw-r--r--src/com/android/photos/data/PhotoProvider.java12
1 files changed, 12 insertions, 0 deletions
diff --git a/src/com/android/photos/data/PhotoProvider.java b/src/com/android/photos/data/PhotoProvider.java
index cffd1239e..d4310ca95 100644
--- a/src/com/android/photos/data/PhotoProvider.java
+++ b/src/com/android/photos/data/PhotoProvider.java
@@ -226,6 +226,9 @@ public class PhotoProvider extends SQLiteContentProvider {
protected static final String IN = " IN ";
protected static final String NESTED_SELECT_START = "(";
protected static final String NESTED_SELECT_END = ")";
+ protected static final String[] PROJECTION_COUNT = {
+ "COUNT(*)"
+ };
/**
* For selecting the mime-type for an image.
@@ -310,6 +313,7 @@ public class PhotoProvider extends SQLiteContentProvider {
@Override
public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs,
String sortOrder, CancellationSignal cancellationSignal) {
+ projection = replaceCount(projection);
int match = matchUri(uri);
selection = addIdToSelection(match, selection);
selectionArgs = addIdToSelectionArgs(match, uri, selectionArgs);
@@ -521,4 +525,12 @@ public class PhotoProvider extends SQLiteContentProvider {
return db.query(table, columns, selection, selectionArgs, null, null, orderBy);
}
}
+
+ protected static String[] replaceCount(String[] projection) {
+ if (projection != null && projection.length == 1
+ && BaseColumns._COUNT.equals(projection[0])) {
+ return PROJECTION_COUNT;
+ }
+ return projection;
+ }
}