summaryrefslogtreecommitdiffstats
path: root/src/com/android/browser
diff options
context:
space:
mode:
Diffstat (limited to 'src/com/android/browser')
-rw-r--r--src/com/android/browser/provider/BrowserProvider2.java145
1 files changed, 95 insertions, 50 deletions
diff --git a/src/com/android/browser/provider/BrowserProvider2.java b/src/com/android/browser/provider/BrowserProvider2.java
index 8137d55..cdda1e4 100644
--- a/src/com/android/browser/provider/BrowserProvider2.java
+++ b/src/com/android/browser/provider/BrowserProvider2.java
@@ -63,13 +63,17 @@ public class BrowserProvider2 extends SQLiteContentProvider {
static final String TABLE_SEARCHES = "searches";
static final String TABLE_SYNC_STATE = "syncstate";
static final String TABLE_SETTINGS = "settings";
- static final String VIEW_COMBINED = "combined";
static final String TABLE_BOOKMARKS_JOIN_IMAGES = "bookmarks LEFT OUTER JOIN images " +
"ON bookmarks.url = images." + Images.URL;
static final String TABLE_HISTORY_JOIN_IMAGES = "history LEFT OUTER JOIN images " +
"ON history.url = images." + Images.URL;
+ static final String FORMAT_COMBINED_JOIN_SUBQUERY_JOIN_IMAGES =
+ "history LEFT OUTER JOIN (%s) bookmarks " +
+ "ON history.url = bookmarks.url LEFT OUTER JOIN images " +
+ "ON history.url = images.url_key";
+
static final String DEFAULT_SORT_HISTORY = History.DATE_LAST_VISITED + " DESC";
static final String DEFAULT_SORT_SEARCHES = Searches.DATE + " DESC";
@@ -115,7 +119,8 @@ public class BrowserProvider2 extends SQLiteContentProvider {
static final HashMap<String, String> HISTORY_PROJECTION_MAP = new HashMap<String, String>();
static final HashMap<String, String> SYNC_STATE_PROJECTION_MAP = new HashMap<String, String>();
static final HashMap<String, String> IMAGES_PROJECTION_MAP = new HashMap<String, String>();
- static final HashMap<String, String> COMBINED_PROJECTION_MAP = new HashMap<String, String>();
+ static final HashMap<String, String> COMBINED_HISTORY_PROJECTION_MAP = new HashMap<String, String>();
+ static final HashMap<String, String> COMBINED_BOOKMARK_PROJECTION_MAP = new HashMap<String, String>();
static final HashMap<String, String> SEARCHES_PROJECTION_MAP = new HashMap<String, String>();
static final HashMap<String, String> SETTINGS_PROJECTION_MAP = new HashMap<String, String>();
@@ -213,18 +218,34 @@ public class BrowserProvider2 extends SQLiteContentProvider {
map.put(Images.TOUCH_ICON, Images.TOUCH_ICON);
// Combined history half
- map = COMBINED_PROJECTION_MAP;
+ map = COMBINED_HISTORY_PROJECTION_MAP;
+ map.put(Combined._ID, bookmarkOrHistoryColumn(Combined._ID));
+ map.put(Combined.TITLE, bookmarkOrHistoryColumn(Combined.TITLE));
+ map.put(Combined.URL, qualifyColumn(TABLE_HISTORY, Combined.URL));
+ map.put(Combined.DATE_CREATED, qualifyColumn(TABLE_HISTORY, Combined.DATE_CREATED));
+ map.put(Combined.DATE_LAST_VISITED, Combined.DATE_LAST_VISITED);
+ map.put(Combined.IS_BOOKMARK, "CASE WHEN " +
+ TABLE_BOOKMARKS + "." + Bookmarks._ID +
+ " IS NOT NULL THEN 1 ELSE 0 END AS " + Combined.IS_BOOKMARK);
+ map.put(Combined.VISITS, Combined.VISITS);
+ map.put(Combined.FAVICON, Combined.FAVICON);
+ map.put(Combined.THUMBNAIL, Combined.THUMBNAIL);
+ map.put(Combined.TOUCH_ICON, Combined.TOUCH_ICON);
+ map.put(Combined.USER_ENTERED, "NULL AS " + Combined.USER_ENTERED);
+
+ // Combined bookmark half
+ map = COMBINED_BOOKMARK_PROJECTION_MAP;
map.put(Combined._ID, Combined._ID);
map.put(Combined.TITLE, Combined.TITLE);
map.put(Combined.URL, Combined.URL);
map.put(Combined.DATE_CREATED, Combined.DATE_CREATED);
- map.put(Combined.DATE_LAST_VISITED, Combined.DATE_LAST_VISITED);
- map.put(Combined.IS_BOOKMARK, Combined.IS_BOOKMARK);
- map.put(Combined.VISITS, Combined.VISITS);
+ map.put(Combined.DATE_LAST_VISITED, "NULL AS " + Combined.DATE_LAST_VISITED);
+ map.put(Combined.IS_BOOKMARK, "1 AS " + Combined.IS_BOOKMARK);
+ map.put(Combined.VISITS, "0 AS " + Combined.VISITS);
map.put(Combined.FAVICON, Combined.FAVICON);
map.put(Combined.THUMBNAIL, Combined.THUMBNAIL);
map.put(Combined.TOUCH_ICON, Combined.TOUCH_ICON);
- map.put(Combined.USER_ENTERED, Combined.USER_ENTERED);
+ map.put(Combined.USER_ENTERED, "NULL AS " + Combined.USER_ENTERED);
// Searches
map = SEARCHES_PROJECTION_MAP;
@@ -252,7 +273,7 @@ public class BrowserProvider2 extends SQLiteContentProvider {
final class DatabaseHelper extends SQLiteOpenHelper {
static final String DATABASE_NAME = "browser2.db";
- static final int DATABASE_VERSION = 25;
+ static final int DATABASE_VERSION = 26;
public DatabaseHelper(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}
@@ -314,37 +335,6 @@ public class BrowserProvider2 extends SQLiteContentProvider {
Settings.VALUE + " TEXT NOT NULL" +
");");
- db.execSQL("CREATE VIEW " + VIEW_COMBINED + " AS " +
- "SELECT " +
- bookmarkOrHistoryColumn(Combined._ID) + ", " +
- bookmarkOrHistoryColumn(Combined.TITLE) + ", " +
- qualifyColumn(TABLE_HISTORY, Combined.URL) + ", " +
- qualifyColumn(TABLE_HISTORY, Combined.DATE_CREATED) + ", " +
- Combined.DATE_LAST_VISITED + ", " +
- "CASE WHEN bookmarks._id IS NOT NULL THEN 1 ELSE 0 END AS " + Combined.IS_BOOKMARK + ", " +
- Combined.VISITS + ", " +
- Combined.FAVICON + ", " +
- Combined.THUMBNAIL + ", " +
- Combined.TOUCH_ICON + ", " +
- "NULL AS " + Combined.USER_ENTERED + " "+
- "FROM history LEFT OUTER JOIN bookmarks ON history.url = bookmarks.url LEFT OUTER JOIN images ON history.url = images.url_key " +
-
- "UNION ALL " +
-
- "SELECT " +
- Combined._ID + ", " +
- Combined.TITLE + ", " +
- Combined.URL + ", " +
- Combined.DATE_CREATED + ", " +
- "NULL AS " + Combined.DATE_LAST_VISITED + ", "+
- "1 AS " + Combined.IS_BOOKMARK + ", " +
- "0 AS " + Combined.VISITS + ", "+
- Combined.FAVICON + ", " +
- Combined.THUMBNAIL + ", " +
- Combined.TOUCH_ICON + ", " +
- "NULL AS " + Combined.USER_ENTERED + " "+
- "FROM bookmarks LEFT OUTER JOIN images ON bookmarks.url = images.url_key WHERE url NOT IN (SELECT url FROM history)");
-
mSyncHelper.createDatabase(db);
createDefaultBookmarks(db);
@@ -353,14 +343,16 @@ public class BrowserProvider2 extends SQLiteContentProvider {
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
// TODO write upgrade logic
- db.execSQL("DROP TABLE IF EXISTS " + TABLE_BOOKMARKS);
- db.execSQL("DROP TABLE IF EXISTS " + TABLE_HISTORY);
- db.execSQL("DROP TABLE IF EXISTS " + TABLE_SEARCHES);
- db.execSQL("DROP TABLE IF EXISTS " + TABLE_IMAGES);
- db.execSQL("DROP TABLE IF EXISTS " + TABLE_SETTINGS);
- db.execSQL("DROP VIEW IF EXISTS " + VIEW_COMBINED);
- mSyncHelper.onAccountsChanged(db, new Account[] {}); // remove all sync info
- onCreate(db);
+ db.execSQL("DROP VIEW IF EXISTS combined");
+ if (oldVersion < 25) {
+ db.execSQL("DROP TABLE IF EXISTS " + TABLE_BOOKMARKS);
+ db.execSQL("DROP TABLE IF EXISTS " + TABLE_HISTORY);
+ db.execSQL("DROP TABLE IF EXISTS " + TABLE_SEARCHES);
+ db.execSQL("DROP TABLE IF EXISTS " + TABLE_IMAGES);
+ db.execSQL("DROP TABLE IF EXISTS " + TABLE_SETTINGS);
+ mSyncHelper.onAccountsChanged(db, new Account[] {}); // remove all sync info
+ onCreate(db);
+ }
}
@Override
@@ -746,14 +738,19 @@ public class BrowserProvider2 extends SQLiteContentProvider {
}
case COMBINED_ID: {
- selection = DatabaseUtils.concatenateWhere(selection, VIEW_COMBINED + "._id=?");
+ selection = DatabaseUtils.concatenateWhere(selection, Combined._ID +"=?");
selectionArgs = DatabaseUtils.appendSelectionArgs(selectionArgs,
new String[] { Long.toString(ContentUris.parseId(uri)) });
// fall through
}
case COMBINED: {
- qb.setTables(VIEW_COMBINED);
- qb.setProjectionMap(COMBINED_PROJECTION_MAP);
+ qb = new SQLiteQueryBuilder();
+ String[] args = createCombinedQuery(uri, projection, qb);
+ if (selectionArgs == null) {
+ selectionArgs = args;
+ } else {
+ selectionArgs = DatabaseUtils.appendSelectionArgs(args, selectionArgs);
+ }
break;
}
@@ -774,6 +771,54 @@ public class BrowserProvider2 extends SQLiteContentProvider {
return cursor;
}
+ private String[] createCombinedQuery(
+ Uri uri, String[] projection, SQLiteQueryBuilder qb) {
+ String[] args = null;
+ // Look for account info
+ String accountType = uri.getQueryParameter(Bookmarks.PARAM_ACCOUNT_TYPE);
+ String accountName = uri.getQueryParameter(Bookmarks.PARAM_ACCOUNT_NAME);
+ StringBuilder whereBuilder = new StringBuilder(128);
+ whereBuilder.append(Bookmarks.IS_DELETED);
+ whereBuilder.append(" = 0 AND ");
+ if (!TextUtils.isEmpty(accountName) && !TextUtils.isEmpty(accountType)) {
+ whereBuilder.append(Bookmarks.ACCOUNT_NAME);
+ whereBuilder.append("=? AND ");
+ whereBuilder.append(Bookmarks.ACCOUNT_TYPE);
+ whereBuilder.append("=?");
+ // We use this where twice
+ args = new String[] { accountName, accountType,
+ accountName, accountType};
+ } else {
+ whereBuilder.append(Bookmarks.ACCOUNT_NAME);
+ whereBuilder.append(" IS NULL AND ");
+ whereBuilder.append(Bookmarks.ACCOUNT_TYPE);
+ whereBuilder.append(" IS NULL");
+ }
+ String where = whereBuilder.toString();
+ // Build the bookmark subquery for history union subquery
+ qb.setTables(TABLE_BOOKMARKS);
+ String subQuery = qb.buildQuery(null, where, null, null, null, null);
+ // Build the history union subquery
+ qb.setTables(String.format(FORMAT_COMBINED_JOIN_SUBQUERY_JOIN_IMAGES, subQuery));
+ qb.setProjectionMap(COMBINED_HISTORY_PROJECTION_MAP);
+ String historySubQuery = qb.buildQuery(null,
+ null, null, null, null, null);
+ // Build the bookmark union subquery
+ qb.setTables(TABLE_BOOKMARKS_JOIN_IMAGES);
+ qb.setProjectionMap(COMBINED_BOOKMARK_PROJECTION_MAP);
+ where += String.format(" AND %s NOT IN (SELECT %s FROM %s)",
+ Combined.URL, History.URL, TABLE_HISTORY);
+ String bookmarksSubQuery = qb.buildQuery(null, where,
+ null, null, null, null);
+ // Put it all together
+ String query = qb.buildUnionQuery(
+ new String[] {historySubQuery, bookmarksSubQuery},
+ null, null);
+ qb.setTables("(" + query + ")");
+ qb.setProjectionMap(null);
+ return args;
+ }
+
@Override
public int deleteInTransaction(Uri uri, String selection, String[] selectionArgs,
boolean callerIsSyncAdapter) {