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:
KaiserBh 2024-01-12 10:22:46 +11:00 committed by Jobobby04
parent f24d50af44
commit f6407805d3

View File

@ -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? {