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) +