10000 Auto generate docs with sphinx (#442) · BioComputing/twilio-python@7d0bf3f · GitHub
[go: up one dir, main page]

Skip to content

Commit 7d0bf3f

Browse files
authored
Auto generate docs with sphinx (twilio#442)
* Change 'make docs-install' command to install Sphinx and Twilio libraries and 'make docs' to run sphinx-apidoc * update gitignore to ignore build directories * Add docs directory and Makefile * add config file * add sidebar template; * adds index directive * adds readme to autogenerated docs * Clean up source/_rst directory before calling sphinx-apidoc * Remove unnecessary commands * Remove twilio lib from doc-install * Add twilio relative import * add glob flag and _rst/module directive * add _rst directory * Update master doc location * fiiiine, added all sphinx make commands to this file and removed docs/Makefile * address code review comments * specify docs directories to ignore * address code review comments * bump Sphinx version * address code review comment
1 parent 5d8618e commit 7d0bf3f

File tree

7 files changed

+252
-4
lines changed

7 files changed

+252
-4
lines changed

.gitignore

Lines changed: 3 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -23,7 +23,9 @@ pip-log.txt
2323

2424
.DS_Store
2525

26-
docs/
26+
# sphinx build and rst folder
27+
docs/_build
28+
docs/source/_rst
2729

2830
# PyCharm/IntelliJ
2931
.idea

Makefile

Lines changed: 6 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -27,10 +27,14 @@ cover:
2727
find tests -type d | xargs nosetests --with-coverage --cover-inclusive --cover-erase --cover-package=twilio
2828

2929
docs-install:
30-
. venv/bin/activate; pip install pdoc
30+
. venv/bin/activate; pip install -r tests/requirements.txt
3131

3232
docs:
33-
. venv/bin/activate; pdoc twilio --overwrite --html --html-dir docs
33+
-rm -rf docs/source/_rst
34+
-rm -rf docs/build
35+
. venv/bin/activate; sphinx-apidoc -f twilio -o docs/source/_rst
36+
. venv/bin/activate; sphinx-build -b html -c ./docs -d docs/build/doctrees . docs/build/html
37+
3438

3539
release:
3640
. venv/bin/activate; python setup.py sdist upload

docs/conf.py

Lines changed: 193 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,193 @@
1+
# -*- coding: utf-8 -*-
2+
#
3+
# Configuration file for the Sphinx documentation builder.
4+
#
5+
# This file does only contain a selection of the most common options. For a
6+
# full list see the documentation:
7+
# http://www.sphinx-doc.org/en/master/config
8+
9+
10+
# -- Path setup --------------------------------------------------------------
11+
12+
# If extensions (or modules to document with autodoc) are in another directory,
13+
# add these directories to sys.path here. If the directory is relative to the
14+
# documentation root, use os.path.abspath to make it absolute, like shown here.
15+
#
16+
import os
17+
import sys
18+
sys.path.insert(0, os.path.join(os.path.abspath('..'), 'twilio'))
19+
sys.path.append('..')
20+
from twilio import __version__
21+
22+
23+
# -- Project information -----------------------------------------------------
24+
25+
project = 'twilio-python'
26+
copyright = '2018, Twilio'
27+
author = 'Twilio'
28+
29+
# The short X.Y version
30+
version = __version__
31+
# The full version, including alpha/beta/rc tags
32+
release = __version__
33+
34+
35+
# -- General configuration ---------------------------------------------------
36+
37+
# If your documentation needs a minimal Sphinx version, state it here.
38+
#
39+
# needs_sphinx = '1.0'
40+
41+
# Add any Sphinx extension module names here, as strings. They can be
42+
# extensions coming with Sphinx (named 'sphinx.ext.*') or your custom
43+
# ones.
44+
extensions = [
45+
'sphinx.ext.autodoc',
46+
'sphinx.ext.doctest',
47+
'sphinx.ext.intersphinx',
48+
'sphinx.ext.coverage',
49+
'sphinx.ext.ifconfig',
50+
'sphinx.ext.viewcode',
51+
]
52+
53+
# Add any paths that contain templates here, relative to this directory.
54+
templates_path = ['source/_templates']
55+
56+
# The suffix(es) of source filenames.
57+
# You can specify multiple suffix as a list of string:
58+
#
59+
# source_suffix = ['.rst', '.md']
60+
source_suffix = '.rst'
61+
62+
# The master toctree document.
63+
master_doc = 'docs/source/index'
64+
65+
# The language for content autogenerated by Sphinx. Refer to documentation
66+
# for a list of supported languages.
67+
#
68+
# This is also used if you do content translation via gettext catalogs.
69+
# Usually you set "language" from the command line for these cases.
70+
language = None
71+
72+
# List of patterns, relative to source directory, that match files and
73+
# directories to ignore when looking for source files.
74+
# This pattern also affects html_static_path and html_extra_path .
75+
exclude_patterns = []
76+
77+
# The name of the Pygments (syntax highlighting) style to use.
78+
pygments_style = 'sphinx'
79+
80+
81+
# -- Options for HTML output -------------------------------------------------
82+
83+
# The theme to use for HTML and HTML Help pages. See the documentation for
84+
# a list of builtin themes.
85+
#
86+
html_theme = 'alabaster'
87+
88+
# Theme options are theme-specific and customize the look and feel of a theme
89+
# further. For a list of options available for each theme, see the
90+
# documentation.
91+
#
92+
# html_theme_options = {}
93+
94+
html_static_path = ['source/_static']
95+
96+
# Custom sidebar templates, must be a dictionary that maps document names
97+
# to template names.
98+
#
99+
# The default sidebars (for documents that don't match any pattern) are
100+
# defined by theme itself. Builtin themes are using these templates by
101+
# default: ``['localtoc.html', 'relations.html', 'sourcelink.html',
102+
# 'searchbox.html']``.
103+
#
104+
html_sidebars = {
105+
'**': [ 'sidebarintro.html', 'localtoc.html', 'relations.html',
106+
'sourcelink.html', 'searchbox.html']
107+
}
108+
109+
110+
# -- Options for HTMLHelp output ---------------------------------------------
111+
112+
# Output file base name for HTML help builder.
113+
htmlhelp_basename = 'twilio-pythondoc'
114+
115+
116+
# -- Options for LaTeX output ------------------------------------------------
117+
118+
latex_elements = {
119+
# The paper size ('letterpaper' or 'a4paper').
120+
#
121+
# 'papersize': 'letterpaper',
122+
123+
# The font size ('10pt', '11pt' or '12pt').
124+
#
125+
# 'pointsize': '10pt',
126+
127+
# Additional stuff for the LaTeX preamble.
128+
#
129+
# 'preamble': '',
130+
131+
# Latex figure (float) alignment
132+
#
133+
# 'figure_align': 'htbp',
134+
}
135+
136+
# Grouping the document tree into LaTeX files. List of tuples
137+
# (source start file, target name, title,
138+
# author, documentclass [howto, manual, or own class]).
139+
latex_documents = [
140+
(master_doc, 'twilio-python.tex', 'twilio-python Documentation',
141+
'Twilio', 'manual'),
142+
]
143+
144+
145+
# -- Options for manual page output ------------------------------------------
146+
147+
# One entry per manual page. List of tuples
148+
# (source start file, name, description, authors, manual section).
149+
man_pages = [
150+
(master_doc, 'twilio-python', 'twilio-python Documentation',
151+
[author], 1)
152+
]
153+
154+
155+
# -- Options for Texinfo output ----------------------------------------------
156+
157+
# Grouping the document tree into Texinfo files. List of tuples
158+
# (source start file, target name, title, author,
159+
# dir menu entry, description, category)
160+
texinfo_documents = [
161+
(master_doc, 'twilio-python', 'twilio-python Documentation',
162+
author, 'twilio-python', 'One line description of project.',
163+
'Miscellaneous'),
164+
]
165+
166+
167+
# -- Options for Epub output -------------------------------------------------
168+
169+
# Bibliographic Dublin Core info.
170+
epub_title = project
171+
epub_author = author
172+
epub_publisher = author
173+
epub_copyright = copyright
174+
175+
# The unique identifier of the text. This can be a ISBN number
176+
# or the project homepage.
177+
#
178+
# epub_identifier = ''
179+
180+
# A unique identification for the text.
181+
#
182+
# epub_uid = ''
183+
184+
# A list of files that should not be packed into the epub file.
185+
epub_exclude_files = ['search.html']
186+
187+
188+
# -- Extension configuration -------------------------------------------------
189+
190+
# -- Options for intersphinx extension ---------------------------------------
191+
192+
# Example configuration for intersphinx: refer to the Python standard library.
193+
intersphinx_mapping = {'https://docs.python.org/': None}
Lines changed: 11 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,11 @@
1+
<h3><a href="https://www.twilio.com/docs/libraries/python">About twilio-python</a></h3>
2+
<p>
3+
A Python module for communicating with the Twilio API and generating <a href="http://www.twilio.com/docs/api/twiml/">TwiML</a>.
4+
</p>
5+
6+
<h3>Useful Links</h3>
7+
<ul>
8+
<li><a href="https://www.twilio.com/docs/libraries/python">Twilio's Python Helper Library Docs</a></li>
9+
<li><a href="https://pypi.org/project/twilio/">twilio @ PyPI</a></li>
10+
<li><a href="https://github.com/twilio/twilio-python">twilio-python @ GitHub</a></li>
11+
</ul>

docs/source/index.rst

Lines changed: 37 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,37 @@
1+
.. twilio-python documentation master file, created by
2+
sphinx-quickstart on Fri Jul 27 12:54:05 2018.
3+
You can adapt this file completely to your liking, but it should at least
4+
contain the root `toctree` directive.
5+
6+
7+
Welcome to twilio-python's documentation!
8+
=========================================
9+
10+
Release v\ |version|.
11+
12+
.. toctree::
13+
:maxdepth: 2
14+
15+
readme_include
16+
17+
18+
API auto-generated documentation
19+
================================
20+
21+
If you are looking for information on a specific function, class or
22+
method, this part of the documentation is for you.
23+
24+
.. toctree::
25+
:maxdepth: 1
26+
:glob:
27+
28+
_rst/modules.rst
29+
30+
31+
Indices and tables
32+
==================
33+
34+
* :ref:`genindex`
35+
* :ref:`modindex`
36+
* :ref:`search`
37+

docs/source/readme_include.rst

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
.. include:: ../../README.rst

tests/requirements.txt

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
1-
sphinx==1.4.9
1+
Sphinx==1.7.6
22
mock==0.8.0
33
nose
44
coverage

0 commit comments

Comments
 (0)
0