Source code for pkgcore.config
"""configuration subsystem"""
__all__ = ("load_config",)
# keep these imports as minimal as possible; access to
# pkgcore.config isn't uncommon, thus don't trigger till
# actually needed
import os
import typing
from .. import const
from . import central, cparser
[docs]
def load_config(
user_conf_file: typing.Optional[str] = const.USER_CONF_FILE,
system_conf_file: typing.Optional[str] = const.SYSTEM_CONF_FILE,
debug: bool = False,
prepend_sources=(),
skip_config_files: bool = False,
profile_override: typing.Optional[str] = None,
location: typing.Optional[str] = None,
**kwargs,
) -> central.CompatConfigManager:
"""The main entry point for any code looking to use pkgcore.
Args:
user_conf_file (optional[str]): pkgcore user config file path
system_conf_file (optional[str]): system pkgcore config file path
profile_override (optional[str]): targeted profile instead of system setting
location (optional[str]): path to pkgcore config file or portage config directory
skip_config_files (bool): don't attempt to load any config files
Returns:
:obj:`pkgcore.config.central.ConfigManager` instance: system config
"""
configs = list(prepend_sources)
if not skip_config_files:
# load a pkgcore config file if one exists
for config in (location, user_conf_file, system_conf_file):
if config is not None and os.path.isfile(config):
with open(config) as f:
configs.append(cparser.config_from_file(f))
break
# otherwise load the portage config
else:
# delay importing to avoid circular imports
from pkgcore.ebuild.portage_conf import PortageConfig
configs.append(
PortageConfig(
location=location, profile_override=profile_override, **kwargs
)
)
return central.CompatConfigManager(central.ConfigManager(configs, debug=debug))