update Commons with some OTG improvements

This commit is contained in:
tibbi 2018-02-14 23:30:38 +01:00
parent 8ef70a8fe5
commit c340b9860e
6 changed files with 23 additions and 17 deletions

View file

@ -45,7 +45,7 @@ ext {
}
dependencies {
implementation 'com.simplemobiletools:commons:3.11.15'
implementation 'com.simplemobiletools:commons:3.11.35'
implementation files('../libs/RootTools.jar')

View file

@ -202,7 +202,7 @@ class MainActivity : SimpleActivity() {
val file = File(path)
if (file.exists() && !file.isDirectory) {
newPath = file.parent
} else if (!file.exists()) {
} else if (!file.exists() && !isPathOnOTG(newPath)) {
newPath = internalStoragePath
}

View file

@ -175,10 +175,10 @@ class ItemsAdapter(activity: SimpleActivity, var fileDirItems: MutableList<FileD
}
private fun copyMoveTo(isCopyOperation: Boolean) {
val files = ArrayList<File>()
selectedPositions.forEach { files.add(File(fileDirItems[it].path)) }
val files = ArrayList<FileDirItem>()
selectedPositions.forEach { files.add(FileDirItem(fileDirItems[it].path, fileDirItems[it].name)) }
val source = if (files[0].isFile) files[0].parent else files[0].absolutePath
val source = if (!files[0].isDirectory) File(files[0].path).parent else files[0].path
FilePickerDialog(activity, source, false, activity.config.shouldShowHidden, true) {
if (activity.isPathOnRoot(source)) {
copyRootItems(files, it)
@ -191,12 +191,12 @@ class ItemsAdapter(activity: SimpleActivity, var fileDirItems: MutableList<FileD
}
}
private fun copyRootItems(files: ArrayList<File>, destinationPath: String) {
private fun copyRootItems(files: ArrayList<FileDirItem>, destinationPath: String) {
activity.toast(R.string.copying)
Thread {
var fileCnt = files.count()
files.forEach {
if (RootTools.copyFile(it.absolutePath, destinationPath, false, true)) {
if (RootTools.copyFile(it.path, destinationPath, false, true)) {
fileCnt--
}
}
@ -354,14 +354,14 @@ class ItemsAdapter(activity: SimpleActivity, var fileDirItems: MutableList<FileD
return
}
val files = ArrayList<File>(selectedPositions.size)
val files = ArrayList<FileDirItem>(selectedPositions.size)
val removeFiles = ArrayList<FileDirItem>(selectedPositions.size)
val SAFFile = File(fileDirItems[selectedPositions.first()].path)
activity.handleSAFDialog(SAFFile) {
selectedPositions.sortedDescending().forEach {
val file = fileDirItems[it]
files.add(File(file.path))
files.add(FileDirItem(file.path, file.name))
removeFiles.add(file)
activity.config.removeFavorite(file.path)
}

View file

@ -2,8 +2,9 @@ package com.simplemobiletools.filemanager.extensions
import android.content.Context
import com.simplemobiletools.commons.extensions.hasExternalSDCard
import com.simplemobiletools.commons.extensions.isPathOnOTG
import com.simplemobiletools.filemanager.helpers.Config
val Context.config: Config get() = Config.newInstance(applicationContext)
fun Context.isPathOnRoot(path: String) = !(path.startsWith(config.internalStoragePath) || (hasExternalSDCard() && path.startsWith(config.sdCardPath)))
fun Context.isPathOnRoot(path: String) = !(path.startsWith(config.internalStoragePath) || isPathOnOTG(path) || (hasExternalSDCard() && path.startsWith(config.sdCardPath)))

View file

@ -10,6 +10,7 @@ import android.view.ViewGroup
import com.simplemobiletools.commons.activities.BaseSimpleActivity
import com.simplemobiletools.commons.dialogs.StoragePickerDialog
import com.simplemobiletools.commons.extensions.*
import com.simplemobiletools.commons.helpers.OTG_PATH
import com.simplemobiletools.commons.helpers.SORT_BY_SIZE
import com.simplemobiletools.commons.models.FileDirItem
import com.simplemobiletools.commons.views.Breadcrumbs
@ -114,7 +115,7 @@ class ItemsFragment : Fragment(), ItemOperationsListener, Breadcrumbs.Breadcrumb
return
}
var realPath = path.trimEnd('/')
var realPath = if (path == OTG_PATH) OTG_PATH else path.trimEnd('/')
if (realPath.isEmpty()) {
realPath = "/"
}
@ -174,7 +175,11 @@ class ItemsFragment : Fragment(), ItemOperationsListener, Breadcrumbs.Breadcrumb
skipItemUpdating = false
Thread {
if (activity?.isActivityDestroyed() == false) {
if (!context!!.config.enableRootAccess || !context!!.isPathOnRoot(path)) {
if (context!!.isPathOnOTG(path)) {
context!!.getOTGItems(path) {
callback(path, it)
}
} else if (!context!!.config.enableRootAccess || !context!!.isPathOnRoot(path)) {
getRegularItemsOf(path, callback)
} else {
RootHelpers().getFiles(activity as SimpleActivity, path, callback)
@ -281,7 +286,7 @@ class ItemsFragment : Fragment(), ItemOperationsListener, Breadcrumbs.Breadcrumb
override fun breadcrumbClicked(id: Int) {
if (id == 0) {
StoragePickerDialog(activity!!, currentPath) {
StoragePickerDialog(activity as SimpleActivity, currentPath) {
openPath(it)
}
} else {
@ -294,9 +299,9 @@ class ItemsFragment : Fragment(), ItemOperationsListener, Breadcrumbs.Breadcrumb
openPath(currentPath)
}
override fun deleteFiles(files: ArrayList<File>) {
override fun deleteFiles(files: ArrayList<FileDirItem>) {
val hasFolder = files.any { it.isDirectory }
if (context!!.isPathOnRoot(files.firstOrNull()?.absolutePath ?: context!!.config.internalStoragePath)) {
if (context!!.isPathOnRoot(files.firstOrNull()?.path ?: context!!.config.internalStoragePath)) {
files.forEach {
RootTools.deleteFileOrDirectory(it.path, false)
}

View file

@ -1,12 +1,12 @@
package com.simplemobiletools.filemanager.interfaces
import java.io.File
import com.simplemobiletools.commons.models.FileDirItem
import java.util.*
interface ItemOperationsListener {
fun refreshItems()
fun deleteFiles(files: ArrayList<File>)
fun deleteFiles(files: ArrayList<FileDirItem>)
fun selectedPaths(paths: ArrayList<String>)
}