X-Git-Url: https://git.phdru.name/?a=blobdiff_plain;f=reindex_blog.py;h=3a189657b581de59c5bbaf373acfb8a371bdde60;hb=91febbbbaed6330bf64dd711f4d4a101501b8126;hp=da9f07ae7f4c60290bdcc5f16c3a01b1bc7b7480;hpb=58d26948376ba044380c5259a1fe6286b438e44e;p=phdru.name%2Fphdru.name.git diff --git a/reindex_blog.py b/reindex_blog.py index da9f07a..3a18965 100755 --- a/reindex_blog.py +++ b/reindex_blog.py @@ -53,7 +53,7 @@ for dirpath, dirs, files in os.walk(blog_root): title = ' '.join(title_parts[6:]) lead = getattr(template, "Lead", None) - tags = getattr(template, "Tag", None) + tags = template.Tag if isinstance(tags, basestring): tags = (tags,) @@ -127,6 +127,9 @@ def write_template(level, year, month, day, titles, tags=None): #attr $Title = "Oleg BroytMann's blog" #attr $Description = "BroytMann Russian Blog Index Document" #attr $Copyright = %(cyear)s +#attr $alternates = (("application/atom+xml", "News [Atom 1.0]", "atom_10.xml"), + ("application/rss+xml", "News [RSS 2.0]", "rss_20.xml") +) ## #def body_html

öÕÒÎÁÌ

@@ -217,13 +220,20 @@ def write_template(level, year, month, day, titles, tags=None): ''' % (lead, href, title)) if level == 0: + new_text.append(""" +
+ +

îÏ×ÏÓÔÅ×ÁÑ ÌÅÎÔÁ × ÆÏÒÍÁÔÁÈ +Atom 1.0 RSS 2.0 . +

+""") + years = {} for year, month, day, file, title, lead in save_titles: years[year] = True new_text.append(''' -
- -

ôÅÇÉ: +

ôÅÇÉ: ''') first_tag = True for count, tag, links in all_tags: @@ -237,7 +247,7 @@ def write_template(level, year, month, day, titles, tags=None): ''') new_text.append(''' -

ðÏ ÇÏÄÁÍ: +

ðÏ ÇÏÄÁÍ: ''') first_year = True for year in sorted(years.keys()): @@ -250,6 +260,11 @@ def write_template(level, year, month, day, titles, tags=None):

''') + new_text.append(""" +
+

öö +""") + new_text.append("""\ #end def $phd_pp_ru.respond(self) @@ -258,8 +273,9 @@ $phd_pp_ru.respond(self) write_if_changed(index_name, ''.join(new_text)) -all_titles = [] all_tags = {} +all_titles = [] +all_titles_tags = [] for year in sorted(years.keys()): year_titles = [] @@ -273,6 +289,7 @@ for year in sorted(years.keys()): for file, title, lead, tags in blog[key]: if file.endswith(".tmpl"): file = file[:-len("tmpl")] + "html" value = (year, month, day, file, title, lead) + all_titles_tags.append((year, month, day, file, title, lead, tags)) all_titles.append(value) year_titles.append(value) month_titles.append(value) @@ -287,8 +304,17 @@ for year in sorted(years.keys()): write_template(2, year, month, day, month_titles) write_template(1, year, month, day, year_titles) +def by_count_rev_tag_link(t1, t2): + """Sort all_tags by count in descending order, + and by tags and links in ascending order + """ + r = cmp(t1[0], t2[0]) + if r: + return -r + return cmp((t1[1], t1[2]), (t2[1], t2[2])) + all_tags = [(len(links), tag, links) for (tag, links) in all_tags.items()] -all_tags.sort() +all_tags.sort(by_count_rev_tag_link) write_template(0, year, month, day, all_titles[-20:], all_tags) @@ -357,3 +383,46 @@ new_text.append("""\ $phd_pp_ru.respond(self) """) write_if_changed(os.path.join(blog_root, "tags", "index.tmpl"), ''.join(new_text)) + + +from atom_10 import atom_10 +from rss_20 import rss_20 +from news import NewsItem + +baseURL = "http://phd.pp.ru/Russian/blog/" + +items = [] +for item in tuple(reversed(all_titles_tags))[:10]: + year, month, day, file, title, lead, tags = item + if lead: + lead = lead + ' ' + else: + lead = '' + item = NewsItem( + "%s-%s-%s" % (year, month, day), + "%s%s" % (lead, title), + "%s/%s/%s/%s" % (year, month, day, file) + ) + items.append(item) + item.baseURL = baseURL + item.categoryList = tags + +namespace = { + "title": "Oleg Broytmann's blog", + "baseURL": baseURL, + "indexFile": "", + "description": "", + "lang": "ru", + "author": "Oleg Broytmann", + "email": "phd@phd.pp.ru", + "generator": os.path.basename(sys.argv[0]), + "posts": items, +} + +# For english dates +locale.setlocale(locale.LC_TIME, 'C') + +atom_tmpl = str(atom_10(searchList=[namespace])) +write_if_changed(os.path.join(blog_root, "atom_10.xml"), atom_tmpl) +rss_tmpl = str(rss_20(searchList=[namespace])) +write_if_changed(os.path.join(blog_root, "rss_20.xml"), rss_tmpl)