Merge "Remove custom autodoc implementation"
This commit is contained in:
commit
de8bb757dd
@ -12,69 +12,6 @@
|
||||
#
|
||||
# python-novaclient documentation build configuration file
|
||||
|
||||
import os
|
||||
import sys
|
||||
|
||||
BASE_DIR = os.path.dirname(os.path.abspath(__file__))
|
||||
ROOT = os.path.abspath(os.path.join(BASE_DIR, "..", ".."))
|
||||
|
||||
sys.path.insert(0, ROOT)
|
||||
sys.path.insert(0, BASE_DIR)
|
||||
|
||||
|
||||
# TODO(stephenfin): This looks like something that pbr's autodoc integration
|
||||
# could be doing for us. Investigate.
|
||||
|
||||
def gen_ref(ver, title, names):
|
||||
refdir = os.path.join(BASE_DIR, "reference", "api")
|
||||
pkg = "novaclient"
|
||||
if ver:
|
||||
pkg = "%s.%s" % (pkg, ver)
|
||||
refdir = os.path.join(refdir, ver)
|
||||
if not os.path.exists(refdir):
|
||||
os.makedirs(refdir)
|
||||
|
||||
# we don't want to write index files for top-level directories - only
|
||||
# sub-directories
|
||||
if ver:
|
||||
idxpath = os.path.join(refdir, "index.rst")
|
||||
with open(idxpath, "w") as idx:
|
||||
idx.write(("%(title)s\n"
|
||||
"%(signs)s\n"
|
||||
"\n"
|
||||
".. toctree::\n"
|
||||
" :maxdepth: 1\n"
|
||||
"\n") % {"title": title, "signs": "=" * len(title)})
|
||||
for name in names:
|
||||
idx.write(" %s\n" % name)
|
||||
|
||||
for name in names:
|
||||
rstpath = os.path.join(refdir, "%s.rst" % name)
|
||||
with open(rstpath, "w") as rst:
|
||||
rst.write(("%(title)s\n"
|
||||
"%(signs)s\n"
|
||||
"\n"
|
||||
".. automodule:: %(pkg)s.%(name)s\n"
|
||||
" :members:\n"
|
||||
" :undoc-members:\n"
|
||||
" :show-inheritance:\n"
|
||||
" :noindex:\n")
|
||||
% {"title": name.capitalize(),
|
||||
"signs": "=" * len(name),
|
||||
"pkg": pkg, "name": name})
|
||||
|
||||
|
||||
def get_module_names():
|
||||
names = os.listdir(os.path.join(ROOT, 'novaclient', 'v2'))
|
||||
exclude = ['shell.py', '__init__.py']
|
||||
for name in names:
|
||||
if name.endswith('.py') and name not in exclude:
|
||||
yield name.strip('.py')
|
||||
|
||||
|
||||
gen_ref(None, "Exceptions", ["exceptions"])
|
||||
gen_ref("v2", "Version 2 API", sorted(get_module_names()))
|
||||
|
||||
# -- General configuration ----------------------------------------------------
|
||||
|
||||
# Add any Sphinx extension module names here, as strings. They can be
|
||||
@ -84,6 +21,8 @@ extensions = [
|
||||
'openstackdocstheme',
|
||||
]
|
||||
|
||||
# The content that will be inserted into the main body of an autoclass
|
||||
# directive.
|
||||
autoclass_content = 'both'
|
||||
|
||||
# Add any paths that contain templates here, relative to this directory.
|
||||
|
@ -106,5 +106,4 @@ For more information, see the reference:
|
||||
.. toctree::
|
||||
:maxdepth: 2
|
||||
|
||||
v2/index
|
||||
exceptions
|
||||
autoindex
|
||||
|
@ -103,8 +103,11 @@ def add_arg(func, *args, **kwargs):
|
||||
|
||||
def service_type(stype):
|
||||
"""Adds 'service_type' attribute to decorated function.
|
||||
|
||||
Usage:
|
||||
|
||||
.. code-block:: python
|
||||
|
||||
@service_type('volume')
|
||||
def mymethod(f):
|
||||
...
|
||||
@ -436,10 +439,8 @@ def record_time(times, enabled, *args):
|
||||
"""Record the time of a specific action.
|
||||
|
||||
:param times: A list of tuples holds time data.
|
||||
:type times: list
|
||||
:param enabled: Whether timing is enabled.
|
||||
:type enabled: bool
|
||||
:param *args: Other data to be stored besides time data, these args
|
||||
:param args: Other data to be stored besides time data, these args
|
||||
will be joined to a string.
|
||||
"""
|
||||
if not enabled:
|
||||
|
@ -39,6 +39,11 @@ build-dir = doc/build
|
||||
[upload_sphinx]
|
||||
upload-dir = doc/build/html
|
||||
|
||||
[pbr]
|
||||
autodoc_index_modules = True
|
||||
autodoc_exclude_modules = novaclient.tests.* novaclient.v2.contrib.*
|
||||
api_doc_dir = reference/api
|
||||
|
||||
[compile_catalog]
|
||||
domain = novaclient
|
||||
directory = novaclient/locale
|
||||
|
Loading…
Reference in New Issue
Block a user