X-Git-Url: https://git.phdru.name/?a=blobdiff_plain;f=reindex_blog.py;h=4451baa740e25f20b60be92b3699fc69e4ca2413;hb=b4c1e4de6a50d04c81519eaf3dc440cca1e38da4;hp=cf830d1cb94ced402bf1a9cf3502f3afe439cfc1;hpb=49d4d1d442fc3b3089af1079b74be14fb25a8809;p=phdru.name%2Fphdru.name.git diff --git a/reindex_blog.py b/reindex_blog.py index cf830d1..4451baa 100755 --- a/reindex_blog.py +++ b/reindex_blog.py @@ -30,12 +30,17 @@ else: blog_file.close() -# blog is a dictionary mapping (year, month, day) => (filename, title, lead) +# blog is a dictionary mapping +# (year, month, day) => [list of (file, title, lead, tags)] + blog = {} years = {} # Walk the directory recursively for dirpath, dirs, files in os.walk(os.curdir): + d = os.path.basename(dirpath) + if not d.startswith("20") and not d.isdigit(): + continue for file in files: # Ignore index.tmpl and *.html files; supose all other files are *.tmpl if file == "index.tmpl" or file.endswith(".html"): @@ -46,13 +51,17 @@ for dirpath, dirs, files in os.walk(os.curdir): title = ' '.join(title_parts[6:]) lead = getattr(template, "Lead", None) + tags = getattr(template, "Tag", None) + if isinstance(tags, basestring): + tags = (tags,) + if title: key = year, month, day = tuple(dirpath.split(os.sep)[1:]) if key in blog: days = blog[key] else: days = blog[key] = [] - days.append((file, title, lead)) + days.append((file, title, lead, tags)) if year in years: months = years[year] @@ -92,6 +101,21 @@ months_names_ru0 = ['', " ] +def write_if_changed(filename, new_text): + try: + infile = open(filename, 'r') + old_text = infile.read() + infile.close() + except IOError: + old_text = None + + if old_text <> new_text: + print "Writing", filename + outfile = open(filename, 'w') + outfile.write(new_text) + outfile.close() + + def write_template(level, year, month, day, titles): path = [] if level >= 1: @@ -102,12 +126,6 @@ def write_template(level, year, month, day, titles): path.append(day) path.append("index.tmpl") index_name = os.path.join(*path) - try: - index_tmpl = open(index_name, 'r') - old_text = index_tmpl.read() - index_tmpl.close() - except IOError: - old_text = None new_text = ["""\ ## THIS FILE IS AUTOMATICALLY GENERATED. DO NOT EDIT. @@ -154,6 +172,16 @@ def write_template(level, year, month, day, titles): iday = int(day) imonth = int(month) + new_text.append("""\ +#attr $Next = "%s" +""" % titles[0][3]) + + + if len(titles) == 1: + new_text.append("""\ +#attr $refresh = "0; URL=%s" +""" % titles[0][3]) + new_text.append("""\ #attr $Title = "Oleg BroytMann's blog: %(day)d %(month_abbr_en)s %(year)s" #attr $Description = "BroytMann Russian Blog %(day)d %(month_name_en)s %(year)s Index Document" @@ -172,7 +200,7 @@ def write_template(level, year, month, day, titles): titles.reverse() save_day = None - for year, month, day, filename, title, lead in titles: + for year, month, day, file, title, lead in titles: href = [] if level == 0: href.append(year) @@ -180,7 +208,7 @@ def write_template(level, year, month, day, titles): href.append(month) if level <= 2: href.append(day) - href.append(filename) + href.append(file) href = '/'.join(href) if day[0] == '0': day = day[1:] if save_day <> day: @@ -201,7 +229,7 @@ def write_template(level, year, month, day, titles): if level == 0: years = {} - for year, month, day, filename, title, lead in save_titles: + for year, month, day, file, title, lead in save_titles: years[year] = True first_year = True new_text.append(''' @@ -224,15 +252,12 @@ def write_template(level, year, month, day, titles): $phd_pp_ru.respond(self) """) - new_text = ''.join(new_text) - if old_text <> new_text: - print "Writing", index_name - index_tmpl = open(index_name, 'w') - index_tmpl.write(new_text) - index_tmpl.close() + write_if_changed(index_name, ''.join(new_text)) all_titles = [] +all_tags = {} + for year in sorted(years.keys()): year_titles = [] months = years[year] @@ -242,15 +267,89 @@ for year in sorted(years.keys()): day_titles = [] key = year, month, day if key in blog: - for filename, title, lead in blog[key]: - if filename.endswith(".tmpl"): - filename = filename[:-len("tmpl")] + "html" - value = (year, month, day, filename, title, lead) + 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.append(value) year_titles.append(value) month_titles.append(value) day_titles.append(value) + for tag in tags: + if tag in all_tags: + tag_links = all_tags[tag] + else: + tag_links = all_tags[tag] = [] + tag_links.append(value) write_template(3, year, month, day, day_titles) write_template(2, year, month, day, month_titles) write_template(1, year, month, day, year_titles) write_template(0, year, month, day, all_titles[-20:]) + +all_tags = [(len(links), tag, links) for (tag, links) in all_tags.items()] +all_tags.sort() + +new_text = ["""\ +## THIS FILE IS AUTOMATICALLY GENERATED. DO NOT EDIT. +#extends phd_pp_ru +#implements respond +#attr $Title = "Oleg BroytMann's blog: tags" +#attr $Description = "BroytMann Russian Blog Tags Index Document" +#attr $Copyright = 2006 +## +#def body_html +

ôÅÇÉ

+ +

+

+"""] + +for count, tag, links in all_tags: + new_text.append("""\ +
%s (%d)
+""" % (tag, tag, count)) + + tag_text = ["""\ +## THIS FILE IS AUTOMATICALLY GENERATED. DO NOT EDIT. +#extends phd_pp_ru +#implements respond +#attr $Title = "Oleg BroytMann's blog: tag %s" +#attr $Description = "BroytMann Russian Blog Tag %s Index Document" +#attr $Copyright = 2006 +## +#def body_html +

%s

+ +

+

+

+#end def +$phd_pp_ru.respond(self) +""") + write_if_changed(os.path.join("tags", tag+".tmpl"), ''.join(tag_text)) + +new_text.append("""\ +
+

+#end def +$phd_pp_ru.respond(self) +""") +write_if_changed(os.path.join("tags", "index.tmpl"), ''.join(new_text))