X-Git-Url: http://git.linex4red.de/pub/Android/ownCloud.git/blobdiff_plain/5f41bb14d370e0c9c0a8003e4ed122f466b0ce71..70e79071435bc8d7a53f36eb4202c4ec05dd2075:/src/com/owncloud/android/utils/FileStorageUtils.java diff --git a/src/com/owncloud/android/utils/FileStorageUtils.java b/src/com/owncloud/android/utils/FileStorageUtils.java index 0851b035..10d17090 100644 --- a/src/com/owncloud/android/utils/FileStorageUtils.java +++ b/src/com/owncloud/android/utils/FileStorageUtils.java @@ -47,19 +47,46 @@ import android.webkit.MimeTypeMap; * Static methods to help in access to local file system. */ public class FileStorageUtils { - public static Integer mSortOrder; - public static Boolean mSortAscending; public static final Integer SORT_NAME = 0; public static final Integer SORT_DATE = 1; public static final Integer SORT_SIZE = 2; - - - //private static final String LOG_TAG = "FileStorageUtils"; + public static Integer mSortOrder = SORT_NAME; + public static Boolean mSortAscending = true; + + //private static final String TAG = FileStorageUtils.class.getSimpleName(); + + @SuppressLint("NewApi") + private static final File getBaseStorePath() { + File baseStoragePath = Environment.getExternalStorageDirectory(); + if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.KITKAT) { + File[] dirs = MainApp.getAppContext().getExternalFilesDirs(null); + if (dirs.length > 1) { + baseStoragePath = dirs[1]; + } + } + return baseStoragePath; + } + + @SuppressLint("NewApi") + private static final String getBaseStorePathString() { + File baseStoragePath = Environment.getExternalStorageDirectory(); + if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.KITKAT) { + File[] dirs = MainApp.getAppContext().getExternalFilesDirs(null); + if (dirs.length > 1) { + baseStoragePath = dirs[1]; + } + return baseStoragePath.getAbsolutePath(); + } else { + return baseStoragePath.getAbsolutePath() + "/" + MainApp.getDataFolder(); + } + } public static final String getSavePath(String accountName) { - File sdCard = Environment.getExternalStorageDirectory(); - return sdCard.getAbsolutePath() + "/" + MainApp.getDataFolder() + "/" + Uri.encode(accountName, "@"); + //File sdCard = Environment.getExternalStorageDirectory(); + //return sdCard.getAbsolutePath() + "/" + MainApp.getDataFolder() + "/" + Uri.encode(accountName, "@"); // URL encoding is an 'easy fix' to overcome that NTFS and FAT32 don't allow ":" in file names, that can be in the accountName since 0.1.190B + //return getBaseStorePath().getAbsolutePath() + "/" + Uri.encode(accountName, "@"); + return getBaseStorePathString() + "/" + Uri.encode(accountName, "@"); } public static final String getDefaultSavePathFor(String accountName, OCFile file) { @@ -67,14 +94,17 @@ public class FileStorageUtils { } public static final String getTemporalPath(String accountName) { - File sdCard = Environment.getExternalStorageDirectory(); - return sdCard.getAbsolutePath() + "/" + MainApp.getDataFolder() + "/tmp/" + Uri.encode(accountName, "@"); + //File sdCard = Environment.getExternalStorageDirectory(); + //return sdCard.getAbsolutePath() + "/" + MainApp.getDataFolder() + "/tmp/" + Uri.encode(accountName, "@"); // URL encoding is an 'easy fix' to overcome that NTFS and FAT32 don't allow ":" in file names, that can be in the accountName since 0.1.190B + //return getBaseStorePath().getAbsolutePath() + "/tmp/" + Uri.encode(accountName, "@"); + return getBaseStorePathString() + "/tmp/" + Uri.encode(accountName, "@"); } @SuppressLint("NewApi") public static final long getUsableSpace(String accountName) { - File savePath = Environment.getExternalStorageDirectory(); + //File savePath = Environment.getExternalStorageDirectory(); + File savePath = getBaseStorePath(); if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.GINGERBREAD) { return savePath.getUsableSpace(); @@ -134,7 +164,7 @@ public class FileStorageUtils { file.setRemoteId(remote.getRemoteId()); return file; } - + /** * Creates and populates a new {@link RemoteFile} object with the data read from an {@link OCFile}. * @@ -152,9 +182,9 @@ public class FileStorageUtils { file.setRemoteId(ocFile.getRemoteId()); return file; } - + /** - * Sorts all filenames, regarding last user decision + * Sorts all filenames, regarding last user decision */ public static Vector sortFolder(Vector files){ switch (mSortOrder){ @@ -164,14 +194,14 @@ public class FileStorageUtils { case 1: files = FileStorageUtils.sortByDate(files); break; - case 2: + case 2: // mFiles = FileStorageUtils.sortBySize(mSortAscending); break; } - + return files; } - + /** * Sorts list by Date * @param files @@ -183,7 +213,7 @@ public class FileStorageUtils { } else { val = -1; } - + Collections.sort(files, new Comparator() { public int compare(OCFile o1, OCFile o2) { if (o1.isFolder() && o2.isFolder()) { @@ -202,7 +232,7 @@ public class FileStorageUtils { } } }); - + return files; } @@ -217,7 +247,7 @@ public class FileStorageUtils { // } else { // val = -1; // } -// +// // Collections.sort(files, new Comparator() { // public int compare(OCFile o1, OCFile o2) { // if (o1.isFolder() && o2.isFolder()) { @@ -236,7 +266,7 @@ public class FileStorageUtils { // } // } // }); -// +// // return files; // } @@ -255,7 +285,7 @@ public class FileStorageUtils { Collections.sort(files, new Comparator() { public int compare(OCFile o1, OCFile o2) { if (o1.isFolder() && o2.isFolder()) { - return val * o1.getRemotePath().toLowerCase().compareTo(o2.getRemotePath().toLowerCase()); + return val * new AlphanumComparator().compare(o1, o2); } else if (o1.isFolder()) { return -1; } else if (o2.isFolder()) { @@ -264,10 +294,10 @@ public class FileStorageUtils { return val * new AlphanumComparator().compare(o1, o2); } }); - + return files; } - + /** * Local Folder size * @param dir File