From eef6f38cd7c63e5aef8ea7111699ec52b1a699cf Mon Sep 17 00:00:00 2001 From: bapeey <90949336+bapeey@users.noreply.github.com> Date: Fri, 27 Sep 2024 08:23:50 -0500 Subject: [PATCH] AsuraScans: Prevent slug map break (#5254) * prevent slugmap break * reset slug map --- src/en/asurascans/build.gradle | 2 +- .../extension/en/asurascans/AsuraScans.kt | 21 ++++++++++++------- 2 files changed, 15 insertions(+), 8 deletions(-) diff --git a/src/en/asurascans/build.gradle b/src/en/asurascans/build.gradle index 3b97ab8e4..871119a47 100644 --- a/src/en/asurascans/build.gradle +++ b/src/en/asurascans/build.gradle @@ -1,7 +1,7 @@ ext { extName = 'Asura Scans' extClass = '.AsuraScans' - extVersionCode = 40 + extVersionCode = 41 } apply from: "$rootDir/common.gradle" diff --git a/src/en/asurascans/src/eu/kanade/tachiyomi/extension/en/asurascans/AsuraScans.kt b/src/en/asurascans/src/eu/kanade/tachiyomi/extension/en/asurascans/AsuraScans.kt index cdd495aed..f6069d74b 100644 --- a/src/en/asurascans/src/eu/kanade/tachiyomi/extension/en/asurascans/AsuraScans.kt +++ b/src/en/asurascans/src/eu/kanade/tachiyomi/extension/en/asurascans/AsuraScans.kt @@ -57,6 +57,9 @@ class AsuraScans : ParsedHttpSource(), ConfigurableSource { if (contains("pref_permanent_manga_url_2_en")) { edit().remove("pref_permanent_manga_url_2_en").apply() } + if (contains("pref_slug_map")) { + edit().remove("pref_slug_map").apply() + } } } @@ -192,9 +195,11 @@ class AsuraScans : ParsedHttpSource(), ConfigurableSource { override fun mangaDetailsParse(response: Response): SManga { if (preferences.dynamicUrl()) { val url = response.request.url.toString() - val newSlug = url.substringAfter("/series/").substringBefore("/") - val absSlug = newSlug.substringBeforeLast("-") - preferences.slugMap = preferences.slugMap.apply { put(absSlug, newSlug) } + val newSlug = url.substringAfter("/series/", "").substringBefore("/") + if (newSlug.isNotEmpty()) { + val absSlug = newSlug.substringBeforeLast("-") + preferences.slugMap = preferences.slugMap.apply { put(absSlug, newSlug) } + } } return super.mangaDetailsParse(response) } @@ -225,9 +230,11 @@ class AsuraScans : ParsedHttpSource(), ConfigurableSource { override fun chapterListParse(response: Response): List { if (preferences.dynamicUrl()) { val url = response.request.url.toString() - val newSlug = url.substringAfter("/series/").substringBefore("/") - val absSlug = newSlug.substringBeforeLast("-") - preferences.slugMap = preferences.slugMap.apply { put(absSlug, newSlug) } + val newSlug = url.substringAfter("/series/", "").substringBefore("/") + if (newSlug.isNotEmpty()) { + val absSlug = newSlug.substringBeforeLast("-") + preferences.slugMap = preferences.slugMap.apply { put(absSlug, newSlug) } + } } return super.chapterListParse(response) } @@ -308,7 +315,7 @@ class AsuraScans : ParsedHttpSource(), ConfigurableSource { private val CLEAN_DATE_REGEX = """(\d+)(st|nd|rd|th)""".toRegex() private val OLD_FORMAT_MANGA_REGEX = """^/manga/(\d+-)?([^/]+)/?$""".toRegex() private val OLD_FORMAT_CHAPTER_REGEX = """^/(\d+-)?[^/]*-chapter-\d+(-\d+)*/?$""".toRegex() - private const val PREF_SLUG_MAP = "pref_slug_map" + private const val PREF_SLUG_MAP = "pref_slug_map_2" private const val PREF_DYNAMIC_URL = "pref_dynamic_url" } }