1#!/usr/local/bin/python3.8 2 3__license__ = 'GPL v3' 4__copyright__ = '2009, Darko Miletic <darko.miletic at gmail.com>' 5 6''' 7pressonline.rs 8''' 9 10import re 11from calibre.web.feeds.recipes import BasicNewsRecipe 12from calibre.ebooks.BeautifulSoup import Tag 13 14 15def new_tag(soup, name, attrs=()): 16 impl = getattr(soup, 'new_tag', None) 17 if impl is not None: 18 return impl(name, attrs=dict(attrs)) 19 return Tag(soup, name, attrs=attrs or None) 20 21 22class PressOnline(BasicNewsRecipe): 23 title = 'Press Online' 24 __author__ = 'Darko Miletic' 25 description = 'Press Online portal dnevnih novina Press.Najnovije vesti iz Srbije i sveta,Sport,Dzet Set,Politika,Hronika,Komenteri,Zabava,Slike,Video,Horoskop,Nagradne igre,Kvizovi,Igrice' # noqa 26 publisher = 'Press Publishing group' 27 category = 'news, politics, Serbia' 28 oldest_article = 2 29 max_articles_per_feed = 100 30 no_stylesheets = True 31 encoding = 'utf-8' 32 use_embedded_content = True 33 language = 'sr' 34 35 lang = 'sr-Latn-RS' 36 direction = 'ltr' 37 38 extra_css = '@font-face {font-family: "serif1";src:url(res:///opt/sony/ebook/FONT/tt0011m_.ttf)} body{font-family: serif1, serif} .article_description{font-family: serif1, serif}' # noqa 39 40 conversion_options = { 41 'comment': description, 'tags': category, 'publisher': publisher, 'language': lang, 'pretty_print': True 42 } 43 44 preprocess_regexps = [(re.compile(u'\u0110'), lambda match: u'\u00D0')] 45 46 feeds = [ 47 48 (u'Vesti Dana', u'http://www.pressonline.rs/page/stories/sr.html?view=rss§ionId=37'), 49 (u'Politika', u'http://www.pressonline.rs/page/stories/sr.html?view=rss§ionId=29'), 50 (u'U Fokusu', u'http://www.pressonline.rs/page/stories/sr.html?view=rss§ionId=33'), 51 (u'Globus', u'http://www.pressonline.rs/page/stories/sr.html?view=rss§ionId=40'), 52 (u'Komentar Dana', u'http://www.pressonline.rs/page/stories/sr.html?view=rss§ionId=62'), 53 (u'Hronika', u'http://www.pressonline.rs/page/stories/sr.html?view=rss§ionId=39'), 54 (u'Regioni', u'http://www.pressonline.rs/page/stories/sr.html?view=rss§ionId=56'), 55 (u'Republika Srpska', u'http://www.pressonline.rs/page/stories/sr.html?view=rss§ionId=51'), 56 (u'Beograd', u'http://www.pressonline.rs/page/stories/sr.html?view=rss§ionId=43'), 57 (u'Dzet-Set Svet', u'http://www.pressonline.rs/page/stories/sr.html?view=rss§ionId=41'), 58 (u'Lifestyle', u'http://www.pressonline.rs/page/stories/sr.html?view=rss§ionId=42'), 59 (u'Sport', u'http://www.pressonline.rs/page/stories/sr.html?view=rss§ionId=44'), 60 (u'Press Magazine', u'http://www.pressonline.rs/page/stories/sr.html?view=rss§ionId=63'), 61 (u'Lola', u'http://www.pressonline.rs/page/stories/sr.html?view=rss§ionId=70'), 62 (u'Duplerica', u'http://www.pressonline.rs/page/stories/sr.html?view=rss§ionId=72'), 63 (u'Presspedia', u'http://www.pressonline.rs/page/stories/sr.html?view=rss§ionId=80'), 64 (u'Kolumne', u'http://www.pressonline.rs/page/stories/sr.html?view=rss§ionId=57') 65 ] 66 67 def preprocess_html(self, soup): 68 soup.html['lang'] = self.lang 69 soup.html['dir'] = self.direction 70 mlang = new_tag(soup, 'meta', [ 71 ("http-equiv", "Content-Language"), ("content", self.lang)]) 72 soup.head.insert(0, mlang) 73 return self.adeify_images(soup) 74