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