SinMH: cleanup and extract lib (#12423)
* SinMH: cleanup, replace rate limiter and extract lib * revert rate limiter change * remove dependency from theme generator
This commit is contained in:
parent
56bb0a4ffe
commit
50e58499a9
|
@ -1,5 +1,6 @@
|
|||
package eu.kanade.tachiyomi.extension.zh.gufengmh
|
||||
|
||||
import eu.kanade.tachiyomi.multisrc.sinmh.ProgressiveParser
|
||||
import eu.kanade.tachiyomi.multisrc.sinmh.SinMH
|
||||
import eu.kanade.tachiyomi.network.GET
|
||||
import eu.kanade.tachiyomi.source.model.SChapter
|
||||
|
|
|
@ -0,0 +1,3 @@
|
|||
dependencies {
|
||||
implementation 'com.github.stevenyomi:unpacker:12a09e3c1a' // 1.1
|
||||
}
|
|
@ -1,5 +1,6 @@
|
|||
package eu.kanade.tachiyomi.extension.zh.wuqimanga
|
||||
|
||||
import com.github.stevenyomi.unpacker.Unpacker
|
||||
import eu.kanade.tachiyomi.multisrc.sinmh.SinMH
|
||||
import eu.kanade.tachiyomi.network.GET
|
||||
import eu.kanade.tachiyomi.source.model.Filter
|
||||
|
@ -59,20 +60,12 @@ class WuqiManga : SinMH("57漫画", "http://www.wuqimh.net") {
|
|||
|
||||
override fun pageListRequest(chapter: SChapter) = GET(baseUrl + chapter.url, headers)
|
||||
|
||||
// Reference: https://github.com/evanw/packer/blob/master/packer.js
|
||||
override fun pageListParse(document: Document): List<Page> {
|
||||
val script = document.selectFirst("body > script").html().let(::ProgressiveParser)
|
||||
val imageList = script.substringBetween(":[", "]").replace("\\", "")
|
||||
if (imageList.isEmpty()) return emptyList()
|
||||
script.consumeUntil("""};',""")
|
||||
val dictionary = script.substringBetween("'", "'").split('|')
|
||||
val size = dictionary.size
|
||||
val unpacked = Regex("""\b\w+\b""").replace(imageList) {
|
||||
with(it.value) {
|
||||
val key = parseRadix62()
|
||||
return@replace if (key < size) dictionary[key] else this
|
||||
}
|
||||
}.removeSurrounding("'").split("','")
|
||||
val script = document.selectFirst("body > script").html()
|
||||
val unpacked = Unpacker.unpack(script, ":[", "]")
|
||||
.ifEmpty { return emptyList() }
|
||||
.replace("\\", "")
|
||||
.removeSurrounding("\"").split("\",\"")
|
||||
val list = unpacked.filterNot { it.endsWith("/ManHuaKu/222.jpg") }.map { image ->
|
||||
if (image.startsWith("http")) image else imageHost + image
|
||||
}
|
||||
|
@ -131,15 +124,3 @@ class WuqiManga : SinMH("57漫画", "http://www.wuqimh.net") {
|
|||
private val sortNames = arrayOf("最新发布", "最近更新", "人气最旺", "评分最高")
|
||||
private val sortKeys = arrayOf("order-id", "order-addtime", "order-hits", "order-gold")
|
||||
}
|
||||
|
||||
private fun String.parseRadix62(): Int {
|
||||
var result = 0
|
||||
for (char in this) {
|
||||
result = result * 62 + when {
|
||||
char <= '9' -> char.code - '0'.code
|
||||
char >= 'a' -> char.code - 'a'.code + 10
|
||||
else -> char.code - 'A'.code + 36
|
||||
}
|
||||
}
|
||||
return result
|
||||
}
|
||||
|
|
|
@ -0,0 +1,11 @@
|
|||
package eu.kanade.tachiyomi.multisrc.sinmh
|
||||
|
||||
internal class ProgressiveParser(private val text: String) {
|
||||
private var startIndex = 0
|
||||
fun substringBetween(left: String, right: String): String = with(text) {
|
||||
val leftIndex = indexOf(left, startIndex) + left.length
|
||||
val rightIndex = indexOf(right, leftIndex)
|
||||
startIndex = rightIndex + right.length
|
||||
return substring(leftIndex, rightIndex)
|
||||
}
|
||||
}
|
|
@ -32,7 +32,7 @@ abstract class SinMH(
|
|||
) : ParsedHttpSource() {
|
||||
|
||||
override val baseUrl = _baseUrl
|
||||
protected open val mobileUrl = _baseUrl.replace("www", "m")
|
||||
protected open val mobileUrl = _baseUrl.replaceFirst("www.", "m.")
|
||||
override val supportsLatest = true
|
||||
|
||||
override val client = network.client.newBuilder().rateLimit(2).build()
|
||||
|
@ -206,20 +206,9 @@ abstract class SinMH(
|
|||
}
|
||||
}
|
||||
|
||||
protected class ProgressiveParser(private val text: String) {
|
||||
private var startIndex = 0
|
||||
fun consumeUntil(string: String) = with(text) { startIndex = indexOf(string, startIndex) + string.length }
|
||||
fun substringBetween(left: String, right: String): String = with(text) {
|
||||
val leftIndex = indexOf(left, startIndex) + left.length
|
||||
val rightIndex = indexOf(right, leftIndex)
|
||||
startIndex = rightIndex + right.length
|
||||
return substring(leftIndex, rightIndex)
|
||||
}
|
||||
}
|
||||
|
||||
// default parsing of ["...","..."]
|
||||
protected open fun parsePageImages(chapterImages: String): List<String> =
|
||||
if (chapterImages.length > 2) {
|
||||
if (chapterImages.length > 4) {
|
||||
chapterImages.run { substring(2, length - 2) }.replace("""\/""", "/").split("\",\"")
|
||||
} else emptyList() // []
|
||||
|
||||
|
@ -258,7 +247,7 @@ abstract class SinMH(
|
|||
if (categories.isNotEmpty()) {
|
||||
list = ArrayList(categories.size + 2)
|
||||
with(list) {
|
||||
add(Filter.Header("如果使用文本搜索,将会忽略分类筛选"))
|
||||
add(Filter.Header("分类筛选(搜索文本时无效)"))
|
||||
categories.forEach { add(it.toUriPartFilter()) }
|
||||
}
|
||||
} else {
|
||||
|
|
|
@ -6,7 +6,7 @@ import generator.ThemeSourceGenerator
|
|||
class SinMHGenerator : ThemeSourceGenerator {
|
||||
override val themeClass = "SinMH"
|
||||
override val themePkg = "sinmh"
|
||||
override val baseVersionCode = 5
|
||||
override val baseVersionCode = 6
|
||||
override val sources = listOf(
|
||||
SingleLang(
|
||||
name = "Gufeng Manhua", baseUrl = "https://www.gufengmh9.com", lang = "zh",
|
||||
|
|
Loading…
Reference in New Issue