feat: adapt WineTab to new cli
All checks were successful
Code check / Check code (push) Successful in 1m13s
All checks were successful
Code check / Check code (push) Successful in 1m13s
Signed-off-by: Boris Yumankulov <boria138@altlinux.org>
This commit is contained in:
@@ -1,9 +1,11 @@
|
||||
import sys
|
||||
import os
|
||||
import subprocess
|
||||
from PySide6.QtCore import QLocale, QTranslator, QLibraryInfo
|
||||
from PySide6.QtWidgets import QApplication
|
||||
from PySide6.QtGui import QIcon
|
||||
from portprotonqt.main_window import MainWindow
|
||||
from portprotonqt.config_utils import save_fullscreen_config
|
||||
from portprotonqt.config_utils import save_fullscreen_config, get_portproton_location
|
||||
from portprotonqt.logger import get_logger, setup_logger
|
||||
from portprotonqt.cli import parse_args
|
||||
|
||||
@@ -12,6 +14,19 @@ __app_name__ = "PortProtonQt"
|
||||
__app_version__ = "0.1.6"
|
||||
|
||||
def main():
|
||||
|
||||
os.environ['PW_CLI'] = '1'
|
||||
os.environ['PROCESS_LOG'] = '1'
|
||||
os.environ['START_FROM_STEAM'] = '1'
|
||||
|
||||
portproton_path = get_portproton_location()
|
||||
|
||||
if portproton_path is None:
|
||||
return
|
||||
|
||||
script_path = os.path.join(portproton_path, 'data', 'scripts', 'start.sh')
|
||||
subprocess.run([script_path, 'cli', '--initial'])
|
||||
|
||||
app = QApplication(sys.argv)
|
||||
app.setWindowIcon(QIcon.fromTheme(__app_id__))
|
||||
app.setDesktopFileName(__app_id__)
|
||||
|
@@ -166,7 +166,6 @@ class MainWindow(QMainWindow):
|
||||
tabs = [
|
||||
_("Library"),
|
||||
_("Auto Install"),
|
||||
_("Emulators"),
|
||||
_("Wine Settings"),
|
||||
_("PortProton Settings"),
|
||||
_("Themes")
|
||||
@@ -198,7 +197,6 @@ class MainWindow(QMainWindow):
|
||||
|
||||
self.createInstalledTab()
|
||||
self.createAutoInstallTab()
|
||||
self.createEmulatorsTab()
|
||||
self.createWineTab()
|
||||
self.createPortProtonTab()
|
||||
self.createThemeTab()
|
||||
@@ -980,32 +978,10 @@ class MainWindow(QMainWindow):
|
||||
|
||||
self.stackedWidget.addWidget(self.autoInstallWidget)
|
||||
|
||||
def createEmulatorsTab(self):
|
||||
"""Вкладка 'Emulators'."""
|
||||
self.emulatorsWidget = QWidget()
|
||||
self.emulatorsWidget.setStyleSheet(self.theme.OTHER_PAGES_WIDGET_STYLE)
|
||||
self.emulatorsWidget.setObjectName("otherPage")
|
||||
layout = QVBoxLayout(self.emulatorsWidget)
|
||||
layout.setContentsMargins(10, 18, 10, 10)
|
||||
|
||||
self.emulatorsTitle = QLabel(_("Emulators"))
|
||||
self.emulatorsTitle.setStyleSheet(self.theme.TAB_TITLE_STYLE)
|
||||
self.emulatorsTitle.setObjectName("tabTitle")
|
||||
layout.addWidget(self.emulatorsTitle)
|
||||
|
||||
self.emulatorsContent = QLabel(_("List of available emulators and their configuration..."))
|
||||
self.emulatorsContent.setStyleSheet(self.theme.CONTENT_STYLE)
|
||||
self.emulatorsContent.setObjectName("tabContent")
|
||||
layout.addWidget(self.emulatorsContent)
|
||||
layout.addStretch(1)
|
||||
|
||||
self.stackedWidget.addWidget(self.emulatorsWidget)
|
||||
|
||||
def createWineTab(self):
|
||||
"""Вкладка 'Wine Settings'."""
|
||||
self.wineWidget = QWidget()
|
||||
self.wineWidget.setStyleSheet(self.theme.OTHER_PAGES_WIDGET_STYLE)
|
||||
self.wineWidget.setObjectName("otherPage")
|
||||
layout = QVBoxLayout(self.wineWidget)
|
||||
layout.setContentsMargins(10, 18, 10, 10)
|
||||
|
||||
@@ -1070,12 +1046,13 @@ class MainWindow(QMainWindow):
|
||||
("uninstaller", _("Uninstaller")),
|
||||
]
|
||||
|
||||
for i, (_tool_cmd, tool_name) in enumerate(tools):
|
||||
for i, (tool_cmd, tool_name) in enumerate(tools):
|
||||
row = i // 3
|
||||
col = i % 3
|
||||
btn = AutoSizeButton(tool_name, update_size=False)
|
||||
btn.setStyleSheet(self.theme.ACTION_BUTTON_STYLE)
|
||||
btn.setFocusPolicy(Qt.FocusPolicy.StrongFocus)
|
||||
btn.clicked.connect(lambda checked, t=tool_cmd: self.launch_wine_tool(t))
|
||||
tools_grid.addWidget(btn, row, col)
|
||||
|
||||
for col in range(3):
|
||||
@@ -1093,7 +1070,7 @@ class MainWindow(QMainWindow):
|
||||
(_("Load Prefix Backup"), self.load_prefix_backup),
|
||||
(_("Delete Compatibility Tool"), self.delete_compat_tool),
|
||||
(_("Delete Prefix"), self.delete_prefix),
|
||||
(_("Clear Prefix"), None),
|
||||
(_("Clear Prefix"), self.clear_prefix),
|
||||
]
|
||||
|
||||
for i, (text, callback) in enumerate(additional_buttons):
|
||||
@@ -1116,6 +1093,70 @@ class MainWindow(QMainWindow):
|
||||
|
||||
self.stackedWidget.addWidget(self.wineWidget)
|
||||
|
||||
def launch_wine_tool(self, tool):
|
||||
mapping = {
|
||||
"winecfg": ("--winecfg", None),
|
||||
"regedit": ("--winereg", None),
|
||||
"control": ("--winecmd", "control"),
|
||||
"taskmgr": ("--winecmd", "taskmgr"),
|
||||
"explorer": ("--winefile", None),
|
||||
"cmd": ("--winecmd", None),
|
||||
"uninstaller": ("--wine_uninstaller", None),
|
||||
}
|
||||
if tool not in mapping:
|
||||
return
|
||||
cli_arg, extra = mapping[tool]
|
||||
self.launch_generic_tool(cli_arg, extra)
|
||||
|
||||
def launch_generic_tool(self, cli_arg, extra=None):
|
||||
wine = self.wineCombo.currentText()
|
||||
prefix = self.prefixCombo.currentText()
|
||||
if not wine or not prefix:
|
||||
return
|
||||
if not self.portproton_location:
|
||||
return
|
||||
start_sh = os.path.join(self.portproton_location, "data", "scripts", "start.sh")
|
||||
if not os.path.exists(start_sh):
|
||||
return
|
||||
cmd = [start_sh, cli_arg, wine, prefix]
|
||||
if extra:
|
||||
cmd.append(extra)
|
||||
proc = QProcess(self)
|
||||
proc.start(cmd[0], cmd[1:])
|
||||
if not proc.waitForStarted():
|
||||
QMessageBox.warning(self, _("Error"), _("Failed to start process."))
|
||||
|
||||
def clear_prefix(self):
|
||||
selected_prefix = self.prefixCombo.currentText()
|
||||
selected_wine = self.wineCombo.currentText()
|
||||
if not selected_prefix or not selected_wine:
|
||||
return
|
||||
if not self.portproton_location:
|
||||
return
|
||||
reply = QMessageBox.question(
|
||||
self,
|
||||
_("Confirm Clear"),
|
||||
_("Are you sure you want to clear prefix '{}'?").format(selected_prefix),
|
||||
QMessageBox.StandardButton.Yes | QMessageBox.StandardButton.No,
|
||||
QMessageBox.StandardButton.No
|
||||
)
|
||||
if reply == QMessageBox.StandardButton.Yes:
|
||||
start_sh = os.path.join(self.portproton_location, "data", "scripts", "start.sh")
|
||||
if not os.path.exists(start_sh):
|
||||
return
|
||||
self.clear_process = QProcess(self)
|
||||
self.clear_process.finished.connect(lambda exitCode, exitStatus: self._on_clear_finished(exitCode))
|
||||
cmd = [start_sh, "--clear_pfx", selected_wine, selected_prefix]
|
||||
self.clear_process.start(cmd[0], cmd[1:])
|
||||
if not self.clear_process.waitForStarted():
|
||||
QMessageBox.warning(self, _("Error"), _("Failed to start clear process."))
|
||||
|
||||
def _on_clear_finished(self, exitCode):
|
||||
if exitCode == 0:
|
||||
QMessageBox.information(self, _("Success"), _("Prefix cleared."))
|
||||
else:
|
||||
QMessageBox.warning(self, _("Error"), _("Prefix clear failed."))
|
||||
|
||||
def create_prefix_backup(self):
|
||||
selected_prefix = self.prefixCombo.currentText()
|
||||
if not selected_prefix:
|
||||
@@ -1196,8 +1237,9 @@ class MainWindow(QMainWindow):
|
||||
QMessageBox.information(self, _("Success"), _("Prefix '{}' deleted.").format(selected_prefix))
|
||||
# обновляем список
|
||||
self.prefixCombo.clear()
|
||||
self.prefixes = [d for d in os.listdir(os.path.join(self.portproton_location, "data", "prefixes"))
|
||||
if os.path.isdir(os.path.join(self.portproton_location, "data", "prefixes", d))]
|
||||
prefixes_path = os.path.join(self.portproton_location, "data", "prefixes")
|
||||
self.prefixes = [d for d in os.listdir(prefixes_path)
|
||||
if os.path.isdir(os.path.join(prefixes_path, d))]
|
||||
self.prefixCombo.addItems(self.prefixes)
|
||||
except Exception as e:
|
||||
QMessageBox.warning(self, _("Error"), _("Failed to delete prefix: {}").format(str(e)))
|
||||
@@ -2392,9 +2434,7 @@ class MainWindow(QMainWindow):
|
||||
else:
|
||||
# Запускаем игру через PortProton
|
||||
env_vars = os.environ.copy()
|
||||
env_vars['START_FROM_STEAM'] = '1'
|
||||
env_vars['LEGENDARY_CONFIG_PATH'] = self.legendary_config_path
|
||||
env_vars['PROCESS_LOG'] = '1'
|
||||
|
||||
wrapper = "flatpak run ru.linux_gaming.PortProton"
|
||||
if self.portproton_location is not None and ".var" not in self.portproton_location:
|
||||
|
Reference in New Issue
Block a user