aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJorge Ruesga <jorge@ruesga.com>2013-11-15 02:56:16 +0100
committerJorge Ruesga <jorge@ruesga.com>2013-11-15 23:55:36 +0100
commit9f7277602bf9cf93ba6083e877a615b3eb0460c3 (patch)
tree9400dd67461d001ee607fbcee54763bb958f0379
parentc40fa2c85135989dcf07b77d0ed4171c5edf9a30 (diff)
downloadandroid_packages_apps_CMFileManager-9f7277602bf9cf93ba6083e877a615b3eb0460c3.tar.gz
android_packages_apps_CMFileManager-9f7277602bf9cf93ba6083e877a615b3eb0460c3.tar.bz2
android_packages_apps_CMFileManager-9f7277602bf9cf93ba6083e877a615b3eb0460c3.zip
CMFM: Remove orphan bookmarks
Change-Id: I49a121af9745651bb6f96ba81313589da3c096c3 Signed-off-by: Jorge Ruesga <jorge@ruesga.com>
-rw-r--r--src/com/cyanogenmod/filemanager/preferences/Bookmarks.java27
-rw-r--r--src/com/cyanogenmod/filemanager/ui/policy/CopyMoveActionPolicy.java8
-rw-r--r--src/com/cyanogenmod/filemanager/ui/policy/DeleteActionPolicy.java9
3 files changed, 43 insertions, 1 deletions
diff --git a/src/com/cyanogenmod/filemanager/preferences/Bookmarks.java b/src/com/cyanogenmod/filemanager/preferences/Bookmarks.java
index 998b7153..0c76a23b 100644
--- a/src/com/cyanogenmod/filemanager/preferences/Bookmarks.java
+++ b/src/com/cyanogenmod/filemanager/preferences/Bookmarks.java
@@ -152,6 +152,33 @@ public class Bookmarks {
}
/**
+ * Method that remove all orphan bookmarks derived from "path"
+ *
+ * @param ctx The current context
+ * @param path The path to check
+ */
+ public static void deleteOrphanBookmarks(Context ctx, String path) {
+ ContentResolver cr = ctx.getContentResolver();
+ Cursor cursor = Bookmarks.getAllBookmarks(cr);
+ try {
+ if (cursor != null && cursor.moveToFirst()) {
+ do {
+ Bookmark bm = new Bookmark(cursor);
+ if (bm.mPath.startsWith(path)) {
+ removeBookmark(ctx, bm);
+ }
+ } while (cursor.moveToNext());
+ }
+ } finally {
+ try {
+ if (cursor != null) {
+ cursor.close();
+ }
+ } catch (Exception e) {/**NON BLOCK**/}
+ }
+ }
+
+ /**
* Method that create the {@link ContentValues} from the bookmark
*
* @param bookmark The bookmark
diff --git a/src/com/cyanogenmod/filemanager/ui/policy/CopyMoveActionPolicy.java b/src/com/cyanogenmod/filemanager/ui/policy/CopyMoveActionPolicy.java
index 1f583e96..c2923f3e 100644
--- a/src/com/cyanogenmod/filemanager/ui/policy/CopyMoveActionPolicy.java
+++ b/src/com/cyanogenmod/filemanager/ui/policy/CopyMoveActionPolicy.java
@@ -28,6 +28,7 @@ import com.cyanogenmod.filemanager.console.RelaunchableException;
import com.cyanogenmod.filemanager.listeners.OnRequestRefreshListener;
import com.cyanogenmod.filemanager.listeners.OnSelectionListener;
import com.cyanogenmod.filemanager.model.FileSystemObject;
+import com.cyanogenmod.filemanager.preferences.Bookmarks;
import com.cyanogenmod.filemanager.util.CommandHelper;
import com.cyanogenmod.filemanager.util.DialogHelper;
import com.cyanogenmod.filemanager.util.ExceptionUtil;
@@ -302,6 +303,13 @@ public final class CopyMoveActionPolicy extends ActionsPolicy {
@Override
public void onSuccess() {
+ // Remove orphan bookmark paths
+ if (files != null) {
+ for (LinkedResource linkedFiles : files) {
+ Bookmarks.deleteOrphanBookmarks(ctx, linkedFiles.mSrc.getAbsolutePath());
+ }
+ }
+
//Operation complete. Refresh
if (this.mOnRequestRefreshListener != null) {
// The reference is not the same, so refresh the complete navigation view
diff --git a/src/com/cyanogenmod/filemanager/ui/policy/DeleteActionPolicy.java b/src/com/cyanogenmod/filemanager/ui/policy/DeleteActionPolicy.java
index 039f4fe8..843afe24 100644
--- a/src/com/cyanogenmod/filemanager/ui/policy/DeleteActionPolicy.java
+++ b/src/com/cyanogenmod/filemanager/ui/policy/DeleteActionPolicy.java
@@ -28,6 +28,7 @@ import com.cyanogenmod.filemanager.console.RelaunchableException;
import com.cyanogenmod.filemanager.listeners.OnRequestRefreshListener;
import com.cyanogenmod.filemanager.listeners.OnSelectionListener;
import com.cyanogenmod.filemanager.model.FileSystemObject;
+import com.cyanogenmod.filemanager.preferences.Bookmarks;
import com.cyanogenmod.filemanager.ui.widgets.FlingerListView.OnItemFlingerResponder;
import com.cyanogenmod.filemanager.util.CommandHelper;
import com.cyanogenmod.filemanager.util.DialogHelper;
@@ -192,6 +193,13 @@ public final class DeleteActionPolicy extends ActionsPolicy {
onItemFlingerResponder.accept();
}
+ // Remove orphan bookmark paths
+ if (files != null) {
+ for (FileSystemObject fso : files) {
+ Bookmarks.deleteOrphanBookmarks(ctx, fso.getFullPath());
+ }
+ }
+
// Refresh
if (this.mOnRequestRefreshListener != null) {
// The reference is not the same, so refresh the complete navigation view
@@ -232,7 +240,6 @@ public final class DeleteActionPolicy extends ActionsPolicy {
* @param ctx The current context
* @param fso The file or folder to be deleted
*/
- @SuppressWarnings("hiding")
private void doOperation(
final Context ctx, final FileSystemObject fso) throws Throwable {
try {