X-Git-Url: https://git.lizzy.rs/?a=blobdiff_plain;f=nhentai%2Fcommand.py;h=41ba40e1c875ab77b903f396a1669ae3a01d4350;hb=dcf22b30a5c03576f2c720640ff4cc3c3994d1fb;hp=88d19c7e2f2b80caac3a70d90d63878653f7efae;hpb=c3983ac5fcb62a0217545a458d1d69c3ab784af1;p=nhentai.git diff --git a/nhentai/command.py b/nhentai/command.py index 88d19c7..41ba40e 100644 --- a/nhentai/command.py +++ b/nhentai/command.py @@ -1,49 +1,131 @@ #!/usr/bin/env python2.7 -#coding: utf-8 +# coding: utf-8 +from __future__ import unicode_literals, print_function +import signal +import platform +import time +import multiprocessing -from cmdline import cmd_parser, banner -from parser import dojinshi_parser, search_parser, print_dojinshi -from dojinshi import Dojinshi -from downloader import Downloader -from logger import logger +from nhentai.cmdline import cmd_parser, banner +from nhentai.parser import doujinshi_parser, search_parser, print_doujinshi, favorites_parser, tag_parser, login +from nhentai.doujinshi import Doujinshi +from nhentai.downloader import Downloader, init_worker +from nhentai.logger import logger +from nhentai.constant import BASE_URL +from nhentai.utils import generate_html, generate_cbz, generate_main_html, check_cookie, signal_handler def main(): banner() options = cmd_parser() + logger.info('Using mirror: {0}'.format(BASE_URL)) - logger.log(15, 'nHentai: あなたも変態。 いいね?') + from nhentai.constant import PROXY + # constant.PROXY will be changed after cmd_parser() + if PROXY != {}: + logger.info('Using proxy: {0}'.format(PROXY)) - dojinshi_ids = [] - dojinshi_list = [] + # check your cookie + check_cookie() - if options.keyword: - dojinshis = search_parser(options.keyword, options.page) + doujinshi_ids = [] + doujinshi_list = [] + + if options.favorites: + if not options.is_download: + logger.warning('You do not specify --download option') + + doujinshis = favorites_parser() + print_doujinshi(doujinshis) + if options.is_download and doujinshis: + doujinshi_ids = [i['id'] for i in doujinshis] + + elif options.tag: + doujinshis = tag_parser(options.tag, sorting=options.sorting, max_page=options.max_page) + print_doujinshi(doujinshis) + if options.is_download and doujinshis: + doujinshi_ids = [i['id'] for i in doujinshis] + + elif options.artist: + doujinshis = tag_parser(options.artist, max_page=options.max_page, index=1) + print_doujinshi(doujinshis) + if options.is_download and doujinshis: + doujinshi_ids = [i['id'] for i in doujinshis] + + elif options.character: + doujinshis = tag_parser(options.character, max_page=options.max_page, index=2) + print_doujinshi(doujinshis) + if options.is_download and doujinshis: + doujinshi_ids = [i['id'] for i in doujinshis] + + elif options.parody: + doujinshis = tag_parser(options.parody, max_page=options.max_page, index=3) + print_doujinshi(doujinshis) + if options.is_download and doujinshis: + doujinshi_ids = [i['id'] for i in doujinshis] + + elif options.group: + doujinshis = tag_parser(options.group, max_page=options.max_page, index=4) + print_doujinshi(doujinshis) + if options.is_download and doujinshis: + doujinshi_ids = [i['id'] for i in doujinshis] + + elif options.language: + doujinshis = tag_parser(options.language, max_page=options.max_page, index=5) + print_doujinshi(doujinshis) + if options.is_download and doujinshis: + doujinshi_ids = [i['id'] for i in doujinshis] + + elif options.keyword: + doujinshis = search_parser(options.keyword, sorting=options.sorting, page=options.page) + print_doujinshi(doujinshis) if options.is_download: - dojinshi_ids = map(lambda d: d['id'], dojinshis) + doujinshi_ids = [i['id'] for i in doujinshis] + + elif not doujinshi_ids: + doujinshi_ids = options.id + + if doujinshi_ids: + for i, id_ in enumerate(doujinshi_ids): + if options.delay: + time.sleep(options.delay) + + doujinshi_info = doujinshi_parser(id_) + + if doujinshi_info: + doujinshi_list.append(Doujinshi(name_format=options.name_format, **doujinshi_info)) + + if (i + 1) % 10 == 0: + logger.info('Progress: %d / %d' % (i + 1, len(doujinshi_ids))) + + if not options.is_show: + downloader = Downloader(path=options.output_dir, size=options.threads, + timeout=options.timeout, delay=options.delay) + + for doujinshi in doujinshi_list: + + doujinshi.downloader = downloader + doujinshi.download() + + if not options.is_nohtml and not options.is_cbz: + generate_html(options.output_dir, doujinshi) + elif options.is_cbz: + generate_cbz(options.output_dir, doujinshi, options.rm_origin_dir) + + if options.main_viewer: + generate_main_html(options.output_dir) + + if not platform.system() == 'Windows': + logger.log(15, '🍻 All done.') else: - print_dojinshi(dojinshis) - else: - dojinshi_ids = options.ids + logger.log(15, 'All done.') - if dojinshi_ids: - for id in dojinshi_ids: - dojinshi_info = dojinshi_parser(id) - dojinshi_list.append(Dojinshi(**dojinshi_info)) else: - logger.log(15, 'Nothing has been done.') - raise SystemExit - - if options.is_download: - downloader = Downloader(path=options.saved_path, thread=options.threads) - for dojinshi in dojinshi_list: - dojinshi.downloader = downloader - dojinshi.download() - else: - map(lambda dojinshi: dojinshi.show(), dojinshi_list) + [doujinshi.show() for doujinshi in doujinshi_list] + - logger.log(15, u'🍺 All done.') +signal.signal(signal.SIGINT, signal_handler) if __name__ == '__main__': - main() \ No newline at end of file + main()