dosage/dosagelib/plugins/t.py

163 lines
6.6 KiB
Python
Raw Normal View History

# -*- coding: iso-8859-1 -*-
# Copyright (C) 2004-2005 Tristan Seligmann and Jonathan Jacobs
2013-02-05 18:51:46 +00:00
# Copyright (C) 2012-2013 Bastian Kleineidam
2012-06-20 19:58:13 +00:00
2012-11-21 20:57:26 +00:00
from re import compile, IGNORECASE
2012-10-11 10:03:12 +00:00
from ..scraper import _BasicScraper
from ..helpers import indirectStarter
2012-11-21 20:57:26 +00:00
from ..util import tagre
2012-06-20 19:58:13 +00:00
2013-02-06 21:27:40 +00:00
class TheBrads(_BasicScraper):
url = 'http://bradcolbow.com/archive/C4/'
stripUrl = url + '%s'
2013-03-07 18:54:18 +00:00
imageSearch = compile(tagre("img", "src", r'(http://s3\.amazonaws\.com/the_brads/the-?brads[-_][^"]+)'))
2013-02-06 21:27:40 +00:00
prevSearch = compile(tagre("a", "href", r'(http://bradcolbow\.com/archive/C4/[^"]+)', before="prev"))
multipleImagesPerStrip = True
help = 'Index format: a letter and a number'
2012-12-08 20:30:51 +00:00
class TheDevilsPanties(_BasicScraper):
url = 'http://thedevilspanties.com/'
stripUrl = url + 'archives/%s'
2012-12-08 20:30:51 +00:00
imageSearch = compile(tagre("img", "src", r'(http://cdn\.thedevilspanties\.com/comics/[^"]+)'))
prevSearch = compile(tagre("a", "href", r'(/archives/\d+)', after="Previous"))
help = 'Index format: number'
2012-06-20 19:58:13 +00:00
class TheNoob(_BasicScraper):
url = 'http://www.thenoobcomic.com/index.php'
stripUrl = url + '?pos=%s'
2012-11-25 06:56:46 +00:00
imageSearch = compile(tagre("img", "src", r'(/headquarters/comics/[^"]+)'))
prevSearch = compile(tagre("a", "href", r'(\?pos=\d+)', before="comic_nav_previous_button"))
2012-06-20 19:58:13 +00:00
help = 'Index format: nnnn'
class TheOrderOfTheStick(_BasicScraper):
url = 'http://www.giantitp.com/comics/oots0863.html'
2012-12-04 06:02:40 +00:00
stripUrl = 'http://www.giantitp.com/comics/oots%s.html'
2012-12-07 23:45:18 +00:00
imageSearch = compile(r'<IMG src="(/comics/images/[^"]+)">')
2012-06-20 19:58:13 +00:00
prevSearch = compile(r'<A href="(/comics/oots\d{4}\.html)"><IMG src="/Images/redesign/ComicNav_Back.gif"')
help = 'Index format: n (unpadded)'
starter = indirectStarter('http://www.giantitp.com/', compile(r'<A href="(/comics/oots\d{4}\.html)"'))
2012-12-07 23:45:18 +00:00
@classmethod
def namer(cls, imageUrl, pageUrl):
return pageUrl.rsplit('/', 1)[-1][:-5]
2012-06-20 19:58:13 +00:00
class TheParkingLotIsFull(_BasicScraper):
url = 'http://plif.courageunfettered.com/archive/arch2002.htm'
2012-11-25 06:56:46 +00:00
stripUrl = 'http://plif.courageunfettered.com/archive/arch%s.htm'
2012-06-20 19:58:13 +00:00
imageSearch = compile(r'<td align="center"><A TARGET=_parent HREF="(wc\d+\..+?)">')
2012-12-04 06:02:40 +00:00
multipleImagesPerStrip = True
prevSearch = compile(r'\d{4} -\s+<A HREF="(arch\d{4}\.htm)">\d{4}')
2012-06-20 19:58:13 +00:00
help = 'Index format: nnn'
class TheWotch(_BasicScraper):
url = 'http://www.thewotch.com/'
stripUrl = url + '?date=%s'
2012-06-20 19:58:13 +00:00
imageSearch = compile(r"<img.+?src='(comics/.+?)'")
2012-12-04 06:02:40 +00:00
prevSearch = compile(r"<link rel='Previous' href='(/\?date=\d+-\d+-\d+)'")
2012-06-20 19:58:13 +00:00
help = 'Index format: yyyy-mm-dd'
2013-02-06 21:08:36 +00:00
class ThisIsIndexed(_BasicScraper):
url = 'http://thisisindexed.com/'
stripUrl = url + 'page/%s'
imageSearch = compile(tagre("img", "src", r'(http://thisisindexed\.com/wp-content/uploads/\d+/\d+/card[^"]+)'))
multipleImagesPerStrip = True
prevSearch = compile(tagre("div", "class", "nav-previous") +
tagre("a", "href", r'(http://thisisindexed\.com/page/\d+/)'))
help = 'Index format: number'
2012-12-08 20:30:51 +00:00
class ThunderAndLightning(_BasicScraper):
2013-02-06 21:08:36 +00:00
url = 'http://www.talcomic.com/wp/'
stripUrl = url + '%s/'
2012-12-08 20:30:51 +00:00
prevSearch = compile(tagre("a", "href", r'(http://www\.talcomic\.com/wp/[^"]+)', after="prev"))
imageSearch = compile(tagre("img", "src", r'(http://www\.talcomic\.com/wp/comics/[^"]+)'))
help = 'Index format: yyyy/mm/dd/page-nn'
2013-02-06 21:08:36 +00:00
@classmethod
def starter(cls):
return cls.url + '?latestcomic'
2012-12-08 20:30:51 +00:00
2012-11-21 20:57:26 +00:00
class TinyKittenTeeth(_BasicScraper):
url = 'http://www.tinykittenteeth.com/'
stripUrl = url + '%s/'
2012-11-21 20:57:26 +00:00
imageSearch = compile(tagre("img", "src", r'(http://www\.tinykittenteeth\.com/comics/[^"]+)'))
prevSearch = compile(tagre("a", "href", r'([^"]+)', after="Previous"))
2012-11-25 06:56:46 +00:00
help = 'Index format: yyyy/mm/dd/stripname (unpadded)'
2012-11-21 20:57:26 +00:00
2012-06-20 19:58:13 +00:00
2013-02-06 21:08:36 +00:00
class ToonHole(_BasicScraper):
url = 'http://www.toonhole.com/'
stripUrl = url + '%s/'
imageSearch = compile(tagre("img", "src", r'(http://www\.toonhole\.com/comics/\d+-\d+-\d+[^"]+)'))
prevSearch = compile(tagre("a", "href", r'(http://www\.toonhole\.com/\d+/\d+/[^"]+)', after="prev"))
help = 'Index format: yyyy/mm/stripname'
2013-03-07 17:22:24 +00:00
def shouldSkipUrl(self, url):
return url in ("http://www.toonhole.com/2013/03/if-game-of-thrones-was-animated/",)
2013-02-06 21:08:36 +00:00
2012-12-13 20:05:27 +00:00
# XXX disallowed by robots.txt
class _TwoLumps(_BasicScraper):
url = 'http://www.twolumps.net/'
stripUrl = url + 'd/%s.html'
2012-12-08 20:30:51 +00:00
imageSearch = compile(tagre("img", "src", r'(/comics/[^"]+)'))
prevSearch = compile(tagre("a", "href", r'(/d/\d+\.html)', after="prev"))
help = 'Index format: yyyymmdd'
2012-06-20 19:58:13 +00:00
class TwoTwoOneFour(_BasicScraper):
url = 'http://www.nitrocosm.com/go/2214_classic/'
stripUrl = url + '%s/'
2012-11-25 06:56:46 +00:00
imageSearch = compile(tagre("img", "src", r'(http://content\.nitrocosm\.com/[^"]+)', before="gallery_display"))
prevSearch = compile(tagre("a", "href", r'(http://www\.nitrocosm\.com/go/2214_classic/\d+/)', after="Previous"))
2012-06-20 19:58:13 +00:00
help = 'Index format: n (unpadded)'
class TheWhiteboard(_BasicScraper):
url = 'http://www.the-whiteboard.com/'
stripUrl = url + 'auto%s.html'
2012-06-20 19:58:13 +00:00
imageSearch = compile(r'<img SRC="(autotwb\d{1,4}.+?|autowb\d{1,4}.+?)">', IGNORECASE)
prevSearch = compile(r'&nbsp<a href="(.+?)">previous</a>', IGNORECASE)
help = 'Index format: twb or wb + n wg. twb1000'
class HMHigh(_BasicScraper):
name = 'TheFallenAngel/HMHigh'
url = 'http://www.thefallenangel.co.uk/hmhigh/'
stripUrl = url + '?id=%s'
2012-06-20 19:58:13 +00:00
imageSearch = compile(r'<img src="(http://www.thefallenangel.co.uk/hmhigh/img/comic/.+?)"')
prevSearch = compile(r' <a href="(http://www.thefallenangel.co.uk/.+?)" title=".+?">Prev</a>')
help = 'Index format: nnn'
class TheOuterQuarter(_BasicScraper):
url = 'http://theouterquarter.com/'
stripUrl = url + 'comic/%s'
2012-06-20 19:58:13 +00:00
imageSearch = compile(r'<img src="(http://theouterquarter.com/comics/.+?)"')
prevSearch = compile(r'<div class="nav-previous"><a href="([^"]+)" rel="prev">')
help = 'Index format: nnn'
2012-12-08 20:30:51 +00:00
2013-02-06 21:08:36 +00:00
class ThreePanelSoul(_BasicScraper):
url = 'http://threepanelsoul.com/'
stripUrl = url + '%s/'
imageSearch = compile(tagre("img", "src", r'(http://threepanelsoul\.com/comics/[^"]+)'))
prevSearch = compile(tagre("a", "href", r'(http://threepanelsoul\.com/\d+/\d+/\d+/[^"]+)', after="prev"))
help = 'Index format: yyyy/mm/dd/stripname'
2012-12-08 20:30:51 +00:00
class TracyAndTristan(_BasicScraper):
url = 'http://tandt.thecomicseries.com/'
stripUrl = url + 'comics/%s'
2012-12-08 20:30:51 +00:00
imageSearch = compile(tagre("img", "src", r'(http://tandt\.thecomicseries\.com/images/comics/[^"]+)'))
prevSearch = compile(tagre("a", "href", r'(/comics/\d+)', after="prev"))
help = 'Index format: number'