# -*- coding: iso-8859-1 -*- # Copyright (C) 2004-2005 Tristan Seligmann and Jonathan Jacobs from re import compile, MULTILINE from ..util import tagre from ..scraper import _BasicScraper from ..helpers import regexNamer, bounceStarter, indirectStarter class ALessonIsLearned(_BasicScraper): latestUrl = 'http://www.alessonislearned.com/' imageUrl = 'http://www.alessonislearned.com/lesson%s.html' imageSearch = compile(tagre("img", "src", r"(cmx/lesson.+?)")) prevSearch = compile(tagre("a", "href", r"(index\.php\?comic=.+?)")+r".+?previous") help = 'Index format: nnn' class ASofterWorld(_BasicScraper): latestUrl = 'http://www.asofterworld.com/' imageUrl = 'http://www.asofterworld.com/index.php?id=%s' imageSearch = compile(tagre("img", "src", r'(http://www\.asofterworld\.com/clean/[^"]+)')) prevSearch = compile(r'"([^"]+)">back') help = 'Index format: n (unpadded)' class AbleAndBaker(_BasicScraper): latestUrl = 'http://www.jimburgessdesign.com/comics/index.php' imageUrl = 'http://www.jimburgessdesign.com/comics/index.php?comic=%s' imageSearch = compile(tagre('img', 'src', r'(comics/.+)')) prevSearch = compile(tagre('a', 'href', r'(.+\d+)') + '.+?previous.gif') help = 'Index format: nnn' class AbominableCharlesChristopher(_BasicScraper): latestUrl = 'http://abominable.cc/' imageUrl = 'http://abominable.cc/%s' imageSearch = compile(r'cc(/comics/.+?)"') prevSearch = compile(r'cc(/.+?)".+?prev') help = 'Index format: yyyy/mm/dd/comicname' class AbstractGender(_BasicScraper): latestUrl = 'http://www.abstractgender.com/' imageUrl = 'http://www.abstractgender.com/?comic=%s' imageSearch = compile(tagre('img', 'src', r'(comics/\d+\.\w+)')) prevSearch = compile(tagre('a', 'href', r"(\?comic=\d+)")+tagre("img", "id", "comic_menu_prev")) help = 'Index format: n (unpadded)' class AbsurdNotions(_BasicScraper): latestUrl = 'http://www.absurdnotions.org/page129.html' imageUrl = 'http://www.absurdnotions.org/page%s.html' imageSearch = compile(tagre('img', 'src', r'(an[^"]+)')) prevSearch = compile(tagre('a', 'href', r'([^"]+)') + tagre('img', 'src', 'nprev\.gif')) help = 'Index format: n (unpadded)' class AbstruseGoose(_BasicScraper): starter = bounceStarter('http://abstrusegoose.com/', compile(tagre('a', 'href', r'(http://abstrusegoose\.com/\d+)')+"Next »")) imageUrl = 'http://abstrusegoose.com/c%s.html' imageSearch = compile(tagre('img', 'src', r'(http://abstrusegoose\.com/strips/[^<>"]+)')) prevSearch = compile(tagre('a', 'href', r'(http://abstrusegoose\.com/\d+)') + r'« Previous') help = 'Index format: n (unpadded)' @classmethod def namer(cls, imageUrl, pageUrl): index = int(pageUrl.rstrip('/').split('/')[-1]) name = imageUrl.split('/')[-1].split('.')[0] return 'c%03d-%s' % (index, name) class AcademyVale(_BasicScraper): latestUrl = 'http://imagerie.com/vale/' imageUrl = 'http://imagerie.com/vale/avarch.cgi?%s' imageSearch = compile(tagre('img', 'src', r'(avale\d{4}-\d{2}\..*?)')) prevSearch = compile(tagre('a', 'href', r'(avarch.*?)') + tagre('img', 'src', 'AVNavBack\.gif')) help = 'Index format: nnn' class Alice(_BasicScraper): latestUrl = 'http://alice.alicecomics.com/' imageUrl = 'http://alice.alicecomics.com/%s' imageSearch = compile(r'(/comics/.+?)"') prevSearch = compile(r' .+"?com(/.+?)" rel="prev') help = 'Index format: non' class AlienLovesPredator(_BasicScraper): imageUrl = 'http://alienlovespredator.com/%s' imageSearch = compile(r']+>(
', MULTILINE) help = 'Index format: n (unpadded)' class AppleGeeksLite(_BasicScraper): latestUrl = 'http://www.applegeeks.com/lite/' imageUrl = 'http://applegeeks.com/lite/index.php?aglitecomic=%s' imageSearch = compile(r'>')) imageUrl = 'http://antwrp.gsfc.nasa.gov/apod/ap%s.html' imageSearch = compile(r'') prevSearch = compile(r'<') help = 'Index format: yymmdd' @classmethod def namer(cls, imageUrl, pageUrl): return '%s-%s' % (pageUrl.split('/')[-1].split('.')[0][2:], imageUrl.split('/')[-1].split('.')[0]) class AfterStrife(_BasicScraper): latestUrl = 'http://afterstrife.com/?p=262' imageUrl = 'http://afterstrife.com/?p=%s' imageSearch = compile(r'(◄ Previous|)') help = 'Index format: yyyy/mm/strip-name' class ASkeweredParadise(_BasicScraper): latestUrl = 'http://aspcomics.net/' imageUrl = 'http://aspcomics.net/archindex.php?strip_id=%s' imageSearch = compile(r'[^>]+Back')) imageUrl = 'http://www.agirlandherfed.com/img/strip/%s' imageSearch = compile(r'[^>]+Back') help = 'Index format: nnn' @classmethod def namer(cls, imageUrl, pageUrl): return pageUrl.split('?')[-1] class AetheriaEpics(_BasicScraper): latestUrl = 'http://aetheria-epics.schala.net/' imageUrl = 'http://aetheria-epics.schala.net/%s.html' imageSearch = compile(r'