This commit is contained in:
kunfei 2023-02-21 11:55:37 +08:00
parent cd1fe2bdd3
commit 52980246e6
17 changed files with 25 additions and 28 deletions

View File

@ -104,8 +104,8 @@ interface BookDao {
@Query("select 1 from books where originName = :fileName")
fun hasFile(fileName: String): Boolean?
@Upsert
fun upsert(vararg book: Book)
@Insert(onConflict = OnConflictStrategy.REPLACE)
fun insert(vararg book: Book)
@Update
fun update(vararg book: Book)

View File

@ -1,9 +1,6 @@
package io.legado.app.data.dao
import androidx.room.Dao
import androidx.room.Delete
import androidx.room.Query
import androidx.room.Upsert
import androidx.room.*
import io.legado.app.data.entities.DictRule
import kotlinx.coroutines.flow.Flow
@ -23,8 +20,8 @@ interface DictRuleDao {
@Query("select * from dictRules where name = :name")
fun getByName(name: String): DictRule?
@Upsert
fun upsert(vararg dictRule: DictRule)
@Insert(onConflict = OnConflictStrategy.REPLACE)
fun insert(vararg dictRule: DictRule)
@Delete
fun delete(vararg dictRule: DictRule)

View File

@ -298,7 +298,7 @@ data class Book(
if (appDb.bookDao.has(bookUrl) == true) {
appDb.bookDao.update(this)
} else {
appDb.bookDao.upsert(this)
appDb.bookDao.insert(this)
}
}

View File

@ -121,7 +121,7 @@ object DefaultData {
}
fun importDefaultDictRules() {
appDb.dictRuleDao.upsert(*dictRules.toTypedArray())
appDb.dictRuleDao.insert(*dictRules.toTypedArray())
}
}

View File

@ -87,7 +87,7 @@ object ImportOldData {
private fun importOldBookshelf(json: String): Int {
val books = fromOldBooks(json)
appDb.bookDao.upsert(*books.toTypedArray())
appDb.bookDao.insert(*books.toTypedArray())
return books.size
}

View File

@ -75,7 +75,7 @@ object Restore {
.forEach { book ->
book.coverUrl = LocalBook.getCoverPath(book)
}
appDb.bookDao.upsert(*it.toTypedArray())
appDb.bookDao.insert(*it.toTypedArray())
}
fileToListT<Bookmark>(path, "bookmark.json")?.let {
appDb.bookmarkDao.insert(*it.toTypedArray())

View File

@ -184,7 +184,7 @@ object LocalBook {
if (book.isEpub) EpubFile.upBookInfo(book)
if (book.isUmd) UmdFile.upBookInfo(book)
if (book.isPdf) PdfFile.upBookInfo(book)
appDb.bookDao.upsert(book)
appDb.bookDao.insert(book)
} else {
//已有书籍说明是更新,删除原有目录
appDb.bookChapterDao.delByBook(bookUrl)

View File

@ -51,7 +51,7 @@ class ImportDictRuleViewModel(app: Application) : BaseViewModel(app) {
selectSource.add(allSources[index])
}
}
appDb.dictRuleDao.upsert(*selectSource.toTypedArray())
appDb.dictRuleDao.insert(*selectSource.toTypedArray())
}.onFinally {
finally.invoke()
}

View File

@ -195,7 +195,7 @@ class AudioPlayActivity :
launch {
withContext(IO) {
AudioPlay.book?.migrateTo(book, toc)
appDb.bookDao.upsert(book)
appDb.bookDao.insert(book)
}
startActivity<ReadBookActivity> {
putExtra("bookUrl", book.bookUrl)

View File

@ -79,7 +79,7 @@ class AudioPlayViewModel(application: Application) : BaseViewModel(application)
fun changeTo(source: BookSource, book: Book, toc: List<BookChapter>) {
execute {
AudioPlay.book?.migrateTo(book, toc)
appDb.bookDao.upsert(book)
appDb.bookDao.insert(book)
AudioPlay.book = book
AudioPlay.bookSource = source
appDb.bookChapterDao.insert(*toc.toTypedArray())

View File

@ -196,7 +196,7 @@ class BookInfoViewModel(application: Application) : BaseViewModel(application) {
if (oldBook.bookUrl == book.bookUrl) {
appDb.bookDao.update(book)
} else {
appDb.bookDao.upsert(book)
appDb.bookDao.insert(book)
BookHelp.updateCacheFolder(oldBook, book)
}
appDb.bookChapterDao.delByBook(oldBook.bookUrl)
@ -237,7 +237,7 @@ class BookInfoViewModel(application: Application) : BaseViewModel(application) {
bookData.value?.migrateTo(book, toc)
if (inBookshelf) {
book.removeType(BookType.updateError)
appDb.bookDao.upsert(book)
appDb.bookDao.insert(book)
appDb.bookChapterDao.insert(*toc.toTypedArray())
}
bookData.postValue(book)

View File

@ -59,7 +59,7 @@ class BookshelfManageViewModel(application: Application) : BaseViewModel(applica
}.getOrNull()?.let { toc ->
book.migrateTo(newBook, toc)
book.removeType(BookType.updateError)
appDb.bookDao.upsert(newBook)
appDb.bookDao.insert(newBook)
appDb.bookChapterDao.insert(*toc.toTypedArray())
}
}

View File

@ -833,7 +833,7 @@ class ReadBookActivity : BaseReadBookActivity(),
ReadAloud.stop(this)
launch {
ReadBook.book?.migrateTo(book, toc)
appDb.bookDao.upsert(book)
appDb.bookDao.insert(book)
}
startActivity<AudioPlayActivity> {
putExtra("bookUrl", book.bookUrl)

View File

@ -165,7 +165,7 @@ class ReadBookViewModel(application: Application) : BaseViewModel(application) {
if (oldBook.bookUrl == book.bookUrl) {
appDb.bookDao.update(book)
} else {
appDb.bookDao.upsert(book)
appDb.bookDao.insert(book)
BookHelp.updateCacheFolder(oldBook, book)
}
appDb.bookChapterDao.delByBook(oldBook.bookUrl)
@ -216,7 +216,7 @@ class ReadBookViewModel(application: Application) : BaseViewModel(application) {
ReadBook.upMsg(context.getString(R.string.loading))
ReadBook.book?.migrateTo(book, toc)
book.removeType(BookType.updateError)
appDb.bookDao.upsert(book)
appDb.bookDao.insert(book)
appDb.bookChapterDao.insert(*toc.toTypedArray())
ReadBook.resetData(book)
ReadBook.upMsg(null)

View File

@ -91,7 +91,7 @@ class DictRuleEditDialog() : BaseDialogFragment(R.layout.dialog_dict_rule_edit,
dictRule?.let {
appDb.dictRuleDao.delete(it)
}
appDb.dictRuleDao.upsert(newDictRule)
appDb.dictRuleDao.insert(newDictRule)
dictRule = newDictRule
}.onFinally {
onFinally.invoke()

View File

@ -11,7 +11,7 @@ class DictRuleViewModel(application: Application) : BaseViewModel(application) {
fun upsert(vararg dictRule: DictRule) {
execute {
appDb.dictRuleDao.upsert(*dictRule)
appDb.dictRuleDao.insert(*dictRule)
}
}
@ -27,7 +27,7 @@ class DictRuleViewModel(application: Application) : BaseViewModel(application) {
for ((index, rule) in rules.withIndex()) {
rule.sortNumber = index + 1
}
appDb.dictRuleDao.upsert(*rules.toTypedArray())
appDb.dictRuleDao.insert(*rules.toTypedArray())
}
}
@ -36,7 +36,7 @@ class DictRuleViewModel(application: Application) : BaseViewModel(application) {
dictRule.forEach {
it.enabled = true
}
appDb.dictRuleDao.upsert(*dictRule)
appDb.dictRuleDao.insert(*dictRule)
}
}
@ -45,7 +45,7 @@ class DictRuleViewModel(application: Application) : BaseViewModel(application) {
dictRule.forEach {
it.enabled = false
}
appDb.dictRuleDao.upsert(*dictRule)
appDb.dictRuleDao.insert(*dictRule)
}
}

View File

@ -133,7 +133,7 @@ class MainViewModel(application: Application) : BaseViewModel(application) {
appDb.bookDao.update(book)
} else {
upTocAdd(book.bookUrl)
appDb.bookDao.upsert(book)
appDb.bookDao.insert(book)
BookHelp.updateCacheFolder(oldBook, book)
}
appDb.bookChapterDao.delByBook(bookUrl)