conf.py 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. # Configuration file for the Sphinx documentation builder.
  2. #
  3. # This file only contains a selection of the most common options. For a full
  4. # list see the documentation:
  5. # https://www.sphinx-doc.org/en/master/usage/configuration.html
  6. # -- Path setup --------------------------------------------------------------
  7. # Ensure we get the local copy of tornado instead of what's on the standard path
  8. import os
  9. import sys
  10. sys.path.insert(0, os.path.abspath(".."))
  11. sys.path.append(os.path.abspath("./_ext"))
  12. import pywebio
  13. version = release = pywebio.__version__
  14. # -- Project information -----------------------------------------------------
  15. project = 'PyWebIO'
  16. copyright = 'Weimin Wang'
  17. author = 'Weimin Wang'
  18. # -- General configuration ---------------------------------------------------
  19. # Add any Sphinx extension module names here, as strings. They can be
  20. # extensions coming with Sphinx (named 'sphinx.ext.*') or your custom
  21. # ones.
  22. extensions = [
  23. 'sphinx.ext.autodoc',
  24. # "sphinx.ext.intersphinx",
  25. "sphinx.ext.viewcode",
  26. 'sphinx_tabs.tabs',
  27. 'sphinx.ext.extlinks',
  28. 'codeblock', # defined in docs/_ext/codeblock.py
  29. 'sphinx_toolbox.collapse',
  30. ]
  31. # https://github.com/sphinx-doc/sphinx/issues/6316
  32. toc_object_entries = False
  33. primary_domain = "py"
  34. default_role = "py:obj"
  35. # intersphinx_mapping = {"python": ("https://docs.python.org/3.6/", None)}
  36. master_doc = 'index'
  37. autodoc_member_order = 'bysource'
  38. # The language for content autogenerated by Sphinx. Refer to documentation
  39. # for a list of supported languages.
  40. #
  41. # This is also used if you do content translation via gettext catalogs.
  42. # Usually you set "language" from the command line for these cases.
  43. language = 'en'
  44. gettext_additional_targets = ["literal-block"]
  45. # List of patterns, relative to source directory, that match files and
  46. # directories to ignore when looking for source files.
  47. # This pattern also affects html_static_path and html_extra_path.
  48. exclude_patterns = ['_build', 'Thumbs.db', '.DS_Store']
  49. # -- Options for HTML output -------------------------------------------------
  50. # The theme to use for HTML and HTML Help pages. See the documentation for
  51. # a list of builtin themes.
  52. #
  53. html_theme = "sphinx_rtd_theme"
  54. # Add any paths that contain custom static files (such as style sheets) here,
  55. # relative to this directory. They are copied after the builtin static files,
  56. # so a file named "default.css" will overwrite the builtin "default.css".
  57. html_static_path = ['static']
  58. def setup(app):
  59. """Configure Sphinx"""
  60. app.add_css_file('pywebio.css')
  61. # from docutils.parsers.rst.directives.admonitions import Note
  62. # app.add_directive('collapse', Note)
  63. # -- Extension configuration -------------------------------------------------
  64. from demos import config
  65. extlinks = {
  66. 'demo_host': (config.demo_host + '%s', 'demo_host'),
  67. 'charts_demo_host': (config.charts_demo_host + '%s', 'charts_demo_host')
  68. }
  69. from sphinx.builders.html import StandaloneHTMLBuilder
  70. StandaloneHTMLBuilder.supported_image_types = [
  71. 'image/svg+xml',
  72. 'image/gif',
  73. 'image/png',
  74. 'image/jpeg'
  75. ]