# -*- 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)