From fd90be8776399aafcb289c8d8a19c4c5d393481f Mon Sep 17 00:00:00 2001 From: Torsten Grote Date: Mon, 12 Feb 2024 10:36:51 -0300 Subject: [PATCH] Don't include empty dirs in media backup Otherwise, the directories would be treated as small files and we would try to backup their content which would fail. --- .../org/calyxos/backup/storage/backup/Backup.kt | 3 --- .../calyxos/backup/storage/scanner/MediaScanner.kt | 13 ++++++++----- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/storage/lib/src/main/java/org/calyxos/backup/storage/backup/Backup.kt b/storage/lib/src/main/java/org/calyxos/backup/storage/backup/Backup.kt index e08d5388..d1451f2b 100644 --- a/storage/lib/src/main/java/org/calyxos/backup/storage/backup/Backup.kt +++ b/storage/lib/src/main/java/org/calyxos/backup/storage/backup/Backup.kt @@ -22,7 +22,6 @@ import org.calyxos.backup.storage.scanner.FileScannerResult import java.io.IOException import java.security.GeneralSecurityException import kotlin.time.Duration -import kotlin.time.ExperimentalTime internal class BackupResult( val chunkIds: Set, @@ -86,7 +85,6 @@ internal class Backup( ) @Throws(IOException::class, GeneralSecurityException::class) - @OptIn(ExperimentalTime::class) suspend fun runBackup(backupObserver: BackupObserver?) { backupObserver?.onStartScanning() var duration: Duration? = null @@ -121,7 +119,6 @@ internal class Backup( } @Throws(IOException::class, GeneralSecurityException::class) - @OptIn(ExperimentalTime::class) private suspend fun backupFiles( filesResult: FileScannerResult, availableChunkIds: HashSet, diff --git a/storage/lib/src/main/java/org/calyxos/backup/storage/scanner/MediaScanner.kt b/storage/lib/src/main/java/org/calyxos/backup/storage/scanner/MediaScanner.kt index 0e0c3526..c2ece36e 100644 --- a/storage/lib/src/main/java/org/calyxos/backup/storage/scanner/MediaScanner.kt +++ b/storage/lib/src/main/java/org/calyxos/backup/storage/scanner/MediaScanner.kt @@ -12,6 +12,7 @@ import android.database.Cursor import android.net.Uri import android.os.Bundle import android.os.Environment +import android.provider.DocumentsContract.Document.MIME_TYPE_DIR import android.provider.MediaStore import android.provider.MediaStore.MediaColumns.IS_DOWNLOAD import android.util.Log @@ -57,15 +58,18 @@ public class MediaScanner(context: Context) { internal fun scanMediaUri(uri: Uri, extraQuery: String? = null): List { val extras = Bundle().apply { - val query = StringBuilder() + val query = StringBuilder().apply { + // don't include directories (if they are non-empty they will be in implicitly) + append("${MediaStore.MediaColumns.MIME_TYPE}!='$MIME_TYPE_DIR'") + } if (uri != MediaType.Downloads.contentUri) { - query.append("$IS_DOWNLOAD=0") + query.append(" AND $IS_DOWNLOAD=0") } extraQuery?.let { - if (query.isNotEmpty()) query.append(" AND ") + query.append(" AND ") query.append(it) } - if (query.isNotEmpty()) putString(QUERY_ARG_SQL_SELECTION, query.toString()) + putString(QUERY_ARG_SQL_SELECTION, query.toString()) } val cursor = contentResolver.query(uri, PROJECTION, extras, null) return ArrayList(cursor?.count ?: 0).apply { @@ -106,7 +110,6 @@ public class MediaScanner(context: Context) { } private fun getRealSize(mediaFile: MediaFile): Long { - @Suppress("DEPRECATION") val extDir = Environment.getExternalStorageDirectory() val path = "$extDir/${mediaFile.dirPath}/${mediaFile.fileName}" return try {