X-Git-Url: https://git.phdru.name/?a=blobdiff_plain;f=phd_pp.py;fp=phd_pp.py;h=0000000000000000000000000000000000000000;hb=42465be8abac2fdb32c939bc7e5ad0fbca5df2f8;hp=d4b2e3211747d7ba54f11aecfa50c7cfc4e9ce52;hpb=5f9cc4c82b2cb603968c843ea3a37c9aad82d4e6;p=phdru.name%2Fphdru.name.git diff --git a/phd_pp.py b/phd_pp.py deleted file mode 100644 index d4b2e32..0000000 --- a/phd_pp.py +++ /dev/null @@ -1,112 +0,0 @@ -import os, re, time, urllib -from Cheetah.Template import Template - - -url_re = r"(((https?|ftp|gopher|telnet)://|(mailto|file|news|about|ed2k|irc|sip|magnet):)[^' \t<>\"]+|(www|web|w3)[A-Za-z0-9_-]*\.[A-Za-z0-9._-]+\.[^' \t<>\"]+)[A-Za-z0-9/]" - -def _url2href(match): - url = match.group(0) - return '%s' % (url, url) - - -full_dirs = len(os.getcwd().split('/')) + 1 - -class phd_pp(Template): - def __init__(self, *args, **kw): - if not hasattr(self, "_fileBaseName"): - self._fileDirName, self._fileBaseName = os.path.split(os.path.abspath(self._CHEETAH_src)) - Template.__init__(self, *args, **kw) - directories = self._fileDirName.split('/')[full_dirs:] # remove directories up to "./files" - dirs_to_root = len(directories) - if dirs_to_root: - root = "../"*dirs_to_root - else: - root = '' - self.root = root - path = '/'.join(directories) + '/' + \ - self._fileBaseName.replace(".tmpl", ".html") - if path[0] <> '/': path = '/' + path - self.path = path - - def copyright(self, start_year): - this_year = time.localtime()[0] - if start_year >= this_year: - return this_year - if start_year == this_year - 1: - return "%s, %s" % (start_year, this_year) - return "%s-%s" % (start_year, this_year) - - - def body(self): - if hasattr(self, "body_html"): - return self.body_html() - if hasattr(self, "body_text"): - return self.text2html() - if hasattr(self, "body_rst"): - return self.rst2html() - - def text2html(self): - body = re.sub(url_re, _url2href, self.body_text()) - - paragraphs = body.split("\n\n") - - new_paras = [] - for p in paragraphs: - parts = p.split("\n ") - parts[0] = parts[0].strip() - new_paras.append('\n

\n

\n'.join(parts)) - - if self.Title: - title = "

%s

\n\n" % self.Title - else: - title = '' - - body = '\n

\n\n

\n'.join(new_paras) - return "%s

%s

" % (title, body) - - def rst2html(self): - from docutils.core import publish_parts - from m_lib.defenc import default_encoding as encoding - - parts = publish_parts(self.body_rst(), writer_name="html") - - title = parts["title"].encode(encoding) or self.Title - if title: - title = "

%s

" % title - - subtitle = parts["subtitle"].encode(encoding) - if subtitle: - subtitle = "

%s

" % subtitle - - body = parts["body"].encode(encoding) - parts = [part for part in (title, subtitle, body) if part] - return "\n\n".join(parts) - - - def img_thumbnail_800_1024(self, img_name): - return """\ -%(img_name)s-thumbnail.jpg
-800x600, 1024x800""" % {"img_name": img_name} - - def wikipedia(self, query): - return "http://en.wikipedia.org/wiki/%s" % quote_string(query.replace(' ', '_'), ext_safe=',') - - def wikipedia_ru(self, query): - return "http://ru.wikipedia.org/wiki/%s" % quote_string(query.replace(' ', '_'), ext_safe=',') - - def nigma(self, query): - return "http://www.nigma.ru/index.php?s=%s" % quote_string(query) - - search = nigma - - def yandex(self, query): - return "http://www.yandex.ru/yandsearch?text=%s&rpt=rad" % quote_string(query, "cp1251") - - def google(self, query): - return "http://www.google.com/search?hl=en&ie=utf-8&oe=utf-8&q=%s" % quote_string(query) - - def google_ru(self, query): - return "http://www.google.ru/search?hl=ru&ie=utf-8&oe=utf-8&q=%s" % quote_string(query) - -def quote_string(s, to_encoding="utf-8", ext_safe=''): - return urllib.quote(unicode(s, "koi8-r").encode(to_encoding), '/' + ext_safe)