# -*- coding: utf-8 -*- """ pygments.sphinxext ~~~~~~~~~~~~~~~~~~ Sphinx extension to generate automatic documentation of lexers, formatters and filters. :copyright: Copyright 2006-2017 by the Pygments team, see AUTHORS. :license: BSD, see LICENSE for details. """ from __future__ import print_function import sys from docutils import nodes from docutils.statemachine import ViewList from sphinx.util.compat import Directive from sphinx.util.nodes import nested_parse_with_titles MODULEDOC = ''' .. module:: %s %s %s ''' LEXERDOC = ''' .. class:: %s :Short names: %s :Filenames: %s :MIME types: %s %s ''' FMTERDOC = ''' .. class:: %s :Short names: %s :Filenames: %s %s ''' FILTERDOC = ''' .. class:: %s :Name: %s %s ''' class PygmentsDoc(Directive): """ A directive to collect all lexers/formatters/filters and generate autoclass directives for them. """ has_content = False required_arguments = 1 optional_arguments = 0 final_argument_whitespace = False option_spec = {} def run(self): self.filenames = set() if self.arguments[0] == 'lexers': out = self.document_lexers() elif self.arguments[0] == 'formatters': out = self.document_formatters() elif self.arguments[0] == 'filters': out = self.document_filters() else: raise Exception('invalid argument for "pygmentsdoc" directive') node = nodes.compound() vl = ViewList(out.split('\n'), source='') nested_parse_with_titles(self.state, vl, node) for fn in self.filenames: self.state.document.settings.record_dependencies.add(fn) return node.children def document_lexers(self): from pygments.lexers._mapping import LEXERS out = [] modules = {} moduledocstrings = {} for classname, data in sorted(LEXERS.items(), key=lambda x: x[0]): module = data[0] mod = __import__(module, None, None, [classname]) self.filenames.add(mod.__file__) cls = getattr(mod, classname) if not cls.__doc__: print("Warning: %s does not have a docstring." % classname) docstring = cls.__doc__ if isinstance(docstring, bytes): docstring = docstring.decode('utf8') modules.setdefault(module, []).append(( classname, ', '.join(data[2]) or 'None', ', '.join(data[3]).replace('*', '\\*').replace('_', '\\') or 'None', ', '.join(data[4]) or 'None', docstring)) if module not in moduledocstrings: moddoc = mod.__doc__ if isinstance(moddoc, bytes): moddoc = moddoc.decode('utf8') moduledocstrings[module] = moddoc for module, lexers in sorted(modules.items(), key=lambda x: x[0]): if moduledocstrings[module] is None: raise Exception("Missing docstring for %s" % (module,)) heading = moduledocstrings[module].splitlines()[4].strip().rstrip('.') out.append(MODULEDOC % (module, heading, '-'*len(heading))) for data in lexers: out.append(LEXERDOC % data) return ''.join(out) def document_formatters(self): from pygments.formatters import FORMATTERS out = [] for classname, data in sorted(FORMATTERS.items(), key=lambda x: x[0]): module = data[0] mod = __import__(module, None, None, [classname]) self.filenames.add(mod.__file__) cls = getattr(mod, classname) docstring = cls.__doc__ if isinstance(docstring, bytes): docstring = docstring.decode('utf8') heading = cls.__name__ out.append(FMTERDOC % (heading, ', '.join(data[2]) or 'None', ', '.join(data[3]).replace('*', '\\*') or 'None', docstring)) return ''.join(out) def document_filters(self): from pygments.filters import FILTERS out = [] for name, cls in FILTERS.items(): self.filenames.add(sys.modules[cls.__module__].__file__) docstring = cls.__doc__ if isinstance(docstring, bytes): docstring = docstring.decode('utf8') out.append(FILTERDOC % (cls.__name__, name, docstring)) return ''.join(out) def setup(app): app.add_directive('pygmentsdoc', PygmentsDoc)
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
filters | Folder | 0755 |
|
|
formatters | Folder | 0755 |
|
|
lexers | Folder | 0755 |
|
|
styles | Folder | 0755 |
|
|
__init__.py | File | 3.07 KB | 0644 |
|
__init__.pyc | File | 3.42 KB | 0644 |
|
cmdline.py | File | 18.87 KB | 0644 |
|
cmdline.pyc | File | 14.11 KB | 0644 |
|
console.py | File | 1.77 KB | 0644 |
|
console.pyc | File | 2.27 KB | 0644 |
|
filter.py | File | 1.99 KB | 0644 |
|
filter.pyc | File | 3.11 KB | 0644 |
|
formatter.py | File | 2.88 KB | 0644 |
|
formatter.pyc | File | 3.35 KB | 0644 |
|
lexer.py | File | 30.33 KB | 0644 |
|
lexer.pyc | File | 28.3 KB | 0644 |
|
modeline.py | File | 1010 B | 0644 |
|
modeline.pyc | File | 1.34 KB | 0644 |
|
plugin.py | File | 1.68 KB | 0644 |
|
plugin.pyc | File | 2.33 KB | 0644 |
|
regexopt.py | File | 3.02 KB | 0644 |
|
regexopt.pyc | File | 3.15 KB | 0644 |
|
scanner.py | File | 3.05 KB | 0644 |
|
scanner.pyc | File | 4.08 KB | 0644 |
|
sphinxext.py | File | 4.55 KB | 0644 |
|
sphinxext.pyc | File | 5.46 KB | 0644 |
|
style.py | File | 4.69 KB | 0644 |
|
style.pyc | File | 4.68 KB | 0644 |
|
token.py | File | 6.02 KB | 0644 |
|
token.pyc | File | 5.53 KB | 0644 |
|
unistring.py | File | 49.95 KB | 0644 |
|
unistring.pyc | File | 26.58 KB | 0644 |
|
util.py | File | 11.62 KB | 0644 |
|
util.pyc | File | 12.69 KB | 0644 |
|