Update source
[AnimeH] Broken source close #1301 [SussyScan] fix close #1298 close #1287 close #1282 close #1273 close #1267 close #1268 close #1260 close #1234 [Manhwa18] fix src close #1297 close #1290 close #1288 [KomikCast] close #1284 close #1283 close #1272 close #1270 close #1265 [Birdtoon] close #1276 [Komiktap] close #1275 [SadScans] close #1274 [Flamecomics] reverse chapter fix close #1266 [Kiryuu] fix url close #1258 [MangaTime] Broken close #1228 [Dexhentai] fix close #1226master
parent
336f64712d
commit
6b1fb90584
@ -1 +1 @@
|
|||||||
total: 1154
|
total: 1172
|
||||||
@ -1,153 +1,152 @@
|
|||||||
package org.koitharu.kotatsu.parsers.site.en
|
package org.koitharu.kotatsu.parsers.site.en
|
||||||
|
|
||||||
import androidx.collection.arraySetOf
|
|
||||||
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
import org.koitharu.kotatsu.parsers.PagedMangaParser
|
import org.koitharu.kotatsu.parsers.PagedMangaParser
|
||||||
import org.koitharu.kotatsu.parsers.config.ConfigKey
|
import org.koitharu.kotatsu.parsers.config.ConfigKey
|
||||||
import org.koitharu.kotatsu.parsers.network.UserAgents
|
|
||||||
import org.koitharu.kotatsu.parsers.model.*
|
import org.koitharu.kotatsu.parsers.model.*
|
||||||
import org.koitharu.kotatsu.parsers.util.*
|
import org.koitharu.kotatsu.parsers.util.*
|
||||||
import java.text.SimpleDateFormat
|
|
||||||
import java.util.*
|
import java.util.*
|
||||||
|
|
||||||
@MangaSourceParser("MYCOMICLIST", "MyComicList", "en", ContentType.COMICS)
|
@MangaSourceParser("MYCOMICLIST", "MyComicList", "en", ContentType.COMICS)
|
||||||
internal class MyComicList(context: MangaLoaderContext) : PagedMangaParser(context, MangaParserSource.MYCOMICLIST, 24) {
|
internal class MyComicList(context: MangaLoaderContext) : PagedMangaParser(context, MangaParserSource.MYCOMICLIST, 24) {
|
||||||
|
|
||||||
override val configKeyDomain = ConfigKey.Domain("mycomiclist.org")
|
override val configKeyDomain = ConfigKey.Domain("mycomiclist.org")
|
||||||
|
|
||||||
override fun onCreateConfig(keys: MutableCollection<ConfigKey<*>>) {
|
override fun onCreateConfig(keys: MutableCollection<ConfigKey<*>>) {
|
||||||
super.onCreateConfig(keys)
|
super.onCreateConfig(keys)
|
||||||
keys.add(userAgentKey)
|
keys.add(userAgentKey)
|
||||||
}
|
}
|
||||||
|
|
||||||
override val availableSortOrders: Set<SortOrder> = EnumSet.of(
|
override val availableSortOrders: Set<SortOrder> = EnumSet.of(
|
||||||
SortOrder.UPDATED,
|
SortOrder.UPDATED,
|
||||||
SortOrder.POPULARITY,
|
SortOrder.POPULARITY,
|
||||||
SortOrder.NEWEST,
|
SortOrder.NEWEST,
|
||||||
SortOrder.ALPHABETICAL
|
SortOrder.ALPHABETICAL,
|
||||||
)
|
)
|
||||||
|
|
||||||
override val filterCapabilities: MangaListFilterCapabilities
|
override val filterCapabilities: MangaListFilterCapabilities
|
||||||
get() = MangaListFilterCapabilities(
|
get() = MangaListFilterCapabilities(
|
||||||
isSearchSupported = true,
|
isSearchSupported = true,
|
||||||
)
|
)
|
||||||
|
|
||||||
override suspend fun getFilterOptions() = MangaListFilterOptions(
|
override suspend fun getFilterOptions() = MangaListFilterOptions(
|
||||||
availableTags = fetchAvailableTags(),
|
availableTags = fetchAvailableTags(),
|
||||||
availableStates = EnumSet.of(MangaState.ONGOING, MangaState.FINISHED)
|
availableStates = EnumSet.of(MangaState.ONGOING, MangaState.FINISHED),
|
||||||
)
|
)
|
||||||
|
|
||||||
override suspend fun getListPage(page: Int, order: SortOrder, filter: MangaListFilter): List<Manga> {
|
override suspend fun getListPage(page: Int, order: SortOrder, filter: MangaListFilter): List<Manga> {
|
||||||
val url = buildString {
|
val url = buildString {
|
||||||
append("https://")
|
append("https://")
|
||||||
append(domain)
|
append(domain)
|
||||||
when {
|
when {
|
||||||
!filter.query.isNullOrEmpty() -> {
|
!filter.query.isNullOrEmpty() -> {
|
||||||
append("/comic-search?key=")
|
append("/comic-search?key=")
|
||||||
append(filter.query.urlEncoded())
|
append(filter.query.urlEncoded())
|
||||||
}
|
}
|
||||||
filter.tags.isNotEmpty() -> {
|
|
||||||
append("/")
|
filter.tags.isNotEmpty() -> {
|
||||||
append(filter.tags.first().key)
|
append("/")
|
||||||
append("-comic")
|
append(filter.tags.first().key)
|
||||||
}
|
append("-comic")
|
||||||
else -> when (order) {
|
}
|
||||||
SortOrder.UPDATED -> append("/hot-comic")
|
|
||||||
SortOrder.POPULARITY -> append("/popular-comic")
|
else -> when (order) {
|
||||||
SortOrder.NEWEST -> append("/new-comic")
|
SortOrder.UPDATED -> append("/hot-comic")
|
||||||
else -> append("/ongoing-comic")
|
SortOrder.POPULARITY -> append("/popular-comic")
|
||||||
}
|
SortOrder.NEWEST -> append("/new-comic")
|
||||||
}
|
else -> append("/ongoing-comic")
|
||||||
if (page > 1) {
|
}
|
||||||
append("?page=")
|
}
|
||||||
append(page)
|
if (page > 1) {
|
||||||
}
|
append("?page=")
|
||||||
}
|
append(page)
|
||||||
|
}
|
||||||
val doc = webClient.httpGet(url).parseHtml()
|
}
|
||||||
return doc.select("div.manga-box").map { div ->
|
|
||||||
val href = div.selectFirstOrThrow("a").attrAsRelativeUrl("href")
|
val doc = webClient.httpGet(url).parseHtml()
|
||||||
val img = div.selectFirst("img.lazyload")
|
return doc.select("div.manga-box").map { div ->
|
||||||
Manga(
|
val href = div.selectFirstOrThrow("a").attrAsRelativeUrl("href")
|
||||||
id = generateUid(href),
|
val img = div.selectFirst("img.lazyload")
|
||||||
url = href,
|
Manga(
|
||||||
publicUrl = href.toAbsoluteUrl(domain),
|
id = generateUid(href),
|
||||||
title = div.selectFirst("h3 a")?.text().orEmpty(),
|
url = href,
|
||||||
altTitle = null,
|
publicUrl = href.toAbsoluteUrl(domain),
|
||||||
author = null,
|
title = div.selectFirst("h3 a")?.text().orEmpty(),
|
||||||
tags = emptySet(),
|
altTitle = null,
|
||||||
rating = RATING_UNKNOWN,
|
author = null,
|
||||||
isNsfw = isNsfwSource,
|
tags = emptySet(),
|
||||||
coverUrl = img?.attr("data-src").orEmpty(),
|
rating = RATING_UNKNOWN,
|
||||||
state = null,
|
isNsfw = isNsfwSource,
|
||||||
source = source,
|
coverUrl = img?.attr("data-src").orEmpty(),
|
||||||
)
|
state = null,
|
||||||
}
|
source = source,
|
||||||
}
|
)
|
||||||
|
}
|
||||||
override suspend fun getDetails(manga: Manga): Manga {
|
}
|
||||||
val doc = webClient.httpGet(manga.url.toAbsoluteUrl(domain)).parseHtml()
|
|
||||||
return manga.copy(
|
override suspend fun getDetails(manga: Manga): Manga {
|
||||||
tags = doc.select("td:contains(Genres:) + td a").mapToSet { a ->
|
val doc = webClient.httpGet(manga.url.toAbsoluteUrl(domain)).parseHtml()
|
||||||
MangaTag(
|
return manga.copy(
|
||||||
key = a.attr("href").substringAfterLast('/').substringBefore("-comic"),
|
tags = doc.select("td:contains(Genres:) + td a").mapToSet { a ->
|
||||||
title = a.text().toTitleCase(sourceLocale),
|
MangaTag(
|
||||||
source = source
|
key = a.attr("href").substringAfterLast('/').substringBefore("-comic"),
|
||||||
)
|
title = a.text().toTitleCase(sourceLocale),
|
||||||
},
|
source = source,
|
||||||
author = doc.selectFirst("td:contains(Author:) + td")?.textOrNull(),
|
)
|
||||||
state = when(doc.selectFirst("td:contains(Status:) + td a")?.text()?.lowercase()) {
|
},
|
||||||
"ongoing" -> MangaState.ONGOING
|
author = doc.selectFirst("td:contains(Author:) + td")?.textOrNull(),
|
||||||
"completed" -> MangaState.FINISHED
|
state = when (doc.selectFirst("td:contains(Status:) + td a")?.text()?.lowercase()) {
|
||||||
else -> null
|
"ongoing" -> MangaState.ONGOING
|
||||||
},
|
"completed" -> MangaState.FINISHED
|
||||||
description = doc.selectFirst("div.manga-desc p.pdesc")?.html(),
|
else -> null
|
||||||
chapters = doc.select("ul.basic-list li").mapChapters(reversed = true) { i, li ->
|
},
|
||||||
val a = li.selectFirst("a.ch-name") ?: return@mapChapters null
|
description = doc.selectFirst("div.manga-desc p.pdesc")?.html(),
|
||||||
val href = a.attrAsRelativeUrl("href")
|
chapters = doc.select("ul.basic-list li").mapChapters(reversed = true) { i, li ->
|
||||||
val name = a.text()
|
val a = li.selectFirst("a.ch-name") ?: return@mapChapters null
|
||||||
|
val href = a.attrAsRelativeUrl("href")
|
||||||
MangaChapter(
|
val name = a.text()
|
||||||
id = generateUid(href),
|
|
||||||
name = name,
|
MangaChapter(
|
||||||
number = name.substringAfter('#').toFloatOrNull() ?: (i + 1f),
|
id = generateUid(href),
|
||||||
url = href,
|
name = name,
|
||||||
scanlator = null,
|
number = name.substringAfter('#').toFloatOrNull() ?: (i + 1f),
|
||||||
uploadDate = 0L,
|
url = href,
|
||||||
branch = null,
|
scanlator = null,
|
||||||
source = source,
|
uploadDate = 0L,
|
||||||
volume = 0,
|
branch = null,
|
||||||
)
|
source = source,
|
||||||
}
|
volume = 0,
|
||||||
)
|
)
|
||||||
}
|
},
|
||||||
|
)
|
||||||
override suspend fun getPages(chapter: MangaChapter): List<MangaPage> {
|
}
|
||||||
val fullUrl = chapter.url.toAbsoluteUrl(domain) + "/all"
|
|
||||||
val doc = webClient.httpGet(fullUrl).parseHtml()
|
override suspend fun getPages(chapter: MangaChapter): List<MangaPage> {
|
||||||
|
val fullUrl = chapter.url.toAbsoluteUrl(domain) + "/all"
|
||||||
return doc.select("img.chapter_img.lazyload").mapNotNull { img ->
|
val doc = webClient.httpGet(fullUrl).parseHtml()
|
||||||
val imageUrl = img.attrOrNull("data-src") ?: return@mapNotNull null
|
|
||||||
MangaPage(
|
return doc.select("img.chapter_img.lazyload").mapNotNull { img ->
|
||||||
id = generateUid(imageUrl),
|
val imageUrl = img.attrOrNull("data-src") ?: return@mapNotNull null
|
||||||
url = imageUrl,
|
MangaPage(
|
||||||
preview = null,
|
id = generateUid(imageUrl),
|
||||||
source = source
|
url = imageUrl,
|
||||||
)
|
preview = null,
|
||||||
}
|
source = source,
|
||||||
}
|
)
|
||||||
|
}
|
||||||
private suspend fun fetchAvailableTags(): Set<MangaTag> {
|
}
|
||||||
val doc = webClient.httpGet("https://$domain").parseHtml()
|
|
||||||
return doc.select("div.cr-anime-box.genre-box a.genre-name").mapToSet { a ->
|
private suspend fun fetchAvailableTags(): Set<MangaTag> {
|
||||||
val href = a.attr("href")
|
val doc = webClient.httpGet("https://$domain").parseHtml()
|
||||||
val key = href.substringAfterLast('/').substringBefore("-comic")
|
return doc.select("div.cr-anime-box.genre-box a.genre-name").mapToSet { a ->
|
||||||
MangaTag(
|
val href = a.attr("href")
|
||||||
key = key,
|
val key = href.substringAfterLast('/').substringBefore("-comic")
|
||||||
title = a.text().toTitleCase(sourceLocale),
|
MangaTag(
|
||||||
source = source
|
key = key,
|
||||||
)
|
title = a.text().toTitleCase(sourceLocale),
|
||||||
}
|
source = source,
|
||||||
}
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,22 +0,0 @@
|
|||||||
package org.koitharu.kotatsu.parsers.site.fuzzydoodle.en
|
|
||||||
|
|
||||||
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
|
||||||
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
|
||||||
import org.koitharu.kotatsu.parsers.model.ContentType
|
|
||||||
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
|
||||||
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
|
||||||
import java.util.*
|
|
||||||
|
|
||||||
@MangaSourceParser("RESETSCANS", "ResetScans", "en")
|
|
||||||
internal class ResetScans(context: MangaLoaderContext) :
|
|
||||||
MadaraParser(context, MangaParserSource.RESETSCANS, domain = "rspro.xyz", pageSize = 18) {
|
|
||||||
|
|
||||||
override suspend fun getFilterOptions() = super.getFilterOptions().copy(
|
|
||||||
availableContentTypes = EnumSet.of(
|
|
||||||
ContentType.MANGA,
|
|
||||||
ContentType.MANHWA,
|
|
||||||
ContentType.MANHUA,
|
|
||||||
),
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
@ -0,0 +1,10 @@
|
|||||||
|
package org.koitharu.kotatsu.parsers.site.keyoapp.en
|
||||||
|
|
||||||
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
|
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
||||||
|
import org.koitharu.kotatsu.parsers.site.keyoapp.KeyoappParser
|
||||||
|
|
||||||
|
@MangaSourceParser("AGSCOMICS", "AgsComics", "en")
|
||||||
|
internal class AgsComics(context: MangaLoaderContext) :
|
||||||
|
KeyoappParser(context, MangaParserSource.AGSCOMICS, "agrcomics.com")
|
||||||
@ -1,10 +1,12 @@
|
|||||||
package org.koitharu.kotatsu.parsers.site.keyoapp.en
|
package org.koitharu.kotatsu.parsers.site.keyoapp.en
|
||||||
|
|
||||||
|
import org.koitharu.kotatsu.parsers.Broken
|
||||||
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
||||||
import org.koitharu.kotatsu.parsers.site.keyoapp.KeyoappParser
|
import org.koitharu.kotatsu.parsers.site.keyoapp.KeyoappParser
|
||||||
|
|
||||||
|
@Broken
|
||||||
@MangaSourceParser("LUASCANS", "luaComic.net", "en")
|
@MangaSourceParser("LUASCANS", "luaComic.net", "en")
|
||||||
internal class LuaScans(context: MangaLoaderContext) :
|
internal class LuaScans(context: MangaLoaderContext) :
|
||||||
KeyoappParser(context, MangaParserSource.LUASCANS, "luacomic.net")
|
KeyoappParser(context, MangaParserSource.LUASCANS, "luacomic.org")
|
||||||
|
|||||||
@ -1,13 +1,11 @@
|
|||||||
package org.koitharu.kotatsu.parsers.site.madara.en
|
package org.koitharu.kotatsu.parsers.site.madara.en
|
||||||
|
|
||||||
import org.koitharu.kotatsu.parsers.Broken
|
|
||||||
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
import org.koitharu.kotatsu.parsers.model.ContentType
|
import org.koitharu.kotatsu.parsers.model.ContentType
|
||||||
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
||||||
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
||||||
|
|
||||||
@Broken
|
|
||||||
@MangaSourceParser("COCOMIC", "CoComic", "en", ContentType.HENTAI)
|
@MangaSourceParser("COCOMIC", "CoComic", "en", ContentType.HENTAI)
|
||||||
internal class CoComic(context: MangaLoaderContext) :
|
internal class CoComic(context: MangaLoaderContext) :
|
||||||
MadaraParser(context, MangaParserSource.COCOMIC, "cocomic.co")
|
MadaraParser(context, MangaParserSource.COCOMIC, "cocomic.co")
|
||||||
|
|||||||
@ -1,11 +1,13 @@
|
|||||||
package org.koitharu.kotatsu.parsers.site.madara.en
|
package org.koitharu.kotatsu.parsers.site.madara.en
|
||||||
|
|
||||||
|
import org.koitharu.kotatsu.parsers.Broken
|
||||||
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
import org.koitharu.kotatsu.parsers.model.ContentType
|
import org.koitharu.kotatsu.parsers.model.ContentType
|
||||||
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
||||||
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
||||||
|
|
||||||
|
@Broken
|
||||||
@MangaSourceParser("HIPERDEX", "HiperToon", "en", ContentType.HENTAI)
|
@MangaSourceParser("HIPERDEX", "HiperToon", "en", ContentType.HENTAI)
|
||||||
internal class HiperDex(context: MangaLoaderContext) :
|
internal class HiperDex(context: MangaLoaderContext) :
|
||||||
MadaraParser(context, MangaParserSource.HIPERDEX, "hipertoon.com", 36)
|
MadaraParser(context, MangaParserSource.HIPERDEX, "hipertoon.com", 36)
|
||||||
|
|||||||
@ -1,12 +1,13 @@
|
|||||||
package org.koitharu.kotatsu.parsers.site.madara.en
|
package org.koitharu.kotatsu.parsers.site.madara.en
|
||||||
|
|
||||||
|
import org.koitharu.kotatsu.parsers.Broken
|
||||||
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
import org.koitharu.kotatsu.parsers.model.ContentType
|
import org.koitharu.kotatsu.parsers.model.ContentType
|
||||||
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
||||||
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
||||||
|
|
||||||
// need to login and pay for read
|
@Broken
|
||||||
@MangaSourceParser("KIARA18", "Kiara18", "en", ContentType.HENTAI)
|
@MangaSourceParser("KIARA18", "Kiara18", "en", ContentType.HENTAI)
|
||||||
internal class Kiara18(context: MangaLoaderContext) :
|
internal class Kiara18(context: MangaLoaderContext) :
|
||||||
MadaraParser(context, MangaParserSource.KIARA18, "18.kiara.cool")
|
MadaraParser(context, MangaParserSource.KIARA18, "18.kiara.cool")
|
||||||
|
|||||||
@ -1,14 +1,12 @@
|
|||||||
package org.koitharu.kotatsu.parsers.site.madara.en
|
package org.koitharu.kotatsu.parsers.site.madara.en
|
||||||
|
|
||||||
import org.koitharu.kotatsu.parsers.Broken
|
|
||||||
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
||||||
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
||||||
|
|
||||||
@Broken
|
@MangaSourceParser("LIKEMANGAIN", "LikeManga.in", "en")
|
||||||
@MangaSourceParser("MANGATX_TO", "MangaTx.to", "en")
|
internal class LikeMangaIn(context: MangaLoaderContext) :
|
||||||
internal class MangaTxTo(context: MangaLoaderContext) :
|
MadaraParser(context, MangaParserSource.LIKEMANGAIN, "likemanga.in", 36) {
|
||||||
MadaraParser(context, MangaParserSource.MANGATX_TO, "mangatx.to", 10) {
|
override val datePattern = "d MMMM, yyyy"
|
||||||
override val tagPrefix = "manhua-genre/"
|
|
||||||
}
|
}
|
||||||
@ -1,11 +1,13 @@
|
|||||||
package org.koitharu.kotatsu.parsers.site.madara.en
|
package org.koitharu.kotatsu.parsers.site.madara.en
|
||||||
|
|
||||||
|
import org.koitharu.kotatsu.parsers.Broken
|
||||||
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
import org.koitharu.kotatsu.parsers.model.ContentType
|
import org.koitharu.kotatsu.parsers.model.ContentType
|
||||||
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
||||||
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
||||||
|
|
||||||
|
@Broken
|
||||||
@MangaSourceParser("MANGARYU", "MangaRyu", "en", ContentType.HENTAI)
|
@MangaSourceParser("MANGARYU", "MangaRyu", "en", ContentType.HENTAI)
|
||||||
internal class MangaRyu(context: MangaLoaderContext) :
|
internal class MangaRyu(context: MangaLoaderContext) :
|
||||||
MadaraParser(context, MangaParserSource.MANGARYU, "mangaryu.com", 10)
|
MadaraParser(context, MangaParserSource.MANGARYU, "mangaryu.com", 10)
|
||||||
|
|||||||
@ -0,0 +1,11 @@
|
|||||||
|
package org.koitharu.kotatsu.parsers.site.madara.en
|
||||||
|
|
||||||
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
|
import org.koitharu.kotatsu.parsers.model.ContentType
|
||||||
|
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
||||||
|
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
||||||
|
|
||||||
|
@MangaSourceParser("MANHWATOON", "ManhwaToon", "en", ContentType.HENTAI)
|
||||||
|
internal class ManhwaToon(context: MangaLoaderContext) :
|
||||||
|
MadaraParser(context, MangaParserSource.MANHWATOON, "www.manhwatoon.com")
|
||||||
@ -0,0 +1,11 @@
|
|||||||
|
package org.koitharu.kotatsu.parsers.site.madara.en
|
||||||
|
|
||||||
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
|
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
||||||
|
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
||||||
|
|
||||||
|
@MangaSourceParser("RESETSCANS", "ReadManhua", "en")
|
||||||
|
internal class ResetScans(context: MangaLoaderContext) :
|
||||||
|
MadaraParser(context, MangaParserSource.RESETSCANS, "reset-scans.co", 20)
|
||||||
|
|
||||||
@ -0,0 +1,12 @@
|
|||||||
|
package org.koitharu.kotatsu.parsers.site.madara.en
|
||||||
|
|
||||||
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
|
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
||||||
|
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
||||||
|
|
||||||
|
@MangaSourceParser("SITEMANGA", "SiteManga", "en")
|
||||||
|
internal class SiteManga(context: MangaLoaderContext) :
|
||||||
|
MadaraParser(context, MangaParserSource.SITEMANGA, "sitemanga.com") {
|
||||||
|
override val datePattern = "MM/dd/yyyy"
|
||||||
|
}
|
||||||
@ -1,10 +1,12 @@
|
|||||||
package org.koitharu.kotatsu.parsers.site.madara.es
|
package org.koitharu.kotatsu.parsers.site.madara.es
|
||||||
|
|
||||||
|
import org.koitharu.kotatsu.parsers.Broken
|
||||||
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
||||||
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
||||||
|
|
||||||
|
@Broken
|
||||||
@MangaSourceParser("HOUSEOFOTAKUS", "HouseOfOtakus", "es")
|
@MangaSourceParser("HOUSEOFOTAKUS", "HouseOfOtakus", "es")
|
||||||
internal class HouseOfOtakus(context: MangaLoaderContext) :
|
internal class HouseOfOtakus(context: MangaLoaderContext) :
|
||||||
MadaraParser(context, MangaParserSource.HOUSEOFOTAKUS, "houseofotakus.xyz")
|
MadaraParser(context, MangaParserSource.HOUSEOFOTAKUS, "houseofotakus.xyz")
|
||||||
|
|||||||
@ -0,0 +1,11 @@
|
|||||||
|
package org.koitharu.kotatsu.parsers.site.madara.es
|
||||||
|
|
||||||
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
|
import org.koitharu.kotatsu.parsers.model.ContentType
|
||||||
|
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
||||||
|
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
||||||
|
|
||||||
|
@MangaSourceParser("MANHWAS_ES", "Manhwas.es", "es", ContentType.HENTAI)
|
||||||
|
internal class Manhwas(context: MangaLoaderContext) :
|
||||||
|
MadaraParser(context, MangaParserSource.MANHWAS_ES, "manhwas.es", 30)
|
||||||
@ -0,0 +1,10 @@
|
|||||||
|
package org.koitharu.kotatsu.parsers.site.madara.es
|
||||||
|
|
||||||
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
|
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
||||||
|
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
||||||
|
|
||||||
|
@MangaSourceParser("MMDAOS", "Mmdaos", "es")
|
||||||
|
internal class Mmdaos(context: MangaLoaderContext) :
|
||||||
|
MadaraParser(context, MangaParserSource.MMDAOS, "mmdaos.com")
|
||||||
@ -0,0 +1,10 @@
|
|||||||
|
package org.koitharu.kotatsu.parsers.site.madara.es
|
||||||
|
|
||||||
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
|
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
||||||
|
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
||||||
|
|
||||||
|
@MangaSourceParser("ZEVEP", "Zevep", "es")
|
||||||
|
internal class Zevep(context: MangaLoaderContext) :
|
||||||
|
MadaraParser(context, MangaParserSource.ZEVEP, "zevep.com", 16)
|
||||||
@ -1,12 +1,14 @@
|
|||||||
package org.koitharu.kotatsu.parsers.site.madara.id
|
package org.koitharu.kotatsu.parsers.site.madara.id
|
||||||
|
|
||||||
|
import org.koitharu.kotatsu.parsers.Broken
|
||||||
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
||||||
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
||||||
|
|
||||||
|
@Broken
|
||||||
@MangaSourceParser("HWAGO", "Hwago", "id")
|
@MangaSourceParser("HWAGO", "Hwago", "id")
|
||||||
internal class Hwago(context: MangaLoaderContext) :
|
internal class Hwago(context: MangaLoaderContext) :
|
||||||
MadaraParser(context, MangaParserSource.HWAGO, "hwago.org") {
|
MadaraParser(context, MangaParserSource.HWAGO, "hwago01.xyz") {
|
||||||
override val datePattern = "d MMMM yyyy"
|
override val datePattern = "d MMMM yyyy"
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,14 +1,10 @@
|
|||||||
package org.koitharu.kotatsu.parsers.site.madara.pt
|
package org.koitharu.kotatsu.parsers.site.madara.pt
|
||||||
|
|
||||||
import org.koitharu.kotatsu.parsers.Broken
|
|
||||||
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
||||||
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
||||||
|
|
||||||
@Broken
|
|
||||||
@MangaSourceParser("ARGOSCOMICS", "ArgosComics", "pt")
|
@MangaSourceParser("ARGOSCOMICS", "ArgosComics", "pt")
|
||||||
internal class ArgosComics(context: MangaLoaderContext) :
|
internal class ArgosComics(context: MangaLoaderContext) :
|
||||||
MadaraParser(context, MangaParserSource.ARGOSCOMICS, "argoscomics.com.br") {
|
MadaraParser(context, MangaParserSource.ARGOSCOMICS, "argoscomic.com")
|
||||||
override val datePattern: String = "d 'de' MMMM 'de' yyyy"
|
|
||||||
}
|
|
||||||
|
|||||||
@ -0,0 +1,12 @@
|
|||||||
|
package org.koitharu.kotatsu.parsers.site.madara.pt
|
||||||
|
|
||||||
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
|
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
||||||
|
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
||||||
|
|
||||||
|
@MangaSourceParser("MANGAONLINE_BLOG", "MangaOnline", "pt")
|
||||||
|
internal class MangaOnline(context: MangaLoaderContext) :
|
||||||
|
MadaraParser(context, MangaParserSource.MANGAONLINE_BLOG, "mangaonline.blog", 16) {
|
||||||
|
override val datePattern: String = "dd 'de' MMMMM 'de' yyyy"
|
||||||
|
}
|
||||||
@ -0,0 +1,12 @@
|
|||||||
|
package org.koitharu.kotatsu.parsers.site.madara.pt
|
||||||
|
|
||||||
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
|
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
||||||
|
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
||||||
|
|
||||||
|
@MangaSourceParser("SSREADING", "SsReading", "pt")
|
||||||
|
internal class SsReading(context: MangaLoaderContext) :
|
||||||
|
MadaraParser(context, MangaParserSource.SSREADING, "ssreading.com.br") {
|
||||||
|
override val datePattern: String = "dd 'de' MMM 'de' yyyy"
|
||||||
|
}
|
||||||
@ -0,0 +1,12 @@
|
|||||||
|
package org.koitharu.kotatsu.parsers.site.madara.pt
|
||||||
|
|
||||||
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
|
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
||||||
|
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
||||||
|
|
||||||
|
@MangaSourceParser("XSSCAN", "XsScan", "pt")
|
||||||
|
internal class XsScan(context: MangaLoaderContext) :
|
||||||
|
MadaraParser(context, MangaParserSource.XSSCAN, "xsscan.xyz") {
|
||||||
|
override val datePattern: String = "dd/MM/yyyy"
|
||||||
|
}
|
||||||
@ -1,10 +1,12 @@
|
|||||||
package org.koitharu.kotatsu.parsers.site.madara.tr
|
package org.koitharu.kotatsu.parsers.site.madara.tr
|
||||||
|
|
||||||
|
import org.koitharu.kotatsu.parsers.Broken
|
||||||
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
||||||
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
||||||
|
|
||||||
|
@Broken
|
||||||
@MangaSourceParser("MANGARUHU", "MangaRuhu", "tr")
|
@MangaSourceParser("MANGARUHU", "MangaRuhu", "tr")
|
||||||
internal class MangaRuhu(context: MangaLoaderContext) :
|
internal class MangaRuhu(context: MangaLoaderContext) :
|
||||||
MadaraParser(context, MangaParserSource.MANGARUHU, "mangaruhu.com", 16)
|
MadaraParser(context, MangaParserSource.MANGARUHU, "mangaruhu.com", 16)
|
||||||
|
|||||||
@ -1,13 +0,0 @@
|
|||||||
package org.koitharu.kotatsu.parsers.site.madara.tr
|
|
||||||
|
|
||||||
import org.koitharu.kotatsu.parsers.Broken
|
|
||||||
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
|
||||||
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
|
||||||
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
|
||||||
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
|
||||||
|
|
||||||
//Images blocked by ReCAPTCHA
|
|
||||||
@Broken // https://github.com/KotatsuApp/kotatsu-parsers/issues/1250
|
|
||||||
@MangaSourceParser("MERLINSCANS", "MerlinScans", "tr")
|
|
||||||
internal class MerlinScans(context: MangaLoaderContext) :
|
|
||||||
MadaraParser(context, MangaParserSource.MERLINSCANS, "merlinscans.com", 10)
|
|
||||||
@ -0,0 +1,12 @@
|
|||||||
|
package org.koitharu.kotatsu.parsers.site.madara.tr
|
||||||
|
|
||||||
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
|
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
||||||
|
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
||||||
|
|
||||||
|
@MangaSourceParser("YAOIBAR", "YaoiBar", "tr")
|
||||||
|
internal class YaoiBar(context: MangaLoaderContext) :
|
||||||
|
MadaraParser(context, MangaParserSource.YAOIBAR, "yaoibar.gay", 16) {
|
||||||
|
override val datePattern = "dd/MM/yyyy"
|
||||||
|
}
|
||||||
@ -0,0 +1,12 @@
|
|||||||
|
package org.koitharu.kotatsu.parsers.site.madara.tr
|
||||||
|
|
||||||
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
|
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
||||||
|
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
||||||
|
|
||||||
|
@MangaSourceParser("YETISKINRUYAMANGA", "YaoiMangaOku", "tr")
|
||||||
|
internal class YetiskinRuyaManga(context: MangaLoaderContext) :
|
||||||
|
MadaraParser(context, MangaParserSource.YETISKINRUYAMANGA, "www.yetiskinruyamanga.com", 16) {
|
||||||
|
override val datePattern = "dD/MM/yyyy"
|
||||||
|
}
|
||||||
@ -0,0 +1,12 @@
|
|||||||
|
package org.koitharu.kotatsu.parsers.site.madara.vi
|
||||||
|
|
||||||
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
|
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
||||||
|
import org.koitharu.kotatsu.parsers.site.madara.MadaraParser
|
||||||
|
|
||||||
|
@MangaSourceParser("RUAHAPCHANHDAY", "RuaHapChanhDay", "vi")
|
||||||
|
internal class RuaHapChanhDay(context: MangaLoaderContext) :
|
||||||
|
MadaraParser(context, MangaParserSource.RUAHAPCHANHDAY, "ruahapchanhday.com", 30) {
|
||||||
|
override val datePattern = "dd/MM/yyyy"
|
||||||
|
}
|
||||||
@ -1,10 +1,12 @@
|
|||||||
package org.koitharu.kotatsu.parsers.site.mangareader.ar
|
package org.koitharu.kotatsu.parsers.site.mangareader.ar
|
||||||
|
|
||||||
|
import org.koitharu.kotatsu.parsers.Broken
|
||||||
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
||||||
import org.koitharu.kotatsu.parsers.site.mangareader.MangaReaderParser
|
import org.koitharu.kotatsu.parsers.site.mangareader.MangaReaderParser
|
||||||
|
|
||||||
|
@Broken
|
||||||
@MangaSourceParser("NOONSCAN", "NoonScan.com", "ar")
|
@MangaSourceParser("NOONSCAN", "NoonScan.com", "ar")
|
||||||
internal class NoonScan(context: MangaLoaderContext) :
|
internal class NoonScan(context: MangaLoaderContext) :
|
||||||
MangaReaderParser(context, MangaParserSource.NOONSCAN, "noonscan.com", pageSize = 20, searchPageSize = 10)
|
MangaReaderParser(context, MangaParserSource.NOONSCAN, "noonscan.com", pageSize = 20, searchPageSize = 10)
|
||||||
|
|||||||
@ -0,0 +1,13 @@
|
|||||||
|
package org.koitharu.kotatsu.parsers.site.mangareader.en
|
||||||
|
|
||||||
|
import org.koitharu.kotatsu.parsers.MangaLoaderContext
|
||||||
|
import org.koitharu.kotatsu.parsers.MangaSourceParser
|
||||||
|
import org.koitharu.kotatsu.parsers.model.MangaParserSource
|
||||||
|
import org.koitharu.kotatsu.parsers.site.mangareader.MangaReaderParser
|
||||||
|
|
||||||
|
@MangaSourceParser("MANGATX_CC", "MangaTx.cc", "en")
|
||||||
|
internal class MangaTxCc(context: MangaLoaderContext) :
|
||||||
|
MangaReaderParser(context, MangaParserSource.MANGATX_CC, "mangatx.cc", 30, 21) {
|
||||||
|
override val datePattern = "dd-MM-yyyy"
|
||||||
|
override val listUrl = "/manga-list"
|
||||||
|
}
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue