From 3272398f49f0287fe582293056c7ac6e76a2ef77 Mon Sep 17 00:00:00 2001 From: tibbi Date: Sat, 16 Feb 2019 16:20:44 +0100 Subject: [PATCH] do not always check invalid db files, only in 20% --- .../gallery/pro/extensions/Context.kt | 26 +++++++++++-------- 1 file changed, 15 insertions(+), 11 deletions(-) diff --git a/app/src/main/kotlin/com/simplemobiletools/gallery/pro/extensions/Context.kt b/app/src/main/kotlin/com/simplemobiletools/gallery/pro/extensions/Context.kt index df67d2b61..45c3eeb64 100644 --- a/app/src/main/kotlin/com/simplemobiletools/gallery/pro/extensions/Context.kt +++ b/app/src/main/kotlin/com/simplemobiletools/gallery/pro/extensions/Context.kt @@ -42,6 +42,7 @@ import java.util.HashSet import java.util.LinkedHashSet import kotlin.Comparator import kotlin.collections.ArrayList +import kotlin.random.Random val Context.portrait get() = resources.configuration.orientation == Configuration.ORIENTATION_PORTRAIT val Context.audioManager get() = getSystemService(Context.AUDIO_SERVICE) as AudioManager @@ -564,20 +565,23 @@ fun Context.getCachedMedia(path: String, getVideosOnly: Boolean = false, getImag val grouped = mediaFetcher.groupMedia(media, pathToUse) callback(grouped.clone() as ArrayList) - val mediaToDelete = ArrayList() - media.filter { !File(it.path).exists() }.forEach { - if (it.path.startsWith(recycleBinPath)) { - deleteDBPath(mediumDao, it.path) - } else { - mediaToDelete.add(it) + val value = Random.nextInt(5) + if (value == 1) { + val mediaToDelete = ArrayList() + media.filter { !File(it.path).exists() }.forEach { + if (it.path.startsWith(recycleBinPath)) { + deleteDBPath(mediumDao, it.path) + } else { + mediaToDelete.add(it) + } } - } - try { - if (mediaToDelete.isNotEmpty()) { - mediumDao.deleteMedia(*mediaToDelete.toTypedArray()) + try { + if (mediaToDelete.isNotEmpty()) { + mediumDao.deleteMedia(*mediaToDelete.toTypedArray()) + } + } catch (ignored: Exception) { } - } catch (ignored: Exception) { } }.start() }