mirror of
https://github.com/searxng/searxng
synced 2024-11-09 01:10:26 +00:00
49 lines
1.6 KiB
Python
49 lines
1.6 KiB
Python
|
# -*- 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)
|