#!/usr/bin/env python2.7
# coding: utf-8
+from __future__ import unicode_literals, print_function
import signal
-from cmdline import cmd_parser, banner
-from parser import doujinshi_parser, search_parser, print_doujinshi
-from doujinshi import Doujinshi
-from downloader import Downloader
-from logger import logger
+import platform
+import time
+import multiprocessing
+
+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))
+
+ from nhentai.constant import PROXY
+ # constant.PROXY will be changed after cmd_parser()
+ if PROXY != {}:
+ logger.info('Using proxy: {0}'.format(PROXY))
- logger.log(15, 'nHentai: あなたも変態。 いいね?')
+ # check your cookie
+ check_cookie()
doujinshi_ids = []
doujinshi_list = []
- if options.keyword:
- doujinshis = search_parser(options.keyword, options.page)
+ 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:
- doujinshi_ids = map(lambda d: d['id'], doujinshis)
- else:
- doujinshi_ids = options.ids
+ doujinshi_ids = [i['id'] for i in doujinshis]
+
+ elif not doujinshi_ids:
+ doujinshi_ids = options.id
if doujinshi_ids:
- for id in doujinshi_ids:
- doujinshi_info = doujinshi_parser(id)
- doujinshi_list.append(Doujinshi(**doujinshi_info))
- else:
- raise SystemExit
+ 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)
- if options.is_download:
- downloader = Downloader(path=options.saved_path,
- thread=options.threads, timeout=options.timeout)
for doujinshi in doujinshi_list:
+
doujinshi.downloader = downloader
doujinshi.download()
- else:
- map(lambda doujinshi: doujinshi.show(), doujinshi_list)
- logger.log(15, u'🍺 All done.')
+ 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:
+ logger.log(15, 'All done.')
+
+ else:
+ [doujinshi.show() for doujinshi in doujinshi_list]
-def signal_handler(signal, frame):
- logger.error('Ctrl-C signal received. Quit.')
- raise SystemExit
signal.signal(signal.SIGINT, signal_handler)
+
+
if __name__ == '__main__':
main()