use only one file for radios

This commit is contained in:
Romain Bignon 2011-07-12 13:41:28 +02:00
commit b005e9a3ca
9 changed files with 67 additions and 227 deletions

View file

@ -21,20 +21,42 @@
from weboob.capabilities.radio import ICapRadio, Radio, Stream, Emission
from weboob.capabilities.collection import ICapCollection, CollectionNotFound
from weboob.tools.backend import BaseBackend
from .browser import lemouvBrowser
from weboob.tools.browser import BaseBrowser, BasePage
__all__ = ['lemouvBackend']
__all__ = ['LeMouvBackend']
class lemouvBackend(BaseBackend, ICapRadio, ICapCollection):
class XMLinfos(BasePage):
def get_current(self):
try:
for channel in self.parser.select(self.document.getroot(), 'channel'):
title = channel.find('item/song_title').text
artist = channel.find('item/artist_name').text
except AttributeError:
title = "Not defined"
artist = "Not defined"
return unicode(artist).strip(), unicode(title).strip()
class LeMouvBrowser(BaseBrowser):
DOMAIN = u'statique.lemouv.fr'
PAGES = {r'.*/files/rfPlayer/mouvRSS\.xml': XMLinfos}
def get_current(self, radio):
self.location('/files/rfPlayer/mouvRSS.xml')
assert self.is_on_page(XMLinfos)
return self.page.get_current()
class LeMouvBackend(BaseBackend, ICapRadio, ICapCollection):
NAME = 'lemouv'
MAINTAINER = 'Johann Broudin'
EMAIL = 'johann.broudin@6-8.fr'
VERSION = '0.9'
DESCRIPTION = u'The le mouv\' french radio'
LICENCE = 'AGPLv3+'
BROWSER = lemouvBrowser
BROWSER = LeMouvBrowser
_RADIOS = {'lemouv': (u'le mouv\'', u'le mouv', u'http://mp3.live.tv-radio.com/lemouv/all/lemouvhautdebit.mp3')}

View file

@ -1,37 +0,0 @@
# * -*- coding: utf-8 -*-
# Copyright(C) 2011 Johann Broudin
#
# This file is part of weboob.
#
# weboob is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# weboob is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Affero General Public License for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.tools.browser import BaseBrowser
from .pages import XMLinfos
__all__ = ['lemouvBrowser']
class lemouvBrowser(BaseBrowser):
DOMAIN = u'statique.lemouv.fr'
PAGES = {r'.*/files/rfPlayer/mouvRSS\.xml': XMLinfos}
def get_current(self, radio):
self.location('/files/rfPlayer/mouvRSS.xml')
assert self.is_on_page(XMLinfos)
return self.page.get_current()

View file

@ -1,38 +0,0 @@
# * -*- coding: utf-8 -*-
# Copyright(C) 2011 Johann Broudin
#
# This file is part of weboob.
#
# weboob is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# weboob is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Affero General Public License for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with weboob. If not, see <http://www.gnu.org/licenses/>.
from weboob.tools.browser import BasePage
__all__ = ['XMLinfos']
class XMLinfos(BasePage):
def get_current(self):
try:
for channel in self.parser.select(self.document.getroot(), 'channel'):
title = channel.find('item/song_title').text
artist = channel.find('item/artist_name').text
except AttributeError:
title = "Not defined"
artist = "Not defined"
return unicode(artist).strip(), unicode(title).strip()