support quality and lang

This commit is contained in:
Romain Bignon 2010-08-13 11:16:48 +02:00
commit 700d77596a
2 changed files with 23 additions and 5 deletions

View file

@ -29,15 +29,27 @@ __all__ = ['ArteBrowser']
class ArteBrowser(BaseBrowser):
DOMAIN = u'videos.arte.tv'
ENCODING = None
PAGES = {r'http://videos.arte.tv/fr/videos/arte7.*': IndexPage,
r'http://videos.arte.tv/fr/do_search/videos/recherche.*': IndexPage,
r'http://videos.arte.tv/fr/videos/(?P<id>.+)\.html': VideoPage
PAGES = {r'http://videos.arte.tv/%(lang)s/videos/arte7.*': IndexPage,
r'http://videos.arte.tv/%(lang)s/do_search/videos/%(searchlang)s.*': IndexPage,
r'http://videos.arte.tv/%(lang)s/videos/(?P<id>.+)\.html': VideoPage
}
SEARCH_LANG = {'fr': 'recherche', 'de':'suche', 'en': 'search'}
def __init__(self, lang, quality, *args, **kwargs):
last_pages = self.PAGES
self.PAGES = {}
for url, page in last_pages.iteritems():
self.PAGES[url % {'lang': lang, 'searchlang': self.SEARCH_LANG[lang]}] = page
BaseBrowser.__init__(self, *args, **kwargs)
self.lang = lang
self.quality = quality
@id2url(ArteVideo.id2url)
def get_video(self, url, video=None):
self.location(url)
return self.page.get_video(video)
return self.page.get_video(video, self.lang, self.quality)
def home(self):
self.location('http://videos.arte.tv/fr/videos/arte7')
@ -46,6 +58,6 @@ class ArteBrowser(BaseBrowser):
if not pattern:
self.home()
else:
self.location(self.buildurl('/fr/do_search/videos/recherche', q=pattern))
self.location(self.buildurl('/%s/do_search/videos/%s' % (self.lang, self.SEARCH_LANG[self.lang]), q=pattern))
assert self.is_on_page(IndexPage)
return self.page.iter_videos()