diff --git a/swh/scanner/cli.py b/swh/scanner/cli.py --- a/swh/scanner/cli.py +++ b/swh/scanner/cli.py @@ -6,12 +6,13 @@ # WARNING: do not import unnecessary things here to keep cli startup time under # control import os -from typing import Any, Dict +from typing import Any, Dict, Optional import click from swh.core import config -from swh.core.cli import CONTEXT_SETTINGS, swh as swh_cli_group +from swh.core.cli import CONTEXT_SETTINGS +from swh.core.cli import swh as swh_cli_group # All generic config code should reside in swh.core.config DEFAULT_CONFIG_PATH = os.environ.get( @@ -40,17 +41,28 @@ @click.option( "-C", "--config-file", - default=DEFAULT_CONFIG_PATH, - type=click.Path(exists=True, dir_okay=False, path_type=str), - help="YAML configuration file", + default=None, + type=click.Path(exists=False, dir_okay=False, path_type=str), + help=f"""YAML configuration file. If absent and cannot load the default one, + default parameters are used. + Default config path is {DEFAULT_CONFIG_PATH}. + Default config values are {DEFAULT_CONFIG} + """, ) @click.pass_context -def scanner(ctx, config_file: str): +def scanner(ctx, config_file: Optional[str]): """Software Heritage Scanner tools.""" - - # recursive merge not done by config.read - conf = config.read_raw_config(config.config_basepath(config_file)) - conf = config.merge_configs(DEFAULT_CONFIG, conf) + if config_file is None and config.config_exists(DEFAULT_CONFIG_PATH): + config_file = DEFAULT_CONFIG_PATH + + if config_file is None: + conf = DEFAULT_CONFIG + else: + # read_raw_config do not fail on ENOENT + if not config.config_exists(config_file): + raise FileNotFoundError(config_file) + conf = config.read_raw_config(config.config_basepath(config_file)) + conf = config.merge_configs(DEFAULT_CONFIG, conf) ctx.ensure_object(dict) ctx.obj["config"] = conf