1# -*- coding: utf-8 -*- 2# 3# LLVM documentation build configuration file. 4# 5# This file is execfile()d with the current directory set to its containing dir. 6# 7# Note that not all possible configuration values are present in this 8# autogenerated file. 9# 10# All configuration values have a default; values that are commented out 11# serve to show the default. 12 13import sys, os 14from datetime import date 15 16# If extensions (or modules to document with autodoc) are in another directory, 17# add these directories to sys.path here. If the directory is relative to the 18# documentation root, use os.path.abspath to make it absolute, like shown here. 19#sys.path.insert(0, os.path.abspath('.')) 20 21# -- General configuration ----------------------------------------------------- 22 23# If your documentation needs a minimal Sphinx version, state it here. 24#needs_sphinx = '1.0' 25 26# Add any Sphinx extension module names here, as strings. They can be extensions 27# coming with Sphinx (named 'sphinx.ext.*') or your custom ones. 28extensions = ['sphinx.ext.intersphinx', 'sphinx.ext.todo'] 29 30# Add any paths that contain templates here, relative to this directory. 31templates_path = ['_templates'] 32 33# The suffix of source filenames. 34source_suffix = ['.rst', '.md'] 35 36source_parsers = {'.md': 'recommonmark.parser.CommonMarkParser'} 37 38# The encoding of source files. 39#source_encoding = 'utf-8-sig' 40 41# The master toctree document. 42master_doc = 'index' 43 44# General information about the project. 45project = u'LLVM' 46copyright = u'2003-%d, LLVM Project' % date.today().year 47 48# The version info for the project you're documenting, acts as replacement for 49# |version| and |release|, also used in various other places throughout the 50# built documents. 51# 52# The short version. 53version = '8' 54# The full version, including alpha/beta/rc tags. 55release = '8' 56 57# The language for content autogenerated by Sphinx. Refer to documentation 58# for a list of supported languages. 59#language = None 60 61# There are two options for replacing |today|: either, you set today to some 62# non-false value, then it is used: 63#today = '' 64# Else, today_fmt is used as the format for a strftime call. 65today_fmt = '%Y-%m-%d' 66 67# List of patterns, relative to source directory, that match files and 68# directories to ignore when looking for source files. 69exclude_patterns = ['_build'] 70 71# The reST default role (used for this markup: `text`) to use for all documents. 72#default_role = None 73 74# If true, '()' will be appended to :func: etc. cross-reference text. 75#add_function_parentheses = True 76 77# If true, the current module name will be prepended to all description 78# unit titles (such as .. function::). 79#add_module_names = True 80 81# If true, sectionauthor and moduleauthor directives will be shown in the 82# output. They are ignored by default. 83show_authors = True 84 85# The name of the Pygments (syntax highlighting) style to use. 86pygments_style = 'friendly' 87 88# A list of ignored prefixes for module index sorting. 89#modindex_common_prefix = [] 90 91 92# -- Options for HTML output --------------------------------------------------- 93 94# The theme to use for HTML and HTML Help pages. See the documentation for 95# a list of builtin themes. 96html_theme = 'llvm-theme' 97 98# Theme options are theme-specific and customize the look and feel of a theme 99# further. For a list of options available for each theme, see the 100# documentation. 101html_theme_options = { "nosidebar": True } 102 103# Add any paths that contain custom themes here, relative to this directory. 104html_theme_path = ["_themes"] 105 106# The name for this set of Sphinx documents. If None, it defaults to 107# "<project> v<release> documentation". 108#html_title = None 109 110# A shorter title for the navigation bar. Default is the same as html_title. 111#html_short_title = None 112 113# The name of an image file (relative to this directory) to place at the top 114# of the sidebar. 115#html_logo = None 116 117# The name of an image file (within the static path) to use as favicon of the 118# docs. This file should be a Windows icon file (.ico) being 16x16 or 32x32 119# pixels large. 120#html_favicon = None 121 122# Add any paths that contain custom static files (such as style sheets) here, 123# relative to this directory. They are copied after the builtin static files, 124# so a file named "default.css" will overwrite the builtin "default.css". 125html_static_path = ['_static'] 126 127# If not '', a 'Last updated on:' timestamp is inserted at every page bottom, 128# using the given strftime format. 129html_last_updated_fmt = '%Y-%m-%d' 130 131# If true, SmartyPants will be used to convert quotes and dashes to 132# typographically correct entities. 133#html_use_smartypants = True 134 135# Custom sidebar templates, maps document names to template names. 136html_sidebars = {'index': 'indexsidebar.html'} 137 138# Additional templates that should be rendered to pages, maps page names to 139# template names. 140#html_additional_pages = {} 141 142# If false, no module index is generated. 143#html_domain_indices = True 144 145# If false, no index is generated. 146#html_use_index = True 147 148# If true, the index is split into individual pages for each letter. 149#html_split_index = False 150 151# If true, links to the reST sources are added to the pages. 152html_show_sourcelink = True 153 154# If true, "Created using Sphinx" is shown in the HTML footer. Default is True. 155#html_show_sphinx = True 156 157# If true, "(C) Copyright ..." is shown in the HTML footer. Default is True. 158#html_show_copyright = True 159 160# If true, an OpenSearch description file will be output, and all pages will 161# contain a <link> tag referring to it. The value of this option must be the 162# base URL from which the finished HTML is served. 163#html_use_opensearch = '' 164 165# This is the file name suffix for HTML files (e.g. ".xhtml"). 166#html_file_suffix = None 167 168# Output file base name for HTML help builder. 169htmlhelp_basename = 'LLVMdoc' 170 171 172# -- Options for LaTeX output -------------------------------------------------- 173 174latex_elements = { 175# The paper size ('letterpaper' or 'a4paper'). 176#'papersize': 'letterpaper', 177 178# The font size ('10pt', '11pt' or '12pt'). 179#'pointsize': '10pt', 180 181# Additional stuff for the LaTeX preamble. 182#'preamble': '', 183} 184 185# Grouping the document tree into LaTeX files. List of tuples 186# (source start file, target name, title, author, documentclass [howto/manual]). 187latex_documents = [ 188 ('index', 'LLVM.tex', u'LLVM Documentation', 189 u'LLVM project', 'manual'), 190] 191 192# The name of an image file (relative to this directory) to place at the top of 193# the title page. 194#latex_logo = None 195 196# For "manual" documents, if this is true, then toplevel headings are parts, 197# not chapters. 198#latex_use_parts = False 199 200# If true, show page references after internal links. 201#latex_show_pagerefs = False 202 203# If true, show URL addresses after external links. 204#latex_show_urls = False 205 206# Documents to append as an appendix to all manuals. 207#latex_appendices = [] 208 209# If false, no module index is generated. 210#latex_domain_indices = True 211 212 213# -- Options for manual page output -------------------------------------------- 214 215# One entry per manual page. List of tuples 216# (source start file, name, description, authors, manual section). 217man_pages = [] 218 219# Automatically derive the list of man pages from the contents of the command 220# guide subdirectory. 221basedir = os.path.dirname(__file__) 222man_page_authors = "Maintained by The LLVM Team (http://llvm.org/)." 223command_guide_subpath = 'CommandGuide' 224command_guide_path = os.path.join(basedir, command_guide_subpath) 225for name in os.listdir(command_guide_path): 226 # Ignore non-ReST files and the index page. 227 if not name.endswith('.rst') or name in ('index.rst',): 228 continue 229 230 # Otherwise, automatically extract the description. 231 file_subpath = os.path.join(command_guide_subpath, name) 232 with open(os.path.join(command_guide_path, name)) as f: 233 title = f.readline().rstrip('\n') 234 header = f.readline().rstrip('\n') 235 236 if len(header) != len(title): 237 print >>sys.stderr, ( 238 "error: invalid header in %r (does not match title)" % ( 239 file_subpath,)) 240 if ' - ' not in title: 241 print >>sys.stderr, ( 242 ("error: invalid title in %r " 243 "(expected '<name> - <description>')") % ( 244 file_subpath,)) 245 246 # Split the name out of the title. 247 name,description = title.split(' - ', 1) 248 man_pages.append((file_subpath.replace('.rst',''), name, 249 description, man_page_authors, 1)) 250 251# If true, show URL addresses after external links. 252#man_show_urls = False 253 254# FIXME: Define intersphinx configuration. 255intersphinx_mapping = {} 256 257# Pygment lexer are sometimes out of date (when parsing LLVM for example) or 258# wrong. Suppress the warning so the build doesn't abort. 259suppress_warnings = [ 'misc.highlighting_failure' ] 260