diff options
Diffstat (limited to 'exts/httpdomain/autohttp')
-rw-r--r-- | exts/httpdomain/autohttp/__init__.py | 11 | ||||
-rw-r--r-- | exts/httpdomain/autohttp/bottle.py | 114 | ||||
-rw-r--r-- | exts/httpdomain/autohttp/common.py | 36 | ||||
-rw-r--r-- | exts/httpdomain/autohttp/flask.py | 48 | ||||
-rw-r--r-- | exts/httpdomain/autohttp/flask_base.py | 215 | ||||
-rw-r--r-- | exts/httpdomain/autohttp/flaskqref.py | 80 | ||||
-rw-r--r-- | exts/httpdomain/autohttp/tornado.py | 128 |
7 files changed, 0 insertions, 632 deletions
diff --git a/exts/httpdomain/autohttp/__init__.py b/exts/httpdomain/autohttp/__init__.py deleted file mode 100644 index 95372d4c..00000000 --- a/exts/httpdomain/autohttp/__init__.py +++ /dev/null @@ -1,11 +0,0 @@ -""" - sphinxcontrib.autohttp - ~~~~~~~~~~~~~~~~~~~~~~ - - The sphinx.ext.autodoc-style HTTP API reference builder - for sphinxcontrib.httpdomain. - - :copyright: Copyright 2011 by Hong Minhee - :license: BSD, see LICENSE for details. - -""" diff --git a/exts/httpdomain/autohttp/bottle.py b/exts/httpdomain/autohttp/bottle.py deleted file mode 100644 index d8c18597..00000000 --- a/exts/httpdomain/autohttp/bottle.py +++ /dev/null @@ -1,114 +0,0 @@ -""" - sphinxcontrib.autohttp.bottle - ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ - - The sphinx.ext.autodoc-style HTTP API reference builder (from Bottle) - for sphinxcontrib.httpdomain. - - :copyright: Copyright 2012 by Jameel Al-Aziz - :license: BSD, see LICENSE for details. - -""" - -import re -import six - -from docutils import nodes -from docutils.parsers.rst import directives -from docutils.statemachine import ViewList - -from sphinx.util import force_decode -from sphinx.util.compat import Directive -from sphinx.util.nodes import nested_parse_with_titles -from sphinx.util.docstrings import prepare_docstring -from sphinx.pycode import ModuleAnalyzer - -from sphinxcontrib import httpdomain -from sphinxcontrib.autohttp.common import http_directive, import_object - - -def translate_bottle_rule(app, rule): - buf = six.StringIO() - if hasattr(app.router, "parse_rule"): - iterator = app.router.parse_rule(rule) # bottle 0.11 - else: - iterator = app.router._itertokens(rule) # bottle 0.12 - for name, filter, conf in iterator: - if filter: - buf.write('(') - buf.write(name) - if (filter != app.router.default_filter and filter != 'default')\ - or conf: - buf.write(':') - buf.write(filter) - if conf: - buf.write(':') - buf.write(conf) - buf.write(')') - else: - buf.write(name) - return buf.getvalue() - - -def get_routes(app): - for route in app.routes: - path = translate_bottle_rule(app, route.rule) - yield route.method, path, route - - -class AutobottleDirective(Directive): - - has_content = True - required_arguments = 1 - option_spec = {'endpoints': directives.unchanged, - 'undoc-endpoints': directives.unchanged, - 'include-empty-docstring': directives.unchanged} - - @property - def endpoints(self): - endpoints = self.options.get('endpoints', None) - if not endpoints: - return None - return frozenset(re.split(r'\s*,\s*', endpoints)) - - @property - def undoc_endpoints(self): - undoc_endpoints = self.options.get('undoc-endpoints', None) - if not undoc_endpoints: - return frozenset() - return frozenset(re.split(r'\s*,\s*', undoc_endpoints)) - - def make_rst(self): - app = import_object(self.arguments[0]) - for method, path, target in get_routes(app): - endpoint = target.name or target.callback.__name__ - if self.endpoints and endpoint not in self.endpoints: - continue - if endpoint in self.undoc_endpoints: - continue - view = target.callback - docstring = view.__doc__ or '' - if not isinstance(docstring, six.text_type): - analyzer = ModuleAnalyzer.for_module(view.__module__) - docstring = force_decode(docstring, analyzer.encoding) - if not docstring and 'include-empty-docstring' not in self.options: - continue - docstring = prepare_docstring(docstring) - for line in http_directive(method, path, docstring): - yield line - - def run(self): - node = nodes.section() - node.document = self.state.document - result = ViewList() - for line in self.make_rst(): - result.append(line, '<autobottle>') - nested_parse_with_titles(self.state, result, node) - return node.children - - -def setup(app): - if 'http' not in app.domains: - httpdomain.setup(app) - app.add_directive('autobottle', AutobottleDirective) - diff --git a/exts/httpdomain/autohttp/common.py b/exts/httpdomain/autohttp/common.py deleted file mode 100644 index 199e2972..00000000 --- a/exts/httpdomain/autohttp/common.py +++ /dev/null @@ -1,36 +0,0 @@ -""" - sphinxcontrib.autohttp.common - ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ - - The common functions for web framework reflection. - - :copyright: Copyright 2011 by Hong Minhee - :license: BSD, see LICENSE for details. - -""" -import six -from six.moves import builtins -from six.moves import reduce - -def import_object(import_name): - module_name, expr = import_name.split(':', 1) - mod = __import__(module_name) - mod = reduce(getattr, module_name.split('.')[1:], mod) - globals = builtins - if not isinstance(globals, dict): - globals = globals.__dict__ - return eval(expr, globals, mod.__dict__) - - -def http_directive(method, path, content): - method = method.lower().strip() - if isinstance(content, six.string_types): - content = content.splitlines() - yield '' - paths = [path] if isinstance(path, six.string_types) else path - for path in paths: - yield '.. http:{method}:: {path}'.format(**locals()) - yield '' - for line in content: - yield ' ' + line - yield '' diff --git a/exts/httpdomain/autohttp/flask.py b/exts/httpdomain/autohttp/flask.py deleted file mode 100644 index 4bd5232e..00000000 --- a/exts/httpdomain/autohttp/flask.py +++ /dev/null @@ -1,48 +0,0 @@ -""" - sphinxcontrib.autohttp.flask - ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ - - The sphinx.ext.autodoc-style HTTP API reference builder (from Flask) - for sphinxcontrib.httpdomain. - - :copyright: Copyright 2011 by Hong Minhee - :license: BSD, see LICENSE for details. - -""" -from __future__ import absolute_import - -import re -import itertools -import six - -from docutils import nodes -from docutils.parsers.rst import directives -from docutils.statemachine import ViewList - -from sphinx.util import force_decode -from sphinx.util.compat import Directive -from sphinx.util.nodes import nested_parse_with_titles -from sphinx.util.docstrings import prepare_docstring -from sphinx.pycode import ModuleAnalyzer - -from sphinxcontrib import httpdomain -from sphinxcontrib.autohttp.common import http_directive, import_object - -from .flask_base import AutoflaskBase - -class AutoflaskDirective(AutoflaskBase): - - def run(self): - node = nodes.section() - node.document = self.state.document - result = ViewList() - for line in self.make_rst(): - result.append(line, '<autoflask>') - nested_parse_with_titles(self.state, result, node) - return node.children - - -def setup(app): - if 'http' not in app.domains: - httpdomain.setup(app) - app.add_directive('autoflask', AutoflaskDirective) diff --git a/exts/httpdomain/autohttp/flask_base.py b/exts/httpdomain/autohttp/flask_base.py deleted file mode 100644 index 50454fe2..00000000 --- a/exts/httpdomain/autohttp/flask_base.py +++ /dev/null @@ -1,215 +0,0 @@ -""" - sphinxcontrib.autohttp.flask - ~~~~~~~~~~~~~~~~~~~~~~~~~~~~ - - The sphinx.ext.autodoc-style HTTP API reference builder (from Flask) - for sphinxcontrib.httpdomain. - - :copyright: Copyright 2011 by Hong Minhee - :license: BSD, see LICENSE for details. - -""" - -import re -import itertools -import six - -from docutils import nodes -from docutils.parsers.rst import directives -from docutils.statemachine import ViewList - -from sphinx.util import force_decode -from sphinx.util.compat import Directive -from sphinx.util.nodes import nested_parse_with_titles -from sphinx.util.docstrings import prepare_docstring -from sphinx.pycode import ModuleAnalyzer - -from sphinxcontrib import httpdomain -from sphinxcontrib.autohttp.common import http_directive, import_object - - -def translate_werkzeug_rule(rule): - from werkzeug.routing import parse_rule - buf = six.StringIO() - for conv, arg, var in parse_rule(rule): - if conv: - buf.write('(') - if conv != 'default': - buf.write(conv) - buf.write(':') - buf.write(var) - buf.write(')') - else: - buf.write(var) - return buf.getvalue() - - -def get_routes(app, endpoint=None, order=None): - endpoints = [] - for rule in app.url_map.iter_rules(endpoint): - url_with_endpoint = ( - six.text_type(next(app.url_map.iter_rules(rule.endpoint))), - rule.endpoint - ) - if url_with_endpoint not in endpoints: - endpoints.append(url_with_endpoint) - if order == 'path': - endpoints.sort() - endpoints = [e for _, e in endpoints] - for endpoint in endpoints: - methodrules = {} - for rule in app.url_map.iter_rules(endpoint): - methods = rule.methods.difference(['OPTIONS', 'HEAD']) - path = translate_werkzeug_rule(rule.rule) - for method in methods: - if method in methodrules: - methodrules[method].append(path) - else: - methodrules[method] = [path] - for method, paths in methodrules.items(): - yield method, paths, endpoint - - -def quickref_directive(method, path, content): - rcomp = re.compile("^\s*.. :quickref:\s*(?P<quick>.*)$") - method = method.lower().strip() - if isinstance(content, six.string_types): - content = content.splitlines() - description="" - name="" - ref = path.replace("<","(").replace(">",")").replace("/","-").replace(":","-") - for line in content: - qref = rcomp.match(line) - if qref: - quickref = qref.group("quick") - parts = quickref.split(";",1) - if len(parts)>1: - name = parts[0] - description= parts[1] - else: - description= quickref - break - - row ={} - row['name'] = name - row['operation'] = ' - `%s %s <#%s-%s>`_' % (method.upper(), path, method.lower(), ref) - row['description'] = description - - return row - -class AutoflaskBase(Directive): - - has_content = True - required_arguments = 1 - option_spec = {'endpoints': directives.unchanged, - 'blueprints': directives.unchanged, - 'modules': directives.unchanged, - 'order': directives.unchanged, - 'undoc-endpoints': directives.unchanged, - 'undoc-blueprints': directives.unchanged, - 'undoc-modules': directives.unchanged, - 'undoc-static': directives.unchanged, - 'include-empty-docstring': directives.unchanged} - - @property - def endpoints(self): - endpoints = self.options.get('endpoints', None) - if not endpoints: - return None - return re.split(r'\s*,\s*', endpoints) - - @property - def undoc_endpoints(self): - undoc_endpoints = self.options.get('undoc-endpoints', None) - if not undoc_endpoints: - return frozenset() - return frozenset(re.split(r'\s*,\s*', undoc_endpoints)) - - @property - def blueprints(self): - blueprints = self.options.get('blueprints', None) - if not blueprints: - return None - return frozenset(re.split(r'\s*,\s*', blueprints)) - - @property - def undoc_blueprints(self): - undoc_blueprints = self.options.get('undoc-blueprints', None) - if not undoc_blueprints: - return frozenset() - return frozenset(re.split(r'\s*,\s*', undoc_blueprints)) - - @property - def modules(self): - modules = self.options.get('modules', None) - if not modules: - return frozenset() - return frozenset(re.split(r'\s*,\s*', modules)) - - @property - def undoc_modules(self): - undoc_modules = self.options.get('undoc-modules', None) - if not undoc_modules: - return frozenset() - return frozenset(re.split(r'\s*,\s*', undoc_modules)) - - @property - def order(self): - order = self.options.get('order', None) - if order not in (None, 'path'): - raise ValueError('Invalid value for :order:') - return order - - def make_rst(self, qref=False): - app = import_object(self.arguments[0]) - if self.endpoints: - routes = itertools.chain(*[get_routes(app, endpoint, self.order) - for endpoint in self.endpoints]) - else: - routes = get_routes(app, order=self.order) - for method, paths, endpoint in routes: - try: - blueprint, _, endpoint_internal = endpoint.rpartition('.') - if self.blueprints and blueprint not in self.blueprints: - continue - if blueprint in self.undoc_blueprints: - continue - except ValueError: - pass # endpoint is not within a blueprint - - if endpoint in self.undoc_endpoints: - continue - try: - static_url_path = app.static_url_path # Flask 0.7 or higher - except AttributeError: - static_url_path = app.static_path # Flask 0.6 or under - if ('undoc-static' in self.options and endpoint == 'static' and - static_url_path + '/(path:filename)' in paths): - continue - view = app.view_functions[endpoint] - - if self.modules and view.__module__ not in self.modules: - continue - - if self.undoc_modules and view.__module__ in self.modules: - continue - - docstring = view.__doc__ or '' - if hasattr(view, 'view_class'): - meth_func = getattr(view.view_class, method.lower(), None) - if meth_func and meth_func.__doc__: - docstring = meth_func.__doc__ - if not isinstance(docstring, six.text_type): - analyzer = ModuleAnalyzer.for_module(view.__module__) - docstring = force_decode(docstring, analyzer.encoding) - - if not docstring and 'include-empty-docstring' not in self.options: - continue - docstring = prepare_docstring(docstring) - if qref == True: - for path in paths: - row = quickref_directive(method, path, docstring) - yield row - else: - for line in http_directive(method, paths, docstring): - yield line diff --git a/exts/httpdomain/autohttp/flaskqref.py b/exts/httpdomain/autohttp/flaskqref.py deleted file mode 100644 index c28bb153..00000000 --- a/exts/httpdomain/autohttp/flaskqref.py +++ /dev/null @@ -1,80 +0,0 @@ -""" - sphinxcontrib.autohttp.flaskqref - ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ - - The sphinx.ext.autodoc-style HTTP API quick reference - builder (from Flask) - for sphinxcontrib.httpdomain. - - :copyright: Copyright 2011 by Hong Minhee - :license: BSD, see LICENSE for details. - -""" - -from docutils import nodes -from docutils.statemachine import ViewList - -from sphinxcontrib import httpdomain -from sphinx.util.nodes import nested_parse_with_titles - -from .flask import AutoflaskBase - - -class QuickReferenceFlaskDirective(AutoflaskBase): - - - header = [ '', - '.. list-table::', - ' :widths: 20 45 35', - ' :header-rows: 1', - '', - ' * - Resource', - ' - Operation', - ' - Description' - ] - - def run(self): - node = nodes.section() - node.document = self.state.document - result = ViewList() - for line in QuickReferenceFlaskDirective.header: - result.append(line, '<qrefflask>') - table={} - table_sorted_names=[] - - for table_row in self.make_rst(qref=True): - name = table_row['name'] - if table.get(name) is None: - table[name]=[] - table[name].append(table_row) - if name not in table_sorted_names: - table_sorted_names.append(name) - - table_sorted_names.sort() - - for name in table_sorted_names: - # Keep table display clean by not repeating duplicate - # resource names and descriptions - display_name = name - previous_description=None - for row in table[name]: - result.append(' * - %s' % display_name, '<qrefflask>') - display_name ="" - result.append(row['operation'], '<qrefflask>') - description = row['description'] - if previous_description is not None and previous_description == description: - description ="" - else: - previous_description = description - - result.append(' - %s' % description, '<qrefflask>') - - result.append('', '<qrefflask>') - nested_parse_with_titles(self.state, result, node) - return node.children - -def setup(app): - if 'http' not in app.domains: - httpdomain.setup(app) - app.add_directive('qrefflask', QuickReferenceFlaskDirective) - diff --git a/exts/httpdomain/autohttp/tornado.py b/exts/httpdomain/autohttp/tornado.py deleted file mode 100644 index 9a514fee..00000000 --- a/exts/httpdomain/autohttp/tornado.py +++ /dev/null @@ -1,128 +0,0 @@ -""" - sphinxcontrib.autohttp.tornado - ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ - - The sphinx.ext.autodoc-style HTTP API reference builder (from Tornado) - for sphinxcontrib.httpdomain. - - :copyright: Copyright 2013 by Rodrigo Machado - :license: BSD, see LICENSE for details. - -""" - -import inspect -import re -import six - -from docutils import nodes -from docutils.parsers.rst import directives -from docutils.statemachine import ViewList - -from sphinx.util import force_decode -from sphinx.util.compat import Directive -from sphinx.util.nodes import nested_parse_with_titles -from sphinx.util.docstrings import prepare_docstring -from sphinx.pycode import ModuleAnalyzer - -from sphinxcontrib import httpdomain -from sphinxcontrib.autohttp.common import http_directive, import_object - - -def translate_tornado_rule(app, rule): - buf = six.StringIO() - for name, filter, conf in app.router.parse_rule(rule): - if filter: - buf.write('(') - buf.write(name) - if filter != app.router.default_filter or conf: - buf.write(':') - buf.write(filter) - if conf: - buf.write(':') - buf.write(conf) - buf.write(')') - else: - buf.write(name) - return buf.getvalue() - - -def get_routes(app): - for spec in app.handlers[0][1]: - handler = spec.handler_class - doc_methods = list(handler.SUPPORTED_METHODS) - if 'HEAD' in doc_methods: - doc_methods.remove('HEAD') - if 'OPTIONS' in doc_methods: - doc_methods.remove('OPTIONS') - - for method in doc_methods: - maybe_method = getattr(handler, method.lower(), None) - if (inspect.isfunction(maybe_method) or - inspect.ismethod(maybe_method)): - yield method.lower(), spec.regex.pattern, handler - - -def normalize_path(path): - if path.endswith('$'): - path = path[:-1] - return path - - -class AutoTornadoDirective(Directive): - - has_content = True - required_arguments = 1 - option_spec = {'endpoints': directives.unchanged, - 'undoc-endpoints': directives.unchanged, - 'include-empty-docstring': directives.unchanged} - - @property - def endpoints(self): - endpoints = self.options.get('endpoints', None) - if not endpoints: - return None - return frozenset(re.split(r'\s*,\s*', endpoints)) - - @property - def undoc_endpoints(self): - undoc_endpoints = self.options.get('undoc-endpoints', None) - if not undoc_endpoints: - return frozenset() - return frozenset(re.split(r'\s*,\s*', undoc_endpoints)) - - def make_rst(self): - app = import_object(self.arguments[0]) - for method, path, handler in get_routes(app): - class_name = handler.__name__ - method_name = getattr(handler, method).__name__ - endpoint = '.'.join((class_name, method_name)) - - if self.endpoints and endpoint not in self.endpoints: - continue - if endpoint in self.undoc_endpoints: - continue - - docstring = getattr(handler, method).__doc__ or '' - #if not isinstance(docstring, unicode): - # analyzer = ModuleAnalyzer.for_module(view.__module__) - # docstring = force_decode(docstring, analyzer.encoding) - if not docstring and 'include-empty-docstring' not in self.options: - continue - docstring = prepare_docstring(docstring) - for line in http_directive(method, normalize_path(path), docstring): - yield line - - def run(self): - node = nodes.section() - node.document = self.state.document - result = ViewList() - for line in self.make_rst(): - result.append(line, '<autotornado>') - nested_parse_with_titles(self.state, result, node) - return node.children - - -def setup(app): - if 'http' not in app.domains: - httpdomain.setup(app) - app.add_directive('autotornado', AutoTornadoDirective) |