2023-09-27 12:36:13 -04:00
|
|
|
Distriction specific patch, not going upstream
|
|
|
|
|
2021-06-07 03:31:03 -04:00
|
|
|
Disable systemd-run if the command is not found.
|
|
|
|
|
2023-09-27 12:36:13 -04:00
|
|
|
diff --git a/xpra/scripts/main.py b/xpra/scripts/main.py
|
2024-05-13 11:43:29 -04:00
|
|
|
index 1c5e8ddaad..084aabe792 100755
|
2023-09-27 12:36:13 -04:00
|
|
|
--- a/xpra/scripts/main.py
|
|
|
|
+++ b/xpra/scripts/main.py
|
2024-05-13 11:43:29 -04:00
|
|
|
@@ -396,23 +396,26 @@ def use_systemd_run(s) -> bool:
|
2023-09-27 12:36:13 -04:00
|
|
|
cmd = ["systemd-run", "--quiet"]
|
2024-05-13 11:43:29 -04:00
|
|
|
if getuid() != 0:
|
2023-09-27 12:36:13 -04:00
|
|
|
cmd += ["--user"]
|
|
|
|
- cmd += ["--scope", "--", "true"]
|
2021-06-07 03:31:03 -04:00
|
|
|
- proc = Popen(cmd, stdout=PIPE, stderr=PIPE, shell=False)
|
|
|
|
try:
|
|
|
|
- proc.communicate(timeout=2)
|
|
|
|
- r = proc.returncode
|
|
|
|
- except TimeoutExpired: # pragma: no cover
|
|
|
|
- r = None
|
|
|
|
- if r is None:
|
2023-09-27 12:36:13 -04:00
|
|
|
- try:
|
2021-06-07 03:31:03 -04:00
|
|
|
- proc.terminate()
|
|
|
|
- except Exception:
|
|
|
|
- pass
|
2023-09-27 12:36:13 -04:00
|
|
|
+ cmd = ["systemd-run", "--quiet", "--user", "--scope", "--", "true"]
|
|
|
|
+ proc = Popen(cmd, stdout=PIPE, stderr=PIPE, shell=False)
|
|
|
|
try:
|
2021-06-07 03:31:03 -04:00
|
|
|
- proc.communicate(timeout=1)
|
|
|
|
+ proc.communicate(timeout=2)
|
|
|
|
+ r = proc.returncode
|
|
|
|
except TimeoutExpired: # pragma: no cover
|
|
|
|
r = None
|
2024-05-13 11:43:29 -04:00
|
|
|
- return r == 0
|
2021-06-07 03:31:03 -04:00
|
|
|
+ if r is None:
|
|
|
|
+ try:
|
|
|
|
+ proc.terminate()
|
|
|
|
+ except Exception:
|
|
|
|
+ pass
|
|
|
|
+ try:
|
|
|
|
+ proc.communicate(timeout=1)
|
|
|
|
+ except TimeoutExpired: # pragma: no cover
|
|
|
|
+ r = None
|
|
|
|
+ return r==0
|
|
|
|
+ except FileNotFoundError:
|
|
|
|
+ return False
|
2024-05-13 11:43:29 -04:00
|
|
|
|
|
|
|
|
2023-09-27 12:36:13 -04:00
|
|
|
def verify_gir():
|