mirror of
https://github.com/kovidgoyal/calibre.git
synced 2025-05-24 02:02:32 -04:00
258 lines
7.9 KiB
Python
258 lines
7.9 KiB
Python
# calibre documentation build configuration file, created by
|
|
# sphinx-quickstart.py on Sun Mar 23 01:23:55 2008.
|
|
#
|
|
# This file is execfile()d with the current directory set to its containing dir.
|
|
#
|
|
# The contents of this file are pickled, so don't put values in the namespace
|
|
# that aren't pickleable (module imports are okay, they're removed automatically).
|
|
#
|
|
# All configuration values have a default value; values that are commented out
|
|
# serve to show the default value.
|
|
|
|
import errno
|
|
import os
|
|
import sys
|
|
from datetime import date
|
|
|
|
# If your extensions are in another directory, add it here.
|
|
base = os.path.dirname(os.path.abspath(__file__))
|
|
sys.path.insert(0, os.path.dirname(base))
|
|
from setup import __appname__, __version__
|
|
|
|
sys.path.append(base)
|
|
|
|
import custom
|
|
|
|
import calibre.utils.img as cimg
|
|
from calibre.utils.localization import localize_website_link
|
|
|
|
del sys.path[0]
|
|
|
|
custom, cimg
|
|
# General configuration
|
|
# ---------------------
|
|
|
|
needs_sphinx = '1.2'
|
|
|
|
# Add any Sphinx extension module names here, as strings. They can be extensions
|
|
# coming with Sphinx (named 'sphinx.addons.*') or your custom ones.
|
|
extensions = ['sphinx.ext.autodoc', 'custom', 'sidebar_toc', 'sphinx.ext.viewcode', 'sphinx.ext.extlinks']
|
|
|
|
# Add any paths that contain templates here, relative to this directory.
|
|
templates_path = ['templates']
|
|
|
|
# The suffix of source filenames.
|
|
source_suffix = {'.rst': 'restructuredtext'}
|
|
|
|
# The master toctree document.
|
|
master_doc = 'index' if tags.has('online') else 'simple_index' # noqa: F821
|
|
# kill the warning about index/simple_index not being in a toctree
|
|
exclude_patterns = ['simple_index.rst'] if master_doc == 'index' else ['index.rst']
|
|
exclude_patterns.append('cli-options-header.rst')
|
|
if tags.has('gettext'): # noqa: F821
|
|
# Do not exclude anything as the strings must be translated. This will
|
|
# generate a warning about the documents not being in a toctree, just ignore
|
|
# it.
|
|
exclude_patterns = []
|
|
|
|
# The language
|
|
language = os.environ.get('CALIBRE_OVERRIDE_LANG', 'en')
|
|
|
|
|
|
def generated_langs():
|
|
try:
|
|
return os.listdir(os.path.join(base, 'generated'))
|
|
except OSError as e:
|
|
if e.errno != errno.ENOENT:
|
|
raise
|
|
return ()
|
|
|
|
|
|
# ignore generated files in languages other than the language we are building for
|
|
ge = {'generated/' + x for x in generated_langs()} | {
|
|
'generated/' + x for x in os.environ.get('ALL_USER_MANUAL_LANGUAGES', '').split()}
|
|
ge.discard('generated/' + language)
|
|
exclude_patterns += list(ge)
|
|
del ge
|
|
|
|
# General substitutions.
|
|
project = __appname__
|
|
copyright = 'Kovid Goyal'
|
|
|
|
# The default replacements for |version| and |release|, also used in various
|
|
# other places throughout the built documents.
|
|
#
|
|
# The short X.Y version.
|
|
version = __version__
|
|
# The full version, including alpha/beta/rc tags.
|
|
release = __version__
|
|
|
|
# There are two options for replacing |today|: either, you set today to some
|
|
# non-false value, then it is used:
|
|
# today = ''
|
|
# Else, today_fmt is used as the format for a strftime call.
|
|
today_fmt = '%B %d, %Y'
|
|
|
|
# List of documents that shouldn't be included in the build.
|
|
unused_docs = ['global', 'cli/global']
|
|
|
|
locale_dirs = ['locale/']
|
|
title = f'{__appname__} User Manual'
|
|
needs_localization = language not in {'en', 'eng'}
|
|
if needs_localization:
|
|
import gettext
|
|
try:
|
|
t = gettext.translation('simple_index', locale_dirs[0], [language])
|
|
except OSError:
|
|
pass
|
|
else:
|
|
title = t.gettext(title)
|
|
|
|
# If true, '()' will be appended to :func: etc. cross-reference text.
|
|
# add_function_parentheses = True
|
|
|
|
# If true, the current module name will be prepended to all description
|
|
# unit titles (such as .. function::).
|
|
# add_module_names = True
|
|
|
|
# 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'
|
|
|
|
|
|
# Options for HTML output
|
|
# -----------------------
|
|
|
|
# The style sheet to use for HTML and HTML Help pages. A file of that name
|
|
# must exist either in Sphinx' static/ path, or in one of the custom paths
|
|
# given in html_static_path.
|
|
html_theme = 'alabaster'
|
|
html_sidebars = {
|
|
'**': [
|
|
'about.html',
|
|
'searchbox.html',
|
|
'localtoc.html',
|
|
'relations.html',
|
|
]
|
|
}
|
|
html_theme_options = {
|
|
'logo': 'logo.png',
|
|
'show_powered_by': False,
|
|
'fixed_sidebar': True,
|
|
'sidebar_collapse': True,
|
|
'github_button': False,
|
|
}
|
|
|
|
# The favicon
|
|
html_favicon = '../icons/favicon.ico'
|
|
|
|
# Add any paths that contain custom static files (such as style sheets) here,
|
|
# relative to this directory. They are copied after the built-in static files,
|
|
# so a file named "default.css" will overwrite the built-in "default.css".
|
|
html_static_path = ['resources', '../icons/favicon.ico']
|
|
|
|
# If not '', a 'Last updated on:' timestamp is inserted at every page bottom,
|
|
# using the given strftime format.
|
|
html_last_updated_fmt = '%b %d, %Y'
|
|
|
|
# Overall title of the documentation
|
|
# html_title = title
|
|
html_short_title = _('Start')
|
|
|
|
from calibre.utils.localization import get_language
|
|
|
|
html_context = {}
|
|
html_context['other_languages'] = [
|
|
(lc, get_language(lc)) for lc in os.environ.get('ALL_USER_MANUAL_LANGUAGES', '').split() if lc != language]
|
|
|
|
|
|
def sort_languages(x):
|
|
from calibre.utils.icu import sort_key
|
|
lc, name = x
|
|
if lc == language:
|
|
return ''
|
|
return sort_key(str(name))
|
|
|
|
|
|
website = 'https://calibre-ebook.com'
|
|
html_context['other_languages'].sort(key=sort_languages)
|
|
html_context['support_text'] = _('Support calibre')
|
|
html_context['support_tooltip'] = _('Contribute to support calibre development')
|
|
html_context['homepage_url'] = website
|
|
if needs_localization:
|
|
html_context['homepage_url'] = localize_website_link(html_context['homepage_url'])
|
|
extlinks = {
|
|
'website_base': (f'{website}/%s', None),
|
|
'website': (html_context['homepage_url'] + '/%s', None),
|
|
'download_file': (f'{website}/downloads/%s', '%s'),
|
|
}
|
|
del sort_languages, get_language
|
|
|
|
epub_author = 'Kovid Goyal'
|
|
epub_publisher = 'Kovid Goyal'
|
|
epub_copyright = f'© {date.today().year} Kovid Goyal'
|
|
epub_description = 'Comprehensive documentation for calibre'
|
|
epub_identifier = 'https://manual.calibre-ebook.com'
|
|
epub_scheme = 'url'
|
|
epub_uid = 'S54a88f8e9d42455e9c6db000e989225f'
|
|
epub_tocdepth = 4
|
|
epub_tocdup = True
|
|
epub_cover = ('epub_cover.jpg', 'epub_cover_template.html')
|
|
suppress_warnings = ['epub.duplicated_toc_entry']
|
|
|
|
# Custom sidebar templates, maps document names to template names.
|
|
# html_sidebars = {}
|
|
|
|
# Additional templates that should be rendered to pages, maps page names to
|
|
# template names.
|
|
# html_additional_pages = {}
|
|
|
|
html_use_modindex = False
|
|
html_use_index = False
|
|
|
|
# If true, the reST sources are included in the HTML build as _sources/<name>.
|
|
html_copy_source = True
|
|
|
|
# Output file base name for HTML help builder.
|
|
htmlhelp_basename = 'calibredoc'
|
|
|
|
html_use_opensearch = 'https://manual.calibre-ebook.com'
|
|
|
|
html_show_sphinx = False
|
|
|
|
# Options for LaTeX output
|
|
# ------------------------
|
|
|
|
# The paper size ('letter' or 'a4').
|
|
latex_paper_size = 'letter'
|
|
|
|
# The font size ('10pt', '11pt' or '12pt').
|
|
latex_font_size = '10pt'
|
|
|
|
# Grouping the document tree into LaTeX files. List of tuples
|
|
# (source start file, target name, title, author, document class [howto/manual]).
|
|
latex_documents = [(master_doc, 'calibre.tex', title, 'Kovid Goyal', 'manual', False)]
|
|
|
|
# Additional stuff for the LaTeX preamble.
|
|
# latex_preamble = ''
|
|
|
|
# Documents to append as an appendix to all manuals.
|
|
# latex_appendices = []
|
|
|
|
# If false, no module index is generated.
|
|
# latex_use_modindex = True
|
|
|
|
# we use lualatex as it is actively maintained and pdflatex and xelatex fail
|
|
# to render smart quotes and dashes
|
|
latex_engine = 'lualatex'
|
|
latex_logo = 'resources/logo.png'
|
|
latex_show_pagerefs = True
|
|
latex_show_urls = 'footnote'
|
|
latex_elements = {
|
|
'papersize':'letterpaper',
|
|
'preamble': r'\renewcommand{\pageautorefname}{%s}' % _('page'), # noqa: UP031
|
|
}
|