From 69ae60f68ab329b079c9a0a06846de5db76b940a Mon Sep 17 00:00:00 2001 From: Alessandro Jean Date: Mon, 31 May 2021 20:03:11 -0300 Subject: [PATCH] Fix Jsoup NPE error at Webtoons. (#7342) --- .../kanade/tachiyomi/multisrc/webtoons/Webtoons.kt | 13 ++++++------- .../multisrc/webtoons/WebtoonsGenerator.kt | 2 +- 2 files changed, 7 insertions(+), 8 deletions(-) diff --git a/multisrc/src/main/java/eu/kanade/tachiyomi/multisrc/webtoons/Webtoons.kt b/multisrc/src/main/java/eu/kanade/tachiyomi/multisrc/webtoons/Webtoons.kt index 272a4e15c..9ccaed842 100644 --- a/multisrc/src/main/java/eu/kanade/tachiyomi/multisrc/webtoons/Webtoons.kt +++ b/multisrc/src/main/java/eu/kanade/tachiyomi/multisrc/webtoons/Webtoons.kt @@ -148,7 +148,7 @@ open class Webtoons( val isThisLang = "$url".startsWith("$baseUrl/$langCode") if (! (couldBeWebtoonOrEpisode && isThisLang)) emptyResult - else{ + else { val potentialUrl = "${webtoonPath(url)}?title_no=$title_no" fetchMangaDetails(SManga.create().apply { this.url = potentialUrl }).map { it.url = potentialUrl @@ -158,7 +158,6 @@ open class Webtoons( } ?: emptyResult } - override fun searchMangaRequest(page: Int, query: String, filters: FilterList): Request { val url = "$baseUrl/$langCode/search?keyword=$query".toHttpUrlOrNull()?.newBuilder()!! val uriPart = (filters.find { it is SearchType } as? SearchType)?.toUriPart() ?: "" @@ -186,19 +185,19 @@ open class Webtoons( val infoElement = document.select("#_asideDetail") val manga = SManga.create() - manga.title = document.selectFirst("h1.subj").text() + manga.title = document.selectFirst("h1.subj, h3.subj").text() manga.author = detailElement.select(".author:nth-of-type(1)").first()?.ownText() manga.artist = detailElement.select(".author:nth-of-type(2)").first()?.ownText() ?: manga.author manga.genre = detailElement.select(".genre").joinToString(", ") { it.text() } manga.description = infoElement.select("p.summary").text() - manga.status = infoElement.select("p.day_info").text().orEmpty().let { parseStatus(it) } + manga.status = infoElement.select("p.day_info").firstOrNull()?.text().orEmpty().toStatus() manga.thumbnail_url = parseDetailsThumbnail(document) return manga } - private fun parseStatus(status: String) = when { - status.contains("UP") -> SManga.ONGOING - status.contains("COMPLETED") -> SManga.COMPLETED + private fun String.toStatus(): Int = when { + contains("UP") -> SManga.ONGOING + contains("COMPLETED") -> SManga.COMPLETED else -> SManga.UNKNOWN } diff --git a/multisrc/src/main/java/eu/kanade/tachiyomi/multisrc/webtoons/WebtoonsGenerator.kt b/multisrc/src/main/java/eu/kanade/tachiyomi/multisrc/webtoons/WebtoonsGenerator.kt index 9aaab09d5..aeacccf34 100644 --- a/multisrc/src/main/java/eu/kanade/tachiyomi/multisrc/webtoons/WebtoonsGenerator.kt +++ b/multisrc/src/main/java/eu/kanade/tachiyomi/multisrc/webtoons/WebtoonsGenerator.kt @@ -13,7 +13,7 @@ class WebtoonsGenerator : ThemeSourceGenerator { override val baseVersionCode: Int = 1 override val sources = listOf( - MultiLang("Webtoons.com", "https://www.webtoons.com", listOf("en", "fr", "es", "id", "th", "zh"), className = "WebtoonsFactory", pkgName = "webtoons", overrideVersionCode = 28), + MultiLang("Webtoons.com", "https://www.webtoons.com", listOf("en", "fr", "es", "id", "th", "zh"), className = "WebtoonsFactory", pkgName = "webtoons", overrideVersionCode = 29), SingleLang("Dongman Manhua", "https://www.dongmanmanhua.cn", "zh") )