2012-06-20 20:41:04 +00:00
|
|
|
# -*- coding: iso-8859-1 -*-
|
|
|
|
# Copyright (C) 2004-2005 Tristan Seligmann and Jonathan Jacobs
|
2012-11-21 20:57:26 +00:00
|
|
|
# Copyright (C) 2012 Bastian Kleineidam
|
|
|
|
|
2012-06-20 19:58:13 +00:00
|
|
|
from re import compile, MULTILINE, IGNORECASE, sub
|
|
|
|
from os.path import splitext
|
2012-10-11 10:03:12 +00:00
|
|
|
from ..scraper import _BasicScraper
|
2012-11-21 20:57:26 +00:00
|
|
|
from ..helpers import indirectStarter
|
2012-11-20 17:53:53 +00:00
|
|
|
from ..util import tagre
|
2012-06-20 19:58:13 +00:00
|
|
|
|
|
|
|
|
|
|
|
class SailorsunOrg(_BasicScraper):
|
|
|
|
latestUrl = 'http://www.sailorsun.org/'
|
2012-11-21 20:57:26 +00:00
|
|
|
stripUrl = latestUrl + '?p=%s'
|
|
|
|
imageSearch = compile(tagre("img", "src", r'(http://sailorsun\.org/comics/[^"]+)'))
|
|
|
|
prevSearch = compile(tagre("a", "href", r'(http://sailorsun\.org/\?p=\d+)', after="prev"))
|
2012-06-20 19:58:13 +00:00
|
|
|
help = 'Index format: n (unpadded)'
|
|
|
|
|
|
|
|
|
|
|
|
class SamAndFuzzy(_BasicScraper):
|
|
|
|
latestUrl = 'http://www.samandfuzzy.com/'
|
2012-11-13 18:10:19 +00:00
|
|
|
stripUrl = 'http://samandfuzzy.com/%s'
|
2012-06-20 19:58:13 +00:00
|
|
|
imageSearch = compile(r'(/comics/.+?)" alt')
|
|
|
|
prevSearch = compile(r'"><a href="(.+?)"><img src="imgint/nav_prev.gif"')
|
|
|
|
help = 'Index format: nnnn'
|
|
|
|
|
|
|
|
|
|
|
|
class SarahZero(_BasicScraper):
|
|
|
|
latestUrl = 'http://www.sarahzero.com/'
|
2012-11-20 17:53:53 +00:00
|
|
|
stripUrl = latestUrl + 'sz_%s.html'
|
2012-11-21 20:57:26 +00:00
|
|
|
imageSearch = compile(tagre("img", "src", r'(z_spreads/sz_[^"]+)'))
|
|
|
|
prevSearch = compile(tagre("a", "href", r'(sz_\d+\.html)') + tagre("img", "src", r'z_site/sz_05_nav\.gif'))
|
2012-06-20 19:58:13 +00:00
|
|
|
help = 'Index format: nnnn'
|
|
|
|
|
|
|
|
|
|
|
|
class ScaryGoRound(_BasicScraper):
|
|
|
|
latestUrl = 'http://www.scarygoround.com/'
|
2012-11-20 17:53:53 +00:00
|
|
|
stripUrl = latestUrl + '?date=%s'
|
2012-11-21 20:57:26 +00:00
|
|
|
imageSearch = compile(tagre("img", "src", r'(strips/\d+\.png)'))
|
|
|
|
prevSearch = compile(tagre("a", "href", r'(\?date=\d+)') + "Previous")
|
2012-06-20 19:58:13 +00:00
|
|
|
help = 'Index format: n (unpadded)'
|
|
|
|
|
|
|
|
|
2012-11-20 17:53:53 +00:00
|
|
|
class SchlockMercenary(_BasicScraper):
|
|
|
|
latestUrl = 'http://www.schlockmercenary.com/'
|
2012-11-21 20:57:26 +00:00
|
|
|
stripUrl = latestUrl + '%s'
|
|
|
|
imageSearch = compile(tagre("img", "src", r'(http://static\.schlockmercenary\.com/comics/[^"]+)'))
|
|
|
|
prevSearch = compile(tagre("a", "href", r'(/d+)', after="nav-previous"))
|
|
|
|
help = 'Index format: yyyy-mm-dd'
|
2012-11-20 17:53:53 +00:00
|
|
|
|
2012-06-20 19:58:13 +00:00
|
|
|
|
|
|
|
class SchoolBites(_BasicScraper):
|
2012-11-21 20:57:26 +00:00
|
|
|
latestUrl = 'http://schoolbites.net/'
|
2012-11-20 17:53:53 +00:00
|
|
|
stripUrl = latestUrl + 'd/%s.html'
|
2012-11-21 20:57:26 +00:00
|
|
|
imageSearch = compile(tagre("img", "src", r'(http://cdn\.schoolbites\.net/comics/[^"]+)'))
|
|
|
|
prevSearch = compile(tagre("a", "href", r'(http://schoolbites\.net/d/\d+\.html)', after="prev"))
|
2012-06-20 19:58:13 +00:00
|
|
|
help = 'Index format: yyyymmdd'
|
|
|
|
|
|
|
|
|
2012-11-20 17:53:53 +00:00
|
|
|
class Sheldon(_BasicScraper):
|
|
|
|
latestUrl = 'http://www.sheldoncomics.com/'
|
2012-11-21 20:57:26 +00:00
|
|
|
stripUrl = latestUrl + 'archive/%s.html'
|
|
|
|
imageSearch = compile(tagre("img", "src", r'(/strips/[^"]+)'))
|
2012-11-26 17:44:31 +00:00
|
|
|
prevSearch = compile(tagre("a", "href", r'(/archive/\d+\.html)', after="sidenav-prev"))
|
2012-11-21 20:57:26 +00:00
|
|
|
help = 'Index format: yymmdd'
|
2012-11-20 17:53:53 +00:00
|
|
|
|
|
|
|
|
|
|
|
class Shortpacked(_BasicScraper):
|
|
|
|
latestUrl = 'http://www.shortpacked.com/'
|
|
|
|
stripUrl = latestUrl + 'd/%s.html'
|
2012-11-21 20:57:26 +00:00
|
|
|
imageSearch = compile(tagre("img", "src", r'(http://www\.shortpacked\.com/comics/[^"]+)'))
|
|
|
|
prevSearch = compile(tagre("a", "href", r'(http://www\.shortpacked\.com/\d+/comic/[^"]+)', after="prev"))
|
2012-11-20 17:53:53 +00:00
|
|
|
help = 'Index format: yyyymmdd'
|
|
|
|
|
|
|
|
|
2012-06-20 19:58:13 +00:00
|
|
|
class SinFest(_BasicScraper):
|
|
|
|
name = 'KeenSpot/SinFest'
|
|
|
|
latestUrl = 'http://www.sinfest.net/'
|
2012-11-20 17:53:53 +00:00
|
|
|
stripUrl = latestUrl + 'archive_page.php?comicID=%s'
|
2012-06-20 19:58:13 +00:00
|
|
|
imageSearch = compile(r'<img src=".+?(/comikaze/comics/.+?)"')
|
|
|
|
prevSearch = compile(r'(/archive_page.php\?comicID=.+?)".+?prev_a')
|
|
|
|
help = 'Index format: n (unpadded)'
|
|
|
|
|
|
|
|
|
|
|
|
class SlightlyDamned(_BasicScraper):
|
2012-11-21 20:57:26 +00:00
|
|
|
latestUrl = 'http://www.sdamned.com/'
|
|
|
|
stripUrl = latestUrl + '%s/'
|
|
|
|
imageSearch = compile(tagre("img", "src", r'(http://www\.sdamned\.com/comics/[^"]+)'))
|
|
|
|
prevSearch = compile(tagre("a", "href", r'(http://www\.sdamned\.com/[^"]+)', after="prev"))
|
|
|
|
help = 'Index format: yyyy/mm/number'
|
2012-06-20 19:58:13 +00:00
|
|
|
|
|
|
|
|
|
|
|
class SluggyFreelance(_BasicScraper):
|
|
|
|
latestUrl = 'http://www.sluggy.com/'
|
2012-11-20 17:53:53 +00:00
|
|
|
stripUrl = latestUrl + 'comics/archives/daily/%s'
|
2012-06-20 19:58:13 +00:00
|
|
|
imageSearch = compile(r'<img src="(/images/comics/.+?)"')
|
|
|
|
prevSearch = compile(r'<a href="(.+?)"[^>]+?><span class="ui-icon ui-icon-seek-prev">')
|
|
|
|
help = 'Index format: yymmdd'
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class SodiumEyes(_BasicScraper):
|
2012-11-21 20:57:26 +00:00
|
|
|
latestUrl = 'http://sodiumeyes.com/'
|
|
|
|
stripUrl = latestUrl + '%s/'
|
|
|
|
imageSearch = compile(tagre("img", "src", r'(http://sodiumeyes\.com/comic/[^"]+)'))
|
|
|
|
prevSearch = compile(tagre("a", "href", r'(http://sodiumeyes\.com/[^"]+)', after="prev"))
|
|
|
|
help = 'Index format: yyyy/mm/dd/stripname'
|
2012-06-20 19:58:13 +00:00
|
|
|
|
|
|
|
|
|
|
|
class SpareParts(_BasicScraper):
|
2012-11-21 20:57:26 +00:00
|
|
|
baseUrl = 'http://www.sparepartscomics.com/'
|
|
|
|
latestUrl = baseUrl + 'comics/?date=20080328'
|
|
|
|
stripUrl = baseUrl + 'comics/?date=s%'
|
|
|
|
imageSearch = compile(tagre("img", "src", r'http://www\.sparepartscomics\.com/comics/[^"]+'))
|
|
|
|
prevSearch = compile(tagre("a", "href", r'(index\.php\?date=\d+)') + "Previous Comic")
|
2012-11-20 17:53:53 +00:00
|
|
|
help = 'Index format: yyyymmdd'
|
|
|
|
|
2012-06-20 19:58:13 +00:00
|
|
|
|
|
|
|
class Stubble(_BasicScraper):
|
2012-11-21 20:57:26 +00:00
|
|
|
latestUrl = 'http://stubblecomics.com/'
|
|
|
|
stripUrl = latestUrl + '?p=%s'
|
|
|
|
imageSearch = compile(tagre("img", "src", r'(http://stubblecomics\.com/comics/[^"]+)'))
|
|
|
|
prevSearch = compile(tagre("a", "href", r'(http://stubblecomics\.com/\?p=\d+)', after="navi-prev"))
|
|
|
|
help = 'Index format: number'
|
2012-06-20 19:58:13 +00:00
|
|
|
|
|
|
|
|
|
|
|
class StrawberryDeathCake(_BasicScraper):
|
2012-11-21 20:57:26 +00:00
|
|
|
latestUrl = 'http://strawberrydeathcake.com/'
|
|
|
|
stripUrl = latestUrl + 'archive/%s/'
|
|
|
|
imageSearch = compile(tagre("img", "src", r'http://strawberrydeathcake\.com/wp-content/webcomic/[^"]+'))
|
|
|
|
prevSearch = compile(tagre("a", "href", r'(http://strawberrydeathcake\.com/archive/[^"]+)', after="previous"))
|
|
|
|
help = 'Index format: stripname'
|
2012-06-20 19:58:13 +00:00
|
|
|
|
|
|
|
|
|
|
|
class SuburbanTribe(_BasicScraper):
|
|
|
|
latestUrl = 'http://www.pixelwhip.com/'
|
2012-11-21 20:57:26 +00:00
|
|
|
stripUrl = latestUrl + '?p=%s'
|
|
|
|
imageSearch = compile(tagre("img", "src", r'(http://www\.pixelwhip\.com/comics/[^"]+)'))
|
|
|
|
prevSearch = compile(tagre("a", "href", r'(http://www\.pixelwhip\.com/\?p=\d+)', after="prev"))
|
2012-06-20 19:58:13 +00:00
|
|
|
help = 'Index format: nnnn'
|
|
|
|
|
|
|
|
|
|
|
|
class SomethingPositive(_BasicScraper):
|
|
|
|
latestUrl = 'http://www.somethingpositive.net/'
|
2012-11-20 17:53:53 +00:00
|
|
|
stripUrl = latestUrl + 'sp%s.shtml'
|
2012-11-21 20:57:26 +00:00
|
|
|
imageSearch = compile(tagre("img", "src", r'(sp\d+\.png)'))
|
|
|
|
prevSearch = compile(tagre("a", "href", r'(sp\d+\.shtml)') + "Previous")
|
2012-06-20 19:58:13 +00:00
|
|
|
help = 'Index format: mmddyyyy'
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def namer(cls, imageUrl, pageUrl):
|
|
|
|
return pageUrl.split('/')[-1].split('.')[0]
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class SexyLosers(_BasicScraper):
|
2012-11-13 18:10:19 +00:00
|
|
|
stripUrl = 'http://www.sexylosers.com/%s.html'
|
2012-06-20 19:58:13 +00:00
|
|
|
imageSearch = compile(r'<img src\s*=\s*"\s*(comics/[\w\.]+?)"', IGNORECASE)
|
|
|
|
prevSearch = compile(r'<a href="(/\d{3}\.\w+?)"><font color = FFAAAA><<', IGNORECASE)
|
|
|
|
help = 'Index format: nnn'
|
|
|
|
starter = indirectStarter('http://www.sexylosers.com/',
|
|
|
|
compile(r'SEXY LOSERS <A HREF="(.+?)">Latest SL Comic \(#\d+\)</A>', IGNORECASE))
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def namer(cls, imageUrl, pageUrl):
|
|
|
|
index = pageUrl.split('/')[-1].split('.')[0]
|
|
|
|
title = imageUrl.split('/')[-1].split('.')[0]
|
|
|
|
return index + '-' + title
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class StarCrossdDestiny(_BasicScraper):
|
|
|
|
latestUrl = 'http://www.starcrossd.net/comic.html'
|
2012-11-13 18:10:19 +00:00
|
|
|
stripUrl = 'http://www.starcrossd.net/archives/%s.html'
|
2012-06-20 19:58:13 +00:00
|
|
|
imageSearch = compile(r'<img src="(http://www\.starcrossd\.net/(?:ch1|strips|book2)/[^"]+)">')
|
|
|
|
prevSearch = compile(r'<a href="(http://www\.starcrossd\.net/(?:ch1/)?archives/\d+\.html)"[^>]*"[^"]*"[^>]*>prev', IGNORECASE)
|
|
|
|
help = 'Index format: nnnnnnnn'
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def namer(cls, imageUrl, pageUrl):
|
|
|
|
if imageUrl.find('ch1') == -1:
|
|
|
|
# At first all images were stored in a strips/ directory but that was changed with the introduction of book2
|
|
|
|
imageUrl = sub('(?:strips)|(?:images)','book1',imageUrl)
|
|
|
|
elif not imageUrl.find('strips') == -1:
|
|
|
|
imageUrl = imageUrl.replace('strips/','')
|
|
|
|
directory, filename = imageUrl.split('/')[-2:]
|
|
|
|
filename, extension = splitext(filename)
|
|
|
|
return directory + '-' + filename
|
|
|
|
|
|
|
|
|
|
|
|
class Spamusement(_BasicScraper):
|
2012-11-13 18:10:19 +00:00
|
|
|
stripUrl = 'http://spamusement.com/index.php/comics/view/%s'
|
2012-06-20 19:58:13 +00:00
|
|
|
imageSearch = compile(r'<img src="(http://spamusement.com/gfx/\d+\..+?)"', IGNORECASE)
|
|
|
|
prevSearch = compile(r'<a href="(http://spamusement.com/index.php/comics/view/.+?)">', IGNORECASE)
|
|
|
|
help = 'Index format: n (unpadded)'
|
|
|
|
|
|
|
|
starter = indirectStarter('http://spamusement.com/', prevSearch)
|
|
|
|
|
|
|
|
|
|
|
|
class StrangeCandy(_BasicScraper):
|
|
|
|
latestUrl = 'http://www.strangecandy.net/'
|
2012-11-20 17:53:53 +00:00
|
|
|
stripUrl = latestUrl + 'd/%s.html'
|
2012-11-21 20:57:26 +00:00
|
|
|
imageSearch = compile(tagre("img", "src", r'(/comics/\d+\.jpg)'))
|
|
|
|
prevSearch = compile(tagre("a", "href", r'(/d/\d+\.html)') + tagre("img", "alt", "Previous comic"))
|
2012-06-20 19:58:13 +00:00
|
|
|
help = 'Index format: yyyyddmm'
|
|
|
|
|
|
|
|
|
|
|
|
class SMBC(_BasicScraper):
|
|
|
|
latestUrl = 'http://www.smbc-comics.com/'
|
2012-11-20 17:53:53 +00:00
|
|
|
stripUrl = latestUrl + 'index.php?db=comics&id=%s'
|
2012-06-20 19:58:13 +00:00
|
|
|
imageSearch = compile(r'<img src=\'(.+?\d{8}.\w{1,4})\'>')
|
|
|
|
prevSearch = compile(r'131,13,216,84"\n\s+href="(.+?)#comic"\n>', MULTILINE)
|
|
|
|
help = 'Index format: nnnn'
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class SomethingLikeLife(_BasicScraper):
|
|
|
|
latestUrl = 'http://www.pulledpunches.com/'
|
2012-11-20 17:53:53 +00:00
|
|
|
stripUrl = latestUrl + '?p=%s'
|
2012-06-20 19:58:13 +00:00
|
|
|
imageSearch = compile(r'<img src="(http://www.pulledpunches.com/comics/[^"]*)"')
|
|
|
|
prevSearch = compile(r'</a> <a href="(http://www.pulledpunches.com/\?p=[^"]*)"><img src="back1.gif"')
|
|
|
|
help = 'Index format: nn'
|