• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 package com.android.launcher3.util;
2 
3 import android.content.ContentValues;
4 import android.content.Context;
5 import android.database.Cursor;
6 import android.database.sqlite.SQLiteDatabase;
7 import android.database.sqlite.SQLiteException;
8 import android.database.sqlite.SQLiteFullException;
9 import android.database.sqlite.SQLiteOpenHelper;
10 import android.util.Log;
11 
12 /**
13  * An extension of {@link SQLiteOpenHelper} with utility methods for a single table cache DB.
14  * Any exception during write operations are ignored, and any version change causes a DB reset.
15  */
16 public abstract class SQLiteCacheHelper {
17     private static final String TAG = "SQLiteCacheHelper";
18 
19     private final String mTableName;
20     private final MySQLiteOpenHelper mOpenHelper;
21 
22     private boolean mIgnoreWrites;
23 
SQLiteCacheHelper(Context context, String name, int version, String tableName)24     public SQLiteCacheHelper(Context context, String name, int version, String tableName) {
25         mTableName = tableName;
26         mOpenHelper = new MySQLiteOpenHelper(context, name, version);
27 
28         mIgnoreWrites = false;
29     }
30 
31     /**
32      * @see SQLiteDatabase#update(String, ContentValues, String, String[])
33      */
update(ContentValues values, String whereClause, String[] whereArgs)34     public void update(ContentValues values, String whereClause, String[] whereArgs) {
35         if (mIgnoreWrites) {
36             return;
37         }
38         try {
39             mOpenHelper.getWritableDatabase().update(mTableName, values, whereClause, whereArgs);
40         } catch (SQLiteFullException e) {
41             onDiskFull(e);
42         } catch (SQLiteException e) {
43             Log.d(TAG, "Ignoring sqlite exception", e);
44         }
45     }
46 
47     /**
48      * @see SQLiteDatabase#delete(String, String, String[])
49      */
delete(String whereClause, String[] whereArgs)50     public void delete(String whereClause, String[] whereArgs) {
51         if (mIgnoreWrites) {
52             return;
53         }
54         try {
55             mOpenHelper.getWritableDatabase().delete(mTableName, whereClause, whereArgs);
56         } catch (SQLiteFullException e) {
57             onDiskFull(e);
58         } catch (SQLiteException e) {
59             Log.d(TAG, "Ignoring sqlite exception", e);
60         }
61     }
62 
63     /**
64      * @see SQLiteDatabase#insertWithOnConflict(String, String, ContentValues, int)
65      */
insertOrReplace(ContentValues values)66     public void insertOrReplace(ContentValues values) {
67         if (mIgnoreWrites) {
68             return;
69         }
70         try {
71             mOpenHelper.getWritableDatabase().insertWithOnConflict(
72                     mTableName, null, values, SQLiteDatabase.CONFLICT_REPLACE);
73         } catch (SQLiteFullException e) {
74             onDiskFull(e);
75         } catch (SQLiteException e) {
76             Log.d(TAG, "Ignoring sqlite exception", e);
77         }
78     }
79 
onDiskFull(SQLiteFullException e)80     private void onDiskFull(SQLiteFullException e) {
81         Log.e(TAG, "Disk full, all write operations will be ignored", e);
82         mIgnoreWrites = true;
83     }
84 
85     /**
86      * @see SQLiteDatabase#query(String, String[], String, String[], String, String, String)
87      */
query(String[] columns, String selection, String[] selectionArgs)88     public Cursor query(String[] columns, String selection, String[] selectionArgs) {
89         return mOpenHelper.getReadableDatabase().query(
90                 mTableName, columns, selection, selectionArgs, null, null, null);
91     }
92 
onCreateTable(SQLiteDatabase db)93     protected abstract void onCreateTable(SQLiteDatabase db);
94 
95     /**
96      * A private inner class to prevent direct DB access.
97      */
98     private class MySQLiteOpenHelper extends SQLiteOpenHelper {
99 
MySQLiteOpenHelper(Context context, String name, int version)100         public MySQLiteOpenHelper(Context context, String name, int version) {
101             super(context, name, null, version);
102         }
103 
104         @Override
onCreate(SQLiteDatabase db)105         public void onCreate(SQLiteDatabase db) {
106             onCreateTable(db);
107         }
108 
109         @Override
onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion)110         public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
111             if (oldVersion != newVersion) {
112                 clearDB(db);
113             }
114         }
115 
116         @Override
onDowngrade(SQLiteDatabase db, int oldVersion, int newVersion)117         public void onDowngrade(SQLiteDatabase db, int oldVersion, int newVersion) {
118             if (oldVersion != newVersion) {
119                 clearDB(db);
120             }
121         }
122 
clearDB(SQLiteDatabase db)123         private void clearDB(SQLiteDatabase db) {
124             db.execSQL("DROP TABLE IF EXISTS " + mTableName);
125             onCreate(db);
126         }
127     }
128 }
129