From: David A. Velasco Date: Mon, 5 Nov 2012 14:44:09 +0000 (+0100) Subject: Removal of folders completed X-Git-Tag: oc-android-1.4.3~88^2~14 X-Git-Url: http://git.linex4red.de/pub/Android/ownCloud.git/commitdiff_plain/b27ebf0310b2355cdd825c43b995e12688ae3df0 Removal of folders completed --- diff --git a/res/values/strings.xml b/res/values/strings.xml index fd2915c7..557486b5 100644 --- a/res/values/strings.xml +++ b/res/values/strings.xml @@ -170,7 +170,9 @@ Remove "Do you really want to remove %1$s ?" + "Do you really want to remove %1$s and its contents ?" Local only + Local contents only Remove from server Remote and local diff --git a/src/com/owncloud/android/datamodel/DataStorageManager.java b/src/com/owncloud/android/datamodel/DataStorageManager.java index 49a3cd73..7cca9702 100644 --- a/src/com/owncloud/android/datamodel/DataStorageManager.java +++ b/src/com/owncloud/android/datamodel/DataStorageManager.java @@ -40,4 +40,6 @@ public interface DataStorageManager { public Vector getDirectoryContent(OCFile f); public void removeFile(OCFile file, boolean removeLocalCopy); + + public void removeDirectory(OCFile dir, boolean removeDBData, boolean removeLocalContent); } diff --git a/src/com/owncloud/android/datamodel/FileDataStorageManager.java b/src/com/owncloud/android/datamodel/FileDataStorageManager.java index 7589b813..1f7ee4c3 100644 --- a/src/com/owncloud/android/datamodel/FileDataStorageManager.java +++ b/src/com/owncloud/android/datamodel/FileDataStorageManager.java @@ -428,6 +428,40 @@ public class FileDataStorageManager implements DataStorageManager { if (file.isDown() && removeLocalCopy) { new File(file.getStoragePath()).delete(); } + if (file.isDirectory() && removeLocalCopy) { + File f = new File(FileDownloader.getSavePath(mAccount.name) + file.getRemotePath()); + if (f.exists() && f.isDirectory() && (f.list() == null || f.list().length == 0)) { + f.delete(); + } + } + } + + @Override + public void removeDirectory(OCFile dir, boolean removeDBData, boolean removeLocalContent) { + // TODO consider possible failures + if (dir != null && dir.isDirectory() && dir.getFileId() != -1) { + Vector children = getDirectoryContent(dir); + if (children != null) { + OCFile child = null; + for (int i=0; i