From 0162fa2526d3f28176e158535cd405585c720b2e Mon Sep 17 00:00:00 2001 From: Abraham Arce Date: Wed, 8 Aug 2018 16:35:41 -0500 Subject: [PATCH] [Doc] OpenStack API Reference Guide Baseline changes to comply with OpenStack API documentation from OpenStack Documentation Contributor Guide [0]: - [1] How to document your OpenStack API service [0] https://docs.openstack.org/doc-contrib-guide [1] https://docs.openstack.org/doc-contrib-guide/api-guides.html Story: 2002712 Task: 24451 Change-Id: I91f7640583081c83d3d43786e979ccfb5bee0490 Signed-off-by: Abraham Arce --- .gitignore | 3 ++ api-ref/source/conf.py | 75 ++++++++++++++++++++++++++++++++++++++++ api-ref/source/index.rst | 8 +++++ doc/requirements.txt | 3 ++ tox.ini | 9 +++++ 5 files changed, 98 insertions(+) create mode 100644 api-ref/source/conf.py create mode 100644 api-ref/source/index.rst diff --git a/.gitignore b/.gitignore index 816bcbf2..c946a099 100644 --- a/.gitignore +++ b/.gitignore @@ -27,3 +27,6 @@ doc/build/ # Release Notes Management releasenotes/build + +# API Reference Guide +api-ref/build/ diff --git a/api-ref/source/conf.py b/api-ref/source/conf.py new file mode 100644 index 00000000..b36a2795 --- /dev/null +++ b/api-ref/source/conf.py @@ -0,0 +1,75 @@ +# Licensed under the Apache License, Version 2.0 (the "License"); you may +# not use this file except in compliance with the License. You may obtain +# a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT +# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the +# License for the specific language governing permissions and limitations +# under the License. +# +# stx-metal API reference documentation build configuration file +# +# This file is execfile()d with the current directory set to +# its containing dir. +# +# Note that not all possible configuration values are present in this +# autogenerated file. +# +# All configuration values have a default; values that are commented out +# serve to show the default. + +import os +import sys + +extensions = [ + 'openstackdocstheme', + 'os_api_ref', +] + +html_theme = 'openstackdocs' + +html_theme_options = { + "sidebar_dropdown": "api_ref", + "sidebar_mode": "toc", +} + +# If extensions (or modules to document with autodoc) are in another directory, +# add these directories to sys.path here. If the directory is relative to the +# documentation root, use os.path.abspath to make it absolute, like shown here. +sys.path.insert(0, os.path.abspath('../../')) +sys.path.insert(0, os.path.abspath('../')) +sys.path.insert(0, os.path.abspath('./')) + +# The suffix of source filenames. +source_suffix = '.rst' + +# The master toctree document. +master_doc = 'index' + +# General information about the project. +repository_name = 'openstack/stx-metal' +project = u'stx-metal' +bug_project = 'starlingx' +bug_tag = 'stx.metal' + +# If true, the current module name will be prepended to all description +# unit titles (such as .. function::). +add_module_names = False + +# If true, sectionauthor and moduleauthor directives will be shown in the +# output. They are ignored by default. +show_authors = False + +# The name of the Pygments (syntax highlighting) style to use. +pygments_style = 'sphinx' + +# Grouping the document tree into LaTeX files. List of tuples +# (source start file, target name, title, author, documentclass +# [howto/manual]). +latex_documents = [ + ('index', 'stx-metal.tex', u'stx-metal API Documentation', + u'StarlingX', 'manual'), +] diff --git a/api-ref/source/index.rst b/api-ref/source/index.rst new file mode 100644 index 00000000..485b4a4e --- /dev/null +++ b/api-ref/source/index.rst @@ -0,0 +1,8 @@ +======================= +stx-metal API Reference +======================= + +This is the API Reference for the StarlingX Bare Metal and Node Management, Hardware Maintenance. + +.. toctree:: + :maxdepth: 2 diff --git a/doc/requirements.txt b/doc/requirements.txt index 83356e11..7359d8fe 100644 --- a/doc/requirements.txt +++ b/doc/requirements.txt @@ -3,3 +3,6 @@ openstackdocstheme>=1.19.0 # Apache-2.0 # Release Notes reno>=0.1.1 # Apache-2.0 + +# API Reference Guide +os-api-ref>=1.4.0 # Apache-2.0 diff --git a/tox.ini b/tox.ini index d2952b6e..29fcf193 100644 --- a/tox.ini +++ b/tox.ini @@ -58,3 +58,12 @@ commands = rm -rf releasenotes/build sphinx-build -a -E -W -d releasenotes/build/doctrees -b html releasenotes/source releasenotes/build/html whitelist_externals = rm + +[testenv:api-ref] +basepython = python3 +deps = + -r{toxinidir}/doc/requirements.txt +commands = + rm -rf api-ref/build + sphinx-build -W -b html -d api-ref/build/doctrees api-ref/source api-ref/build/html +whitelist_externals = rm