import click import logging from config.state import config from .device import get_devices, get_profile_device @click.command(name='devices') def cmd_devices(): 'list the available devices and descriptions' devices = get_devices() if not devices: raise Exception("No devices found!") profile_device = None try: dev = get_profile_device() assert dev profile_device = dev except Exception as ex: logging.debug(f"Failed to get profile device for visual highlighting, not a problem: {ex}") output = [''] for name in sorted(devices.keys()): prefix = '' suffix = '' device = devices[name] assert device try: device.parse_deviceinfo(try_download=False) except Exception as ex: logging.debug(f"Failed to parse deviceinfo for extended description, not a problem: {ex}") if profile_device and profile_device.name == device.name: prefix = '>>> ' suffix = f'\n\nCurrently selected by profile "{config.file.profiles.current}"' snippet = f'{device}{suffix}' # prefix each line in the snippet snippet = '\n'.join([f'{prefix}{line}' for line in snippet.split('\n')]) output.append(f"{snippet}\n") for line in output: print(line)