| Martin v. Löwis | 5680d0c | 2008-04-10 03:06:53 +0000 | [diff] [blame] | 1 | # -*- coding: utf-8 -*- | 
|  | 2 | """ | 
|  | 3 | pyspecific.py | 
|  | 4 | ~~~~~~~~~~~~~ | 
|  | 5 |  | 
|  | 6 | Sphinx extension with Python doc-specific markup. | 
|  | 7 |  | 
|  | 8 | :copyright: 2008 by Georg Brandl. | 
|  | 9 | :license: Python license. | 
|  | 10 | """ | 
|  | 11 |  | 
|  | 12 | ISSUE_URI = 'http://bugs.python.org/issue%s' | 
|  | 13 |  | 
|  | 14 | from docutils import nodes, utils | 
|  | 15 |  | 
|  | 16 | def issue_role(typ, rawtext, text, lineno, inliner, options={}, content=[]): | 
|  | 17 | issue = utils.unescape(text) | 
|  | 18 | text = 'issue ' + issue | 
|  | 19 | refnode = nodes.reference(text, text, refuri=ISSUE_URI % issue) | 
|  | 20 | return [refnode], [] | 
|  | 21 |  | 
|  | 22 |  | 
| Georg Brandl | 6b38daa | 2008-06-01 21:05:17 +0000 | [diff] [blame] | 23 | # Support for building "topic help" for pydoc | 
|  | 24 |  | 
|  | 25 | pydoc_topic_labels = [ | 
|  | 26 | 'assert', 'assignment', 'atom-identifiers', 'atom-literals', | 
|  | 27 | 'attribute-access', 'attribute-references', 'augassign', 'binary', | 
|  | 28 | 'bitwise', 'bltin-code-objects', 'bltin-ellipsis-object', | 
|  | 29 | 'bltin-file-objects', 'bltin-null-object', 'bltin-type-objects', 'booleans', | 
|  | 30 | 'break', 'callable-types', 'calls', 'class', 'comparisons', 'compound', | 
|  | 31 | 'context-managers', 'continue', 'conversions', 'customization', 'debugger', | 
|  | 32 | 'del', 'dict', 'dynamic-features', 'else', 'exceptions', 'execmodel', | 
|  | 33 | 'exprlists', 'floating', 'for', 'formatstrings', 'function', 'global', | 
|  | 34 | 'id-classes', 'identifiers', 'if', 'imaginary', 'import', 'in', 'integers', | 
|  | 35 | 'lambda', 'lists', 'naming', 'numbers', 'numeric-types', 'objects', | 
|  | 36 | 'operator-summary', 'pass', 'power', 'raise', 'return', 'sequence-types', | 
|  | 37 | 'shifting', 'slicings', 'specialattrs', 'specialnames', 'string-methods', | 
|  | 38 | 'strings', 'subscriptions', 'truth', 'try', 'types', 'typesfunctions', | 
|  | 39 | 'typesmapping', 'typesmethods', 'typesmodules', 'typesseq', | 
|  | 40 | 'typesseq-mutable', 'unary', 'while', 'with', 'yield' | 
|  | 41 | ] | 
|  | 42 |  | 
|  | 43 | from os import path | 
|  | 44 | from time import asctime | 
|  | 45 | from pprint import pformat | 
|  | 46 | from docutils.io import StringOutput | 
|  | 47 | from docutils.utils import new_document | 
| Benjamin Peterson | 6e43fb1 | 2008-12-21 00:16:13 +0000 | [diff] [blame^] | 48 |  | 
|  | 49 | try: | 
|  | 50 | from sphinx.builders import Builder | 
|  | 51 | except ImportError: | 
|  | 52 | from sphinx.builder import Builder | 
| Georg Brandl | db6f108 | 2008-12-01 23:02:51 +0000 | [diff] [blame] | 53 |  | 
|  | 54 | try: | 
|  | 55 | from sphinx.writers.text import TextWriter | 
|  | 56 | except ImportError: | 
|  | 57 | from sphinx.textwriter import TextWriter | 
| Georg Brandl | 6b38daa | 2008-06-01 21:05:17 +0000 | [diff] [blame] | 58 |  | 
|  | 59 | class PydocTopicsBuilder(Builder): | 
|  | 60 | name = 'pydoc-topics' | 
|  | 61 |  | 
|  | 62 | def init(self): | 
|  | 63 | self.topics = {} | 
|  | 64 |  | 
|  | 65 | def get_outdated_docs(self): | 
|  | 66 | return 'all pydoc topics' | 
|  | 67 |  | 
|  | 68 | def get_target_uri(self, docname, typ=None): | 
|  | 69 | return ''  # no URIs | 
|  | 70 |  | 
|  | 71 | def write(self, *ignored): | 
|  | 72 | writer = TextWriter(self) | 
|  | 73 | for label in self.status_iterator(pydoc_topic_labels, 'building topics... '): | 
|  | 74 | if label not in self.env.labels: | 
|  | 75 | self.warn('label %r not in documentation' % label) | 
|  | 76 | continue | 
|  | 77 | docname, labelid, sectname = self.env.labels[label] | 
|  | 78 | doctree = self.env.get_and_resolve_doctree(docname, self) | 
|  | 79 | document = new_document('<section node>') | 
|  | 80 | document.append(doctree.ids[labelid]) | 
|  | 81 | destination = StringOutput(encoding='utf-8') | 
|  | 82 | writer.write(document, destination) | 
|  | 83 | self.topics[label] = str(writer.output) | 
|  | 84 |  | 
|  | 85 | def finish(self): | 
|  | 86 | f = open(path.join(self.outdir, 'pydoc_topics.py'), 'w') | 
|  | 87 | try: | 
|  | 88 | f.write('# Autogenerated by Sphinx on %s\n' % asctime()) | 
|  | 89 | f.write('topics = ' + pformat(self.topics) + '\n') | 
|  | 90 | finally: | 
|  | 91 | f.close() | 
|  | 92 |  | 
|  | 93 |  | 
| Georg Brandl | f0dd6a6 | 2008-07-23 15:19:11 +0000 | [diff] [blame] | 94 | # Support for documenting Opcodes | 
|  | 95 |  | 
|  | 96 | import re | 
|  | 97 | from sphinx import addnodes | 
|  | 98 |  | 
|  | 99 | opcode_sig_re = re.compile(r'(\w+(?:\+\d)?)\s*\((.*)\)') | 
|  | 100 |  | 
|  | 101 | def parse_opcode_signature(env, sig, signode): | 
|  | 102 | """Transform an opcode signature into RST nodes.""" | 
|  | 103 | m = opcode_sig_re.match(sig) | 
|  | 104 | if m is None: | 
|  | 105 | raise ValueError | 
|  | 106 | opname, arglist = m.groups() | 
|  | 107 | signode += addnodes.desc_name(opname, opname) | 
|  | 108 | paramlist = addnodes.desc_parameterlist() | 
|  | 109 | signode += paramlist | 
|  | 110 | paramlist += addnodes.desc_parameter(arglist, arglist) | 
|  | 111 | return opname.strip() | 
|  | 112 |  | 
|  | 113 |  | 
| Martin v. Löwis | 5680d0c | 2008-04-10 03:06:53 +0000 | [diff] [blame] | 114 | def setup(app): | 
|  | 115 | app.add_role('issue', issue_role) | 
| Georg Brandl | 6b38daa | 2008-06-01 21:05:17 +0000 | [diff] [blame] | 116 | app.add_builder(PydocTopicsBuilder) | 
| Georg Brandl | f0dd6a6 | 2008-07-23 15:19:11 +0000 | [diff] [blame] | 117 | app.add_description_unit('opcode', 'opcode', '%s (opcode)', | 
|  | 118 | parse_opcode_signature) |