From 582b83b196c35bad620f7cb9ae0a41dd772c7545 Mon Sep 17 00:00:00 2001 From: R1kaB3rN <100738684+R1kaB3rN@users.noreply.github.com> Date: Fri, 11 Oct 2024 22:16:41 -0700 Subject: [PATCH] umu_util: hold a lock while removing rc4 files --- umu/umu_util.py | 55 ++++++++++++++++++++++++++----------------------- 1 file changed, 29 insertions(+), 26 deletions(-) diff --git a/umu/umu_util.py b/umu/umu_util.py index 86543b355..8fac51301 100644 --- a/umu/umu_util.py +++ b/umu/umu_util.py @@ -10,6 +10,7 @@ from ssl import SSLContext, create_default_context from subprocess import PIPE, STDOUT, Popen, TimeoutExpired +from filelock import FileLock from Xlib import display from umu.umu_consts import STEAM_COMPAT, UMU_LOCAL @@ -184,32 +185,34 @@ def find_obsolete() -> None: "sniper_platform_0.20231211.70175", } launcher: Path - - # Obsoleted files in $HOME/.local/share/umu from RC4 and below - for file in UMU_LOCAL.glob("*"): - is_umu_file: bool = file.name.endswith(".py") and ( - file.name.startswith(("umu", "ulwgl")) - ) - if is_umu_file or file.name in obsoleted: - if file.is_file(): - file.unlink() - if file.is_dir(): - rmtree(str(file)) - - # $HOME/.local/share/Steam/compatibilitytool.d - launcher = STEAM_COMPAT.joinpath("ULWGL-Launcher") - if launcher.is_dir(): - rmtree(str(launcher)) - - # $HOME/.cache - launcher = home.joinpath(".cache", "ULWGL") - if launcher.is_dir(): - rmtree(str(launcher)) - - # $HOME/.local/share - launcher = home.joinpath(".local", "share", "ULWGL") - if launcher.is_dir(): - rmtree(str(launcher)) + lock: FileLock = FileLock(f"{UMU_LOCAL}/umu.lock") + + with lock: + # Obsoleted files in $HOME/.local/share/umu from RC4 and below + for file in UMU_LOCAL.glob("*"): + is_umu_file: bool = file.name.endswith(".py") and ( + file.name.startswith(("umu", "ulwgl")) + ) + if is_umu_file or file.name in obsoleted: + if file.is_file(): + file.unlink() + if file.is_dir(): + rmtree(str(file)) + + # $HOME/.local/share/Steam/compatibilitytool.d + launcher = STEAM_COMPAT.joinpath("ULWGL-Launcher") + if launcher.is_dir(): + rmtree(str(launcher)) + + # $HOME/.cache + launcher = home.joinpath(".cache", "ULWGL") + if launcher.is_dir(): + rmtree(str(launcher)) + + # $HOME/.local/share + launcher = home.joinpath(".local", "share", "ULWGL") + if launcher.is_dir(): + rmtree(str(launcher)) @contextmanager