12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849 |
- # -*- coding: utf-8; mode: python -*-
- """Implement some sphinx-build tools.
- """
- import os
- import sys
- from sphinx.util.pycompat import execfile_
- # ------------------------------------------------------------------------------
- def load_sphinx_config(namespace):
- # ------------------------------------------------------------------------------
- u"""Load an additional configuration file into *namespace*.
- The name of the configuration file is taken from the environment
- ``SPHINX_CONF``. The external configuration file extends (or overwrites) the
- configuration values from the origin ``conf.py``. With this you are able to
- maintain *build themes*. To your docs/conf.py add::
- from sphinx_build_tools import load_sphinx_config
- ...
- # Since loadConfig overwrites settings from the global namespace, it has to be
- # the last statement in the conf.py file
- load_sphinx_config(globals())
- """
- config_file = os.environ.get("SPHINX_CONF", None)
- if (config_file is not None
- and os.path.normpath(namespace["__file__"]) != os.path.normpath(config_file) ):
- config_file = os.path.abspath(config_file)
- if os.path.isfile(config_file):
- sys.stdout.write(
- "load additional sphinx-config: %s\n"
- % config_file)
- config = namespace.copy()
- config['__file__'] = config_file
- execfile_(config_file, config)
- del config['__file__']
- namespace.update(config)
- else:
- sys.stderr.write(
- "WARNING: additional sphinx-config not found: %s\n"
- % config_file)
|