Files
2019-12-14 22:33:14 -05:00

53 lines
1.7 KiB
Python

from .danbooru_donmai_us import DanbooruDonmaiUs
from .helpers.std import Std
class LoliBooruMoe(DanbooruDonmaiUs, Std):
_archive_prefix = 'lolibooru_'
def get_manga_name(self) -> str:
if ~self.get_url().find(r'tags='):
self._is_tag = True
self._manga_name = self._get_name(r'[\?&]tags=([^&]+)')
else:
self._manga_name = self._get_name(r'/post/show/(\d+)')
return self._archive_prefix + self._manga_name
def get_chapters(self): # pragma: no cover
if self._is_tag:
pages = self._elements('#paginator .pagination > a')
if pages:
count = self.re.search(r'\bpage=(\d+)', pages[-2].get('href')).group(1)
max_page = int(count)
if max_page > 1001:
self.log('1000 pages maximum!')
max_page = 1000
return range(1, max_page)[::-1]
return [1]
def _tag_images(self): # pragma: no cover
url = '{}/post?tags={}&page={}'.format(
self.domain,
self._manga_name,
self.chapter,
)
parser = self.html_fromstring(url)
return self._images_helper(parser, '#post-list-posts a.directlink', 'href')
def _post_image(self, url): # pragma: no cover
if isinstance(url, str):
parser = self.html_fromstring(url)
else:
parser = url
full_size = parser.cssselect('.status-notice a.highres-show')
if full_size:
return [full_size[0].get('href')]
return [parser.cssselect('#image')[0].get('src')]
def chapter_for_json(self):
return self.get_url()
main = LoliBooruMoe