diff options
author | Daniil Baturin <daniil@vyos.io> | 2024-03-13 11:12:27 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2024-03-13 11:12:27 +0100 |
commit | c8528d080786a4be9436fa71c9ec969b9c3719fd (patch) | |
tree | fa6d141ce9e5194b288601d30c3953fb4044951a /python/vyos | |
parent | ed3332f9eac3cedcbbaf48095b1ad202a5379267 (diff) | |
parent | 84b520dd580b7725de4c9e62b11ec490cb8d3f4f (diff) | |
download | vyos-1x-c8528d080786a4be9436fa71c9ec969b9c3719fd.tar.gz vyos-1x-c8528d080786a4be9436fa71c9ec969b9c3719fd.zip |
Merge pull request #3127 from vyos/mergify/bp/sagitta/pr-3126
grub: T4548: Fixed GRUB configuration files order (backport #3126)
Diffstat (limited to 'python/vyos')
-rw-r--r-- | python/vyos/system/grub.py | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/python/vyos/system/grub.py b/python/vyos/system/grub.py index 2e8b20972..864ed65aa 100644 --- a/python/vyos/system/grub.py +++ b/python/vyos/system/grub.py @@ -17,6 +17,7 @@ import platform from pathlib import Path from re import MULTILINE, compile as re_compile +from shutil import copy2 from typing import Union from uuid import uuid5, NAMESPACE_URL, UUID @@ -422,3 +423,38 @@ def set_kernel_cmdline_options(cmdline_options: str, version_name: str, version_add(version_name=version_name, root_dir=root_dir, boot_opts_config=cmdline_options) + + +def sort_inodes(dir_path: str) -> None: + """Sort inodes for files inside a folder + Regenerate inodes for each file to get the same order for both inodes + and file names + + GRUB iterates files by inodes, not alphabetically. Therefore, if we + want to read them in proper order, we need to sort inodes for all + config files in a folder. + + Args: + dir_path (str): a path to directory + """ + dir_content: list[Path] = sorted(Path(dir_path).iterdir()) + temp_list_old: list[Path] = [] + temp_list_new: list[Path] = [] + + # create a copy of all files, to get new inodes + for item in dir_content: + # skip directories + if item.is_dir(): + continue + # create a new copy of file with a temporary name + copy_path = Path(f'{item.as_posix()}_tmp') + copy2(item, Path(copy_path)) + temp_list_old.append(item) + temp_list_new.append(copy_path) + + # delete old files and rename new ones + for item in temp_list_old: + item.unlink() + for item in temp_list_new: + new_name = Path(f'{item.as_posix()[0:-4]}') + item.rename(new_name) |