import sys def print_msg(*args, print_to="debug"): from .. import conf if print_to is None: return elif print_to == "debug": # print a debug message to stderr if config["debug"] is set if conf.config["debug"]: print("DEBUG:", *args, file=sys.stderr) elif print_to == "verbose": # print a verbose message to stdout if config["verbose"] or config["debug"] is set if conf.config["verbose"] or conf.config["debug"]: print(*args) elif print_to == "stdout": # print the message to stdout print(*args) elif print_to == "stderr": # print the message to stderr print(*args, file=sys.stderr) else: raise ValueError(f"Invalid value of the 'print_to' option: {print_to}") def format_msg_project_package_options( msg, project=None, package=None, dest_project=None, dest_package=None, repository=None, dest_repository=None, **options, ): """ Format msg, project, package, dest_project, dest_package and options into a meaningful message that can be printed out directly or as a debug message. """ if project and not package: msg += f" project '{project}'" else: msg += f" package '{project}/{package}'" if repository: msg += f" repository '{repository}'" if any([dest_project, dest_package, dest_repository]): msg += " to" if dest_project and not dest_package: msg += f" project '{dest_project}'" elif dest_project and dest_package: msg += f" package '{dest_project}/{dest_package}'" if dest_repository: msg += f" repository '{dest_repository}'" msg_options = [key.replace("_", "-") for key, value in options.items() if value] if msg_options: msg_options.sort() msg_options_str = ", ".join(msg_options) msg += f" options: {msg_options_str}" return msg