From 9a09338977d1561a847f6436d51450b1e25c1183 Mon Sep 17 00:00:00 2001 From: Jay Date: Wed, 5 Feb 2020 22:54:00 -0800 Subject: [PATCH] Fixed cache missing items sometimes --- .../tachiyomi/data/download/DownloadCache.kt | 26 +++++++------------ .../data/library/LibraryUpdateService.kt | 11 -------- .../data/library/LibraryUpdateServiceTest.kt | 2 +- 3 files changed, 11 insertions(+), 28 deletions(-) diff --git a/app/src/main/java/eu/kanade/tachiyomi/data/download/DownloadCache.kt b/app/src/main/java/eu/kanade/tachiyomi/data/download/DownloadCache.kt index 075c677c61..a28e6b581a 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/data/download/DownloadCache.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/data/download/DownloadCache.kt @@ -44,10 +44,6 @@ class DownloadCache( */ private var lastRenew = 0L - /** - * The root directory for downloads. - */ - //private var rootDir = RootDirectory(getDirectoryFromPreference()) private var mangaFiles: MutableMap> = mutableMapOf() init { @@ -55,7 +51,6 @@ class DownloadCache( .skip(1) .subscribe { lastRenew = 0L // invalidate cache - //rootDir = RootDirectory(getDirectoryFromPreference()) } } @@ -121,14 +116,14 @@ class DownloadCache( .mapNotNullKeys { entry -> onlineSources.find { provider.getSourceDirName(it) == entry.key }?.id } - //Timber.i("Sources: ${sourceDirs.map { it.value.dir.filePath }.joinToString(", ")}") - - //rootDir.files = sourceDirs val db:DatabaseHelper by injectLazy() - val mangas = db.getMangas().executeAsBlocking() + val mangas = db.getMangas().executeAsBlocking().groupBy { it.source } sourceDirs.forEach { sourceValue -> + val sourceMangasRaw = mangas[sourceValue.key]?.toMutableSet() ?: return@forEach + val sourceMangas = arrayOf(sourceMangasRaw.filter { it.favorite }, sourceMangasRaw + .filterNot { it.favorite }) val sourceDir = sourceValue.value val mangaDirs = sourceDir.dir.listFiles() .orEmpty() @@ -136,25 +131,24 @@ class DownloadCache( val name = it.name ?: return@mapNotNull null name to MangaDirectory(it) }.toMap() -// Timber.i("${sourceDir.dir.name}: ${mangaDirs.map { -// it.key + " :: " + it.value.dir.filePath }.joinToString(", ")}") - mangaDirs.values.forEach { mangaDir -> val chapterDirs = mangaDir.dir.listFiles() .orEmpty() .mapNotNull { it.name } .toHashSet() -// Timber.i("${mangaDir.dir.name}: ${chapterDirs.joinToString(", ")}") mangaDir.files = chapterDirs } val trueMangaDirs = mangaDirs.mapNotNull { mangaDir -> - val manga = mangas.find { DiskUtil.buildValidFilename(it.originalTitle()) == - mangaDir.key && it.source == sourceValue.key } + val manga = sourceMangas.firstOrNull()?.find { DiskUtil.buildValidFilename( + it.originalTitle()).toLowerCase() == mangaDir.key + .toLowerCase() && it.source == sourceValue.key } ?: + sourceMangas.lastOrNull()?.find { DiskUtil.buildValidFilename( + it.originalTitle()).toLowerCase() == mangaDir.key + .toLowerCase() && it.source == sourceValue.key } val id = manga?.id ?: return@mapNotNull null id to mangaDir.value.files }.toMap() - //sourceDir.files = trueMangaDirs mangaFiles.putAll(trueMangaDirs) } } diff --git a/app/src/main/java/eu/kanade/tachiyomi/data/library/LibraryUpdateService.kt b/app/src/main/java/eu/kanade/tachiyomi/data/library/LibraryUpdateService.kt index ca99bf873a..7b01ebcec9 100644 --- a/app/src/main/java/eu/kanade/tachiyomi/data/library/LibraryUpdateService.kt +++ b/app/src/main/java/eu/kanade/tachiyomi/data/library/LibraryUpdateService.kt @@ -379,17 +379,6 @@ class LibraryUpdateService( cancelProgressNotification() } - private fun cleanupDownloads() { - val mangaList = db.getMangas().executeAsBlocking() - var foldersCleared = 0 - for (manga in mangaList) { - val chapterList = db.getChapters(manga).executeAsBlocking() - val source = sourceManager.getOrStub(manga.source) - foldersCleared += downloadManager.cleanupChapters(chapterList, manga, source) - } - - } - fun downloadChapters(manga: Manga, chapters: List) { // we need to get the chapters from the db so we have chapter ids val mangaChapters = db.getChapters(manga).executeAsBlocking() diff --git a/app/src/test/java/eu/kanade/tachiyomi/data/library/LibraryUpdateServiceTest.kt b/app/src/test/java/eu/kanade/tachiyomi/data/library/LibraryUpdateServiceTest.kt index bfd87f5af0..8f41a6697d 100644 --- a/app/src/test/java/eu/kanade/tachiyomi/data/library/LibraryUpdateServiceTest.kt +++ b/app/src/test/java/eu/kanade/tachiyomi/data/library/LibraryUpdateServiceTest.kt @@ -97,7 +97,7 @@ class LibraryUpdateServiceTest { val intent = Intent() val target = LibraryUpdateService.Target.CHAPTERS - service.updateChapterList(service.getMangaToUpdate(intent, target)).subscribe() + service.updateDetails(favManga).subscribe() // There are 3 network attempts and 2 insertions (1 request failed) assertThat(service.db.getChapters(favManga[0]).executeAsBlocking()).hasSize(2)