| """Shared CLI output helpers for Hermes CLI modules. |
| |
| Extracts the identical ``print_info/success/warning/error`` and ``prompt()`` |
| functions previously duplicated across setup.py, tools_config.py, |
| mcp_config.py, and memory_setup.py. |
| """ |
|
|
| import getpass |
|
|
| from hermes_cli.colors import Colors, color |
|
|
|
|
| |
|
|
|
|
| def print_info(text: str) -> None: |
| """Print a dim informational message.""" |
| print(color(f" {text}", Colors.DIM)) |
|
|
|
|
| def print_success(text: str) -> None: |
| """Print a green success message with β prefix.""" |
| print(color(f"β {text}", Colors.GREEN)) |
|
|
|
|
| def print_warning(text: str) -> None: |
| """Print a yellow warning message with β prefix.""" |
| print(color(f"β {text}", Colors.YELLOW)) |
|
|
|
|
| def print_error(text: str) -> None: |
| """Print a red error message with β prefix.""" |
| print(color(f"β {text}", Colors.RED)) |
|
|
|
|
| def print_header(text: str) -> None: |
| """Print a bold yellow header.""" |
| print(color(f"\n {text}", Colors.YELLOW)) |
|
|
|
|
| |
|
|
|
|
| def prompt( |
| question: str, |
| default: str | None = None, |
| password: bool = False, |
| ) -> str: |
| """Prompt the user for input with optional default and password masking. |
| |
| Replaces the four independent ``_prompt()`` / ``prompt()`` implementations |
| in setup.py, tools_config.py, mcp_config.py, and memory_setup.py. |
| |
| Returns the user's input (stripped), or *default* if the user presses Enter. |
| Returns empty string on Ctrl-C or EOF. |
| """ |
| suffix = f" [{default}]" if default else "" |
| display = color(f" {question}{suffix}: ", Colors.YELLOW) |
|
|
| try: |
| if password: |
| value = getpass.getpass(display) |
| else: |
| value = input(display) |
| value = value.strip() |
| return value if value else (default or "") |
| except (KeyboardInterrupt, EOFError): |
| print() |
| return "" |
|
|
|
|
| def prompt_yes_no(question: str, default: bool = True) -> bool: |
| """Prompt for a yes/no answer. Returns bool.""" |
| hint = "Y/n" if default else "y/N" |
| answer = prompt(f"{question} ({hint})") |
| if not answer: |
| return default |
| return answer.lower().startswith("y") |
|
|