diff options
author | Daniil Baturin <daniil@vyos.io> | 2024-01-10 22:02:57 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-01-10 22:02:57 +0000 |
commit | 942f4cf77dbacc09393b577c2122e403fd788194 (patch) | |
tree | 1cf125ff0c253d6db731b777462c66e7e3c2d310 | |
parent | 348892a97be2c2dfb810422fb94fe4eabe5d6a42 (diff) | |
parent | 2e69d72515df4993bba334399e6b2a96ab62ec01 (diff) | |
download | vyos-1x-942f4cf77dbacc09393b577c2122e403fd788194.tar.gz vyos-1x-942f4cf77dbacc09393b577c2122e403fd788194.zip |
Merge pull request #2795 from vyos/mergify/bp/sagitta/pr-2786
image-tools: T5917: annotate image list with (running)/(default boot) (backport #2786)
-rwxr-xr-x | src/op_mode/image_manager.py | 25 |
1 files changed, 23 insertions, 2 deletions
diff --git a/src/op_mode/image_manager.py b/src/op_mode/image_manager.py index e75485f9f..e64a85b95 100755 --- a/src/op_mode/image_manager.py +++ b/src/op_mode/image_manager.py @@ -33,6 +33,27 @@ DELETE_IMAGE_PROMPT_MSG: str = 'Select an image to delete:' MSG_DELETE_IMAGE_RUNNING: str = 'Currently running image cannot be deleted; reboot into another image first' MSG_DELETE_IMAGE_DEFAULT: str = 'Default image cannot be deleted; set another image as default first' +def annotated_list(images_list: list[str]) -> list[str]: + """Annotate list of images with additional info + + Args: + images_list (list[str]): a list of image names + + Returns: + list[str]: a list of image names with additional info + """ + index_running: int = None + index_default: int = None + try: + index_running = images_list.index(image.get_running_image()) + index_default = images_list.index(image.get_default_image()) + except ValueError: + pass + if index_running is not None: + images_list[index_running] += ' (running)' + if index_default is not None: + images_list[index_default] += ' (default boot)' + return images_list @compat.grub_cfg_update def delete_image(image_name: Optional[str] = None, @@ -42,7 +63,7 @@ def delete_image(image_name: Optional[str] = None, Args: image_name (str): a name of image to delete """ - available_images: list[str] = grub.version_list() + available_images: list[str] = annotated_list(grub.version_list()) if image_name is None: if no_prompt: exit('An image name is required for delete action') @@ -83,7 +104,7 @@ def set_image(image_name: Optional[str] = None, Args: image_name (str): an image name """ - available_images: list[str] = grub.version_list() + available_images: list[str] = annotated_list(grub.version_list()) if image_name is None: if not prompt: exit('An image name is required for set action') |