Use transaction on restore to go brr. (#10375)
refactor: use transaction to go brr. This improve the restore speed on fresh db and non fresh db. Signed-off-by: KaiserBh <kaiserbh@proton.me> (cherry picked from commit b1067b942ef5c8d53e5ab838ef078789b9c0627a) # Conflicts: # app/src/main/java/eu/kanade/tachiyomi/data/backup/restore/restorers/MangaRestorer.kt
This commit is contained in:
parent
f24d50af44
commit
f6407805d3
@ -71,30 +71,32 @@ class MangaRestorer(
|
||||
backupManga: BackupManga,
|
||||
backupCategories: List<BackupCategory>,
|
||||
) {
|
||||
val dbManga = findExistingManga(backupManga)
|
||||
var manga = backupManga.getMangaImpl()
|
||||
// SY -->
|
||||
manga = EXHMigrations.migrateBackupEntry(manga)
|
||||
// SY <--
|
||||
val restoredManga = if (dbManga == null) {
|
||||
restoreNewManga(manga)
|
||||
} else {
|
||||
restoreExistingManga(manga, dbManga)
|
||||
}
|
||||
|
||||
restoreMangaDetails(
|
||||
manga = restoredManga,
|
||||
chapters = backupManga.chapters,
|
||||
categories = backupManga.categories,
|
||||
backupCategories = backupCategories,
|
||||
history = backupManga.history + backupManga.brokenHistory.map { it.toBackupHistory() },
|
||||
tracks = backupManga.tracking,
|
||||
handler.await(inTransaction = true) {
|
||||
val dbManga = findExistingManga(backupManga)
|
||||
var manga = backupManga.getMangaImpl()
|
||||
// SY -->
|
||||
mergedMangaReferences = backupManga.mergedMangaReferences,
|
||||
flatMetadata = backupManga.flatMetadata,
|
||||
customManga = backupManga.getCustomMangaInfo(),
|
||||
manga = EXHMigrations.migrateBackupEntry(manga)
|
||||
// SY <--
|
||||
)
|
||||
val restoredManga = if (dbManga == null) {
|
||||
restoreNewManga(manga)
|
||||
} else {
|
||||
restoreExistingManga(manga, dbManga)
|
||||
}
|
||||
|
||||
restoreMangaDetails(
|
||||
manga = restoredManga,
|
||||
chapters = backupManga.chapters,
|
||||
categories = backupManga.categories,
|
||||
backupCategories = backupCategories,
|
||||
history = backupManga.history + backupManga.brokenHistory.map { it.toBackupHistory() },
|
||||
tracks = backupManga.tracking,
|
||||
// SY -->
|
||||
mergedMangaReferences = backupManga.mergedMangaReferences,
|
||||
flatMetadata = backupManga.flatMetadata,
|
||||
customManga = backupManga.getCustomMangaInfo(),
|
||||
// SY <--
|
||||
)
|
||||
}
|
||||
}
|
||||
|
||||
private suspend fun findExistingManga(backupManga: BackupManga): Manga? {
|
||||
|
Loading…
x
Reference in New Issue
Block a user