mirror of
https://github.com/Omni-guides/Jackify.git
synced 2026-06-08 01:47:45 +02:00
148 lines
6.3 KiB
Python
148 lines
6.3 KiB
Python
#!/usr/bin/env python3
|
|
# -*- coding: utf-8 -*-
|
|
"""
|
|
Protontricks run/launch commands mixin.
|
|
Extracted from protontricks_handler for file-size and domain separation.
|
|
"""
|
|
|
|
import os
|
|
import subprocess
|
|
from pathlib import Path
|
|
import shutil
|
|
from typing import Optional
|
|
|
|
import logging
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
|
class ProtontricksCommandsMixin:
|
|
"""Mixin providing run_protontricks and run_protontricks_launch."""
|
|
|
|
def run_protontricks(self, *args, **kwargs):
|
|
"""
|
|
Run protontricks with the given arguments and keyword arguments.
|
|
kwargs are passed to subprocess.run (e.g., stderr=subprocess.DEVNULL).
|
|
Returns subprocess.CompletedProcess or None.
|
|
"""
|
|
if self.which_protontricks is None:
|
|
if not self.detect_protontricks():
|
|
self.logger.error("Could not detect protontricks installation")
|
|
return None
|
|
|
|
if self.which_protontricks == 'bundled':
|
|
from .subprocess_utils import get_safe_python_executable
|
|
python_exe = get_safe_python_executable()
|
|
wrapper_script = self._get_bundled_protontricks_wrapper_path()
|
|
if wrapper_script and Path(wrapper_script).exists():
|
|
cmd = [python_exe, str(wrapper_script)]
|
|
cmd.extend([str(a) for a in args])
|
|
else:
|
|
cmd = [python_exe, "-m", "protontricks.cli.main"]
|
|
cmd.extend([str(a) for a in args])
|
|
elif self.which_protontricks == 'flatpak':
|
|
cmd = list(self._get_flatpak_run_args())
|
|
if kwargs.get('env') and kwargs['env'].get('WINETRICKS_CACHE'):
|
|
try:
|
|
cache_val = str(Path(kwargs['env']['WINETRICKS_CACHE']).resolve())
|
|
cmd.append(f'--env=WINETRICKS_CACHE={cache_val}')
|
|
except Exception:
|
|
pass
|
|
cmd.append("com.github.Matoking.protontricks")
|
|
cmd.extend(args)
|
|
else:
|
|
cmd = ["protontricks"]
|
|
cmd.extend(args)
|
|
|
|
run_kwargs = {
|
|
'stdout': subprocess.PIPE,
|
|
'stderr': subprocess.PIPE,
|
|
'text': True,
|
|
**kwargs
|
|
}
|
|
|
|
cmd_str = ' '.join(map(str, cmd))
|
|
self.logger.debug("=" * 80)
|
|
self.logger.debug("PROTONTRICKS COMMAND (for manual reproduction):")
|
|
self.logger.debug(f" {cmd_str}")
|
|
self.logger.debug("=" * 80)
|
|
|
|
if 'env' in kwargs and kwargs['env']:
|
|
env = self._get_clean_subprocess_env()
|
|
env.update(kwargs['env'])
|
|
else:
|
|
env = self._get_clean_subprocess_env()
|
|
|
|
env['WINEDEBUG'] = '-all'
|
|
steam_dir = self._get_steam_dir_from_libraryfolders()
|
|
if steam_dir:
|
|
env['STEAM_DIR'] = str(steam_dir)
|
|
self.logger.debug(f"Set STEAM_DIR for protontricks: {steam_dir}")
|
|
else:
|
|
self.logger.warning("Could not determine STEAM_DIR from libraryfolders.vdf - protontricks may prompt user")
|
|
|
|
if self.which_protontricks == 'native':
|
|
winetricks_path = self._get_bundled_winetricks_path()
|
|
if winetricks_path:
|
|
env['WINETRICKS'] = str(winetricks_path)
|
|
self.logger.debug(f"Set WINETRICKS for native protontricks: {winetricks_path}")
|
|
else:
|
|
self.logger.info("Bundled winetricks not found - native protontricks will use system winetricks")
|
|
cabextract_path = self._get_bundled_cabextract_path()
|
|
if cabextract_path:
|
|
cabextract_dir = str(cabextract_path.parent)
|
|
current_path = env.get('PATH', '')
|
|
env['PATH'] = f"{cabextract_dir}{os.pathsep}{current_path}" if current_path else cabextract_dir
|
|
self.logger.debug(f"Added bundled cabextract to PATH for native protontricks: {cabextract_dir}")
|
|
else:
|
|
self.logger.info("Bundled cabextract not found - native protontricks will use system cabextract")
|
|
else:
|
|
self.logger.debug(f"Using {self.which_protontricks} protontricks - it has its own winetricks (cannot access AppImage mounts)")
|
|
|
|
from ..handlers.config_handler import ConfigHandler
|
|
config_handler = ConfigHandler()
|
|
debug_mode = config_handler.get('debug_mode', False)
|
|
if not debug_mode:
|
|
env['WINETRICKS_SUPER_QUIET'] = '1'
|
|
self.logger.debug("Set WINETRICKS_SUPER_QUIET=1 to suppress winetricks verbose output")
|
|
else:
|
|
self.logger.debug("Debug mode enabled - winetricks verbose output will be shown")
|
|
|
|
run_kwargs['env'] = env
|
|
try:
|
|
return subprocess.run(cmd, **run_kwargs)
|
|
except Exception as e:
|
|
self.logger.error(f"Error running protontricks: {e}")
|
|
return None
|
|
|
|
def run_protontricks_launch(self, appid, installer_path, *extra_args):
|
|
"""
|
|
Run protontricks-launch (for WebView or similar installers).
|
|
Returns subprocess.CompletedProcess or None.
|
|
"""
|
|
if self.which_protontricks is None:
|
|
if not self.detect_protontricks():
|
|
self.logger.error("Could not detect protontricks installation")
|
|
return None
|
|
if self.which_protontricks == 'bundled':
|
|
from .subprocess_utils import get_safe_python_executable
|
|
python_exe = get_safe_python_executable()
|
|
cmd = [python_exe, "-m", "protontricks.cli.launch", "--appid", appid, str(installer_path)]
|
|
elif self.which_protontricks == 'flatpak':
|
|
cmd = self._get_flatpak_run_args() + ["--command=protontricks-launch", "com.github.Matoking.protontricks", "--appid", appid, str(installer_path)]
|
|
else:
|
|
launch_path = shutil.which("protontricks-launch")
|
|
if not launch_path:
|
|
self.logger.error("protontricks-launch command not found in PATH.")
|
|
return None
|
|
cmd = [launch_path, "--appid", appid, str(installer_path)]
|
|
if extra_args:
|
|
cmd.extend(extra_args)
|
|
self.logger.debug(f"Running protontricks-launch: {' '.join(map(str, cmd))}")
|
|
try:
|
|
env = self._get_clean_subprocess_env()
|
|
return subprocess.run(cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE, text=True, env=env)
|
|
except Exception as e:
|
|
self.logger.error(f"Error running protontricks-launch: {e}")
|
|
return None
|