diff --git a/setup.py b/setup.py
index f472e197d..8c47244b4 100755
--- a/setup.py
+++ b/setup.py
@@ -19,7 +19,7 @@
# The command line script name. Currently set to "markdown_py" so as not to
# conflict with the perl implimentation (which uses "markdown"). We can't use
# "markdown.py" as the default config on some systems will cause the script to
-# try to import itself rather than the library which raised an error.
+# try to import itself rather than the library which will raise an error.
SCRIPT_NAME = 'markdown_py'
class md_install_scripts(install_scripts):
@@ -42,8 +42,22 @@ def run(self):
print ('ERROR: Unable to create %s: %s' % (bat_path, err))
+doc_header = """
+
+
+%(title)s
+
+
+"""
+
+doc_footer = """
+
+
+"""
+
class build_docs(Command):
- """ Build mardkown documentation into html."""
+ """ Build markdown documentation into html."""
description = '"build" documentation (convert markdown text to html)'
@@ -70,6 +84,19 @@ def _get_docs(self):
for file in files:
yield os.path.join(root, file)
+ def _get_page_title(self, path):
+ """ Get page title from file name (and path). """
+ root, ext = os.path.splitext(path)
+ path, name = os.path.split(root)
+ parts = path.split(os.sep)
+ parts = [x.replace('_', ' ').capitalize() for x in parts[1:]]
+ if name.lower() != 'index':
+ parts.append(name.replace('_', ' ').capitalize())
+ if parts:
+ return ' | '.join(parts) + ' — Python Markdown'
+ else:
+ return 'Python Markdown'
+
def run(self):
try:
import markdown
@@ -80,6 +107,7 @@ def run(self):
for doc in self.docs:
outfile, ext = os.path.splitext(doc)
if ext == '.txt':
+ title = self._get_page_title(outfile)
outfile += '.html'
outfile = change_root(self.build_base, outfile)
self.mkpath(os.path.split(outfile)[0])
@@ -87,8 +115,12 @@ def run(self):
if self.verbose:
print ('Converting %s ---> %s' % (doc, outfile))
if not self.dry_run:
+ outfile = open(outfile, 'w')
+ outfile.write(doc_header % {'title': title})
md.convertFile(doc, outfile)
md.reset()
+ outfile.write(doc_footer)
+ outfile.close()
else:
if self.verbose:
print ('Skipping... (%s is newer)' % outfile)
@@ -135,3 +167,4 @@ def run(self):
data['install_requires'] = ['elementtree']
setup(**data)
+