|
|
@ -11,6 +11,7 @@ import io.legado.app.data.entities.BookChapter |
|
|
|
import io.legado.app.data.entities.ReplaceRule |
|
|
|
import io.legado.app.data.entities.ReplaceRule |
|
|
|
import io.legado.app.model.localBook.AnalyzeTxtFile |
|
|
|
import io.legado.app.model.localBook.AnalyzeTxtFile |
|
|
|
import io.legado.app.utils.* |
|
|
|
import io.legado.app.utils.* |
|
|
|
|
|
|
|
import kotlinx.coroutines.Dispatchers.IO |
|
|
|
import kotlinx.coroutines.Dispatchers.Main |
|
|
|
import kotlinx.coroutines.Dispatchers.Main |
|
|
|
import kotlinx.coroutines.withContext |
|
|
|
import kotlinx.coroutines.withContext |
|
|
|
import org.apache.commons.text.similarity.JaccardSimilarity |
|
|
|
import org.apache.commons.text.similarity.JaccardSimilarity |
|
|
@ -242,18 +243,9 @@ object BookHelp { |
|
|
|
private var replaceRules: List<ReplaceRule> = arrayListOf() |
|
|
|
private var replaceRules: List<ReplaceRule> = arrayListOf() |
|
|
|
|
|
|
|
|
|
|
|
@Synchronized |
|
|
|
@Synchronized |
|
|
|
fun upReplaceRules(name: String? = null, origin: String? = null) { |
|
|
|
suspend fun upReplaceRules() { |
|
|
|
if (name != null) { |
|
|
|
withContext(IO) { |
|
|
|
if (bookName != name || bookOrigin != origin) { |
|
|
|
synchronized(this) { |
|
|
|
replaceRules = if (origin.isNullOrEmpty()) { |
|
|
|
|
|
|
|
App.db.replaceRuleDao().findEnabledByScope(name) |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
App.db.replaceRuleDao().findEnabledByScope(name, origin) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
bookName = name |
|
|
|
|
|
|
|
bookOrigin = origin |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
val o = bookOrigin |
|
|
|
val o = bookOrigin |
|
|
|
bookName?.let { |
|
|
|
bookName?.let { |
|
|
|
replaceRules = if (o.isNullOrEmpty()) { |
|
|
|
replaceRules = if (o.isNullOrEmpty()) { |
|
|
@ -264,6 +256,7 @@ object BookHelp { |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
suspend fun disposeContent( |
|
|
|
suspend fun disposeContent( |
|
|
|
title: String, |
|
|
|
title: String, |
|
|
@ -274,7 +267,17 @@ object BookHelp { |
|
|
|
): String { |
|
|
|
): String { |
|
|
|
var c = content |
|
|
|
var c = content |
|
|
|
if (enableReplace) { |
|
|
|
if (enableReplace) { |
|
|
|
upReplaceRules(name, origin) |
|
|
|
synchronized(this) { |
|
|
|
|
|
|
|
if (bookName != name || bookOrigin != origin) { |
|
|
|
|
|
|
|
bookName = name |
|
|
|
|
|
|
|
bookOrigin = origin |
|
|
|
|
|
|
|
replaceRules = if (origin.isNullOrEmpty()) { |
|
|
|
|
|
|
|
App.db.replaceRuleDao().findEnabledByScope(name) |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
App.db.replaceRuleDao().findEnabledByScope(name, origin) |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
replaceRules.forEach { item -> |
|
|
|
replaceRules.forEach { item -> |
|
|
|
item.pattern.let { |
|
|
|
item.pattern.let { |
|
|
|
if (it.isNotEmpty()) { |
|
|
|
if (it.isNotEmpty()) { |
|
|
|