Skip to content

Commit

Permalink
add shim file so we can set customizations inside the container befor…
Browse files Browse the repository at this point in the history
…e running proton
  • Loading branch information
GloriousEggroll committed Oct 22, 2024
1 parent 0aea3e7 commit 25f5311
Show file tree
Hide file tree
Showing 3 changed files with 57 additions and 1 deletion.
2 changes: 2 additions & 0 deletions umu/umu_run.py
Original file line number Diff line number Diff line change
Expand Up @@ -335,6 +335,7 @@ def build_command(
opts: list[str] = [],
) -> tuple[Path | str, ...]:
"""Build the command to be executed."""
shim: Path = local.joinpath("umu-shim")
proton: Path = Path(env["PROTONPATH"], "proton")
entry_point: Path = local.joinpath("umu")

Expand Down Expand Up @@ -373,6 +374,7 @@ def build_command(
"--verb",
env["PROTON_VERB"],
"--",
shim,
proton,
env["PROTON_VERB"],
env["EXE"],
Expand Down
48 changes: 48 additions & 0 deletions umu/umu_runtime.py
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,44 @@
has_data_filter: bool = False


def create_shim(file_path: Path | None = None):
"""Create a shell script shim at the specified file path.
This script sets the DISPLAY environment variable if certain conditions
are met and executes the passed command.
Args:
file_path (Path, optional): The path where the shim script will be created.
Defaults to UMU_LOCAL.joinpath("umu-shim").
"""
# Set the default path if none is provided
if file_path is None:
file_path = UMU_LOCAL.joinpath("umu-shim")
# Define the content of the shell script
script_content = """#!/bin/sh
if [ "${XDG_CURRENT_DESKTOP}" = "gamescope" ] || [ "${XDG_SESSION_DESKTOP}" = "gamescope" ]; then
# Check if STEAM_MULTIPLE_XWAYLANDS is set to 1
if [ "${STEAM_MULTIPLE_XWAYLANDS}" = "1" ]; then
# Check if DISPLAY is set, if not, set it to ":1"
if [ -z "${DISPLAY}" ]; then
export DISPLAY=":1"
fi
fi
fi
# Execute the passed command
"$@"
"""

# Write the script content to the specified file path
with file_path.open('w') as file:
file.write(script_content)

# Make the script executable
file_path.chmod(0o700)

def _install_umu(
json: dict[str, Any],
thread_pool: ThreadPoolExecutor,
Expand Down Expand Up @@ -177,6 +215,7 @@ def _install_umu(
# Rename _v2-entry-point
log.debug("Renaming: _v2-entry-point -> umu")
UMU_LOCAL.joinpath("_v2-entry-point").rename(UMU_LOCAL.joinpath("umu"))
create_shim()

# Validate the runtime after moving the files
check_runtime(UMU_LOCAL, json)
Expand Down Expand Up @@ -368,6 +407,9 @@ def _update_umu(
rmtree(str(runtime))
log.debug("Released file lock '%s'", lock.lock_file)

if not UMU_LOCAL.joinpath("umu-shim").exists():
create_shim()

log.console("steamrt is up to date")


Expand Down Expand Up @@ -474,6 +516,9 @@ def check_runtime(src: Path, json: dict[str, Any]) -> int:
return ret
log.console(f"{runtime.name}: mtree is OK")

if not UMU_LOCAL.joinpath("umu-shim").exists():
create_shim()

return ret


Expand All @@ -491,3 +536,6 @@ def _restore_umu(
return
_install_umu(json, thread_pool, client_session)
log.debug("Released file lock '%s'", lock.lock_file)

if not UMU_LOCAL.joinpath("umu-shim").exists():
create_shim()
8 changes: 7 additions & 1 deletion umu/umu_test.py
Original file line number Diff line number Diff line change
Expand Up @@ -1299,6 +1299,10 @@ def test_build_command(self):
# Mock the proton file
Path(self.test_file, "proton").touch()

# Mock the shim file
shim_path = Path(self.test_local_share, "umu-shim")
shim_path.touch()

with (
patch("sys.argv", ["", self.test_exe]),
ThreadPoolExecutor() as thread_pool,
Expand Down Expand Up @@ -1353,7 +1357,7 @@ def test_build_command(self):
7,
f"Expected 7 elements, received {len(test_command)}",
)
entry_point, opt1, verb, opt2, proton, verb2, exe = [*test_command]
entry_point, opt1, verb, opt2, shim, proton, verb2, exe = [*test_command]
# The entry point dest could change. Just check if there's a value
self.assertTrue(entry_point, "Expected an entry point")
self.assertIsInstance(
Expand All @@ -1362,6 +1366,8 @@ def test_build_command(self):
self.assertEqual(opt1, "--verb", "Expected --verb")
self.assertEqual(verb, self.test_verb, "Expected a verb")
self.assertEqual(opt2, "--", "Expected --")
self.assertIsInstance(shim, os.PathLike, "Expected shim to be PathLike")
self.assertEqual(shim, shim_path, "Expected the shim file")
self.assertIsInstance(proton, os.PathLike, "Expected proton to be PathLike")
self.assertEqual(
proton,
Expand Down

0 comments on commit 25f5311

Please sign in to comment.