diff --git a/gradle.properties b/gradle.properties index ced6c8f..9fa7fe8 100644 --- a/gradle.properties +++ b/gradle.properties @@ -21,4 +21,4 @@ kotlin.code.style=official # resources declared in the library itself and none from the library's dependencies, # thereby reducing the size of the R class for that library android.nonTransitiveRClass=true -#org.gradle.java.home=/Applications/Android Studio.app/Contents/jbr/Contents/Home \ No newline at end of file +org.gradle.java.home=/Applications/Android Studio.app/Contents/jbr/Contents/Home \ No newline at end of file diff --git a/trashbin/src/main/java/com/amaze/trashbin/TrashBin.kt b/trashbin/src/main/java/com/amaze/trashbin/TrashBin.kt index 4e5392f..72e6221 100644 --- a/trashbin/src/main/java/com/amaze/trashbin/TrashBin.kt +++ b/trashbin/src/main/java/com/amaze/trashbin/TrashBin.kt @@ -22,6 +22,7 @@ import com.google.gson.Gson import com.google.gson.GsonBuilder import com.google.gson.reflect.TypeToken import com.google.gson.stream.JsonReader +import kotlinx.coroutines.Dispatchers import kotlinx.coroutines.GlobalScope import kotlinx.coroutines.launch import java.io.FileReader @@ -39,11 +40,12 @@ typealias ListTrashBinFilesCallback = (parentTrashBinPath: String) -> List= trashConfig.getCleanupIntervalHours()) { - - GlobalScope.launch { + if (trashConfig.getCleanupIntervalHours() != -1 && + hours >= trashConfig.getCleanupIntervalHours() && + doTriggerCleanup && deletePermanentlySuperCallback != null + ) { + GlobalScope.launch(Dispatchers.IO) { triggerCleanup { - - sharedPreferences.edit().putLong("com.amaze.trashbin.lastCleanup", currentTime).apply() - + sharedPreferences.edit().putLong( + "com.amaze.trashbin.lastCleanup", + currentTime + ).apply() false } } } - } fun deletePermanently( diff --git a/trashbin/src/main/java/com/amaze/trashbin/TrashBinConfig.kt b/trashbin/src/main/java/com/amaze/trashbin/TrashBinConfig.kt index 925e46a..4d4fd51 100644 --- a/trashbin/src/main/java/com/amaze/trashbin/TrashBinConfig.kt +++ b/trashbin/src/main/java/com/amaze/trashbin/TrashBinConfig.kt @@ -29,16 +29,16 @@ data class TrashBinConfig( val retentionDays: Int, val retentionBytes: Long, val retentionNumOfFiles: Int, + val cleanupHours: Int = -1, val deleteRogueFiles: Boolean, - val triggerCleanupAutomatically: Boolean, - private val cleanupDays: Int, - private val cleanupHours: Int + val triggerCleanupAutomatically: Boolean ) { companion object { const val RETENTION_DAYS_INFINITE = -1 const val RETENTION_BYTES_INFINITE = -1L const val RETENTION_NUM_OF_FILES = -1 + const val INTERVAL_CLEANUP_HOURS = 1 const val TRASH_BIN_CAPACITY_INVALID = -1 const val TRASH_BIN_DIR = "TrashBinFiles" const val TRASH_BIN_META_FILE = "metadata.json" @@ -69,6 +69,6 @@ data class TrashBinConfig( } fun getCleanupIntervalHours(): Int { - return cleanupDays * 24 + cleanupHours; + return cleanupHours } }