Back to project page android-database-sqlcipher.
The source code is released under:
Apache License
If you think the Android project android-database-sqlcipher listed in this page is inappropriate, such as containing malicious code/tools or violating the copyright, please email info at java2s dot com, thanks.
/* * Copyright (C) 2008 Esmertec AG.//from w w w.j av a 2 s. c om * Copyright (C) 2008 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package net.sqlcipher.database; import android.content.ContentResolver; import android.content.ContentValues; import android.content.Context; import net.sqlcipher.*; import android.net.Uri; import android.util.Log; import android.widget.Toast; /** * @hide */ public final class SqliteWrapper { private static final String TAG = "SqliteWrapper"; private static final String SQLITE_EXCEPTION_DETAIL_MESSAGE = "unable to open database file"; private SqliteWrapper() { // Forbidden being instantiated. } // FIXME: need to optimize this method. private static boolean isLowMemory(SQLiteException e) { return e.getMessage().equals(SQLITE_EXCEPTION_DETAIL_MESSAGE); } public static void checkSQLiteException(Context context, SQLiteException e) { if (isLowMemory(e)) { Toast.makeText(context, e.getMessage(), Toast.LENGTH_SHORT).show(); } else { throw e; } } public static Cursor query(Context context, ContentResolver resolver, Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder) { try { return (Cursor) resolver.query(uri, projection, selection, selectionArgs, sortOrder); } catch (SQLiteException e) { Log.e(TAG, "Catch a SQLiteException when query: ", e); checkSQLiteException(context, e); return null; } } public static boolean requery(Context context, android.database.Cursor cursor) { try { return cursor.requery(); } catch (SQLiteException e) { Log.e(TAG, "Catch a SQLiteException when requery: ", e); checkSQLiteException(context, e); return false; } } public static int update(Context context, ContentResolver resolver, Uri uri, ContentValues values, String where, String[] selectionArgs) { try { return resolver.update(uri, values, where, selectionArgs); } catch (SQLiteException e) { Log.e(TAG, "Catch a SQLiteException when update: ", e); checkSQLiteException(context, e); return -1; } } public static int delete(Context context, ContentResolver resolver, Uri uri, String where, String[] selectionArgs) { try { return resolver.delete(uri, where, selectionArgs); } catch (SQLiteException e) { Log.e(TAG, "Catch a SQLiteException when delete: ", e); checkSQLiteException(context, e); return -1; } } public static Uri insert(Context context, ContentResolver resolver, Uri uri, ContentValues values) { try { return resolver.insert(uri, values); } catch (SQLiteException e) { Log.e(TAG, "Catch a SQLiteException when insert: ", e); checkSQLiteException(context, e); return null; } } }