Compare commits
5 Commits
e91037708a
...
v0.1.4
Author | SHA1 | Date | |
---|---|---|---|
85e9aba836
|
|||
4d3499d2c1
|
|||
a13c15bc28
|
|||
83076d3dfc
|
|||
04aaf68e36
|
@@ -17,10 +17,12 @@ jobs:
|
|||||||
- name: Install required dependencies
|
- name: Install required dependencies
|
||||||
run: |
|
run: |
|
||||||
sudo apt update
|
sudo apt update
|
||||||
sudo apt install -y binutils coreutils desktop-file-utils gtk-update-icon-cache fakeroot fuse libgdk-pixbuf2.0-dev patchelf python3-pip python3-dev python3-setuptools squashfs-tools strace util-linux zsync
|
sudo apt install -y binutils coreutils desktop-file-utils gtk-update-icon-cache fakeroot fuse libgdk-pixbuf2.0-dev patchelf python3-pip python3-dev python3-setuptools squashfs-tools strace util-linux zsync git
|
||||||
|
|
||||||
- name: Install tools
|
- name: Install tools
|
||||||
run: pip3 install appimage-builder uv
|
run: |
|
||||||
|
pip3 install git+https://github.com/Frederic98/appimage-builder.git
|
||||||
|
pip3 install uv
|
||||||
|
|
||||||
- name: Build AppImage
|
- name: Build AppImage
|
||||||
run: |
|
run: |
|
||||||
|
@@ -8,7 +8,7 @@ on:
|
|||||||
|
|
||||||
env:
|
env:
|
||||||
# Common version, will be used for tagging the release
|
# Common version, will be used for tagging the release
|
||||||
VERSION: 0.1.3
|
VERSION: 0.1.4
|
||||||
PKGDEST: "/tmp/portprotonqt"
|
PKGDEST: "/tmp/portprotonqt"
|
||||||
PACKAGE: "portprotonqt"
|
PACKAGE: "portprotonqt"
|
||||||
GITEA_TOKEN: ${{ secrets.GITEA_TOKEN }}
|
GITEA_TOKEN: ${{ secrets.GITEA_TOKEN }}
|
||||||
@@ -23,10 +23,12 @@ jobs:
|
|||||||
- name: Install required dependencies
|
- name: Install required dependencies
|
||||||
run: |
|
run: |
|
||||||
sudo apt update
|
sudo apt update
|
||||||
sudo apt install -y binutils coreutils desktop-file-utils gtk-update-icon-cache fakeroot fuse libgdk-pixbuf2.0-dev patchelf python3-pip python3-dev python3-setuptools squashfs-tools strace util-linux zsync
|
sudo apt install -y binutils coreutils desktop-file-utils gtk-update-icon-cache fakeroot fuse libgdk-pixbuf2.0-dev patchelf python3-pip python3-dev python3-setuptools squashfs-tools strace util-linux zsync git
|
||||||
|
|
||||||
- name: Install tools
|
- name: Install tools
|
||||||
run: pip3 install appimage-builder uv
|
run: |
|
||||||
|
pip3 install git+https://github.com/Frederic98/appimage-builder.git
|
||||||
|
pip3 install uv
|
||||||
|
|
||||||
- name: Build AppImage
|
- name: Build AppImage
|
||||||
run: |
|
run: |
|
||||||
|
187
.gitea/workflows/code-build.yml
Normal file
187
.gitea/workflows/code-build.yml
Normal file
@@ -0,0 +1,187 @@
|
|||||||
|
name: Build Check - AppImage, Arch, Fedora
|
||||||
|
|
||||||
|
on:
|
||||||
|
workflow_dispatch:
|
||||||
|
pull_request:
|
||||||
|
paths:
|
||||||
|
- 'build-aux/**'
|
||||||
|
|
||||||
|
env:
|
||||||
|
PKGDEST: "/tmp/portprotonqt"
|
||||||
|
PACKAGE: "portprotonqt"
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
changes:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
outputs:
|
||||||
|
appimage: ${{ steps.check.outputs.appimage }}
|
||||||
|
fedora: ${{ steps.check.outputs.fedora }}
|
||||||
|
arch: ${{ steps.check.outputs.arch }}
|
||||||
|
steps:
|
||||||
|
- uses: https://gitea.com/actions/checkout@v4
|
||||||
|
with:
|
||||||
|
fetch-depth: 0
|
||||||
|
|
||||||
|
- name: Ensure git is installed
|
||||||
|
run: |
|
||||||
|
sudo apt update
|
||||||
|
sudo apt install -y git
|
||||||
|
|
||||||
|
- name: Check changed files
|
||||||
|
id: check
|
||||||
|
run: |
|
||||||
|
# Get changed files
|
||||||
|
git diff --name-only ${{ github.event.pull_request.base.sha }}...${{ github.event.pull_request.head.sha }} > changed_files.txt
|
||||||
|
|
||||||
|
echo "Changed files:"
|
||||||
|
cat changed_files.txt
|
||||||
|
|
||||||
|
# Check AppImage files
|
||||||
|
if grep -q "build-aux/AppImageBuilder.yml" changed_files.txt; then
|
||||||
|
echo "appimage=true" >> $GITHUB_OUTPUT
|
||||||
|
else
|
||||||
|
echo "appimage=false" >> $GITHUB_OUTPUT
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Check Fedora spec files (only fedora-git.spec)
|
||||||
|
if grep -q "build-aux/fedora-git.spec" changed_files.txt; then
|
||||||
|
echo "fedora=true" >> $GITHUB_OUTPUT
|
||||||
|
else
|
||||||
|
echo "fedora=false" >> $GITHUB_OUTPUT
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Check Arch PKGBUILD-git
|
||||||
|
if grep -q "build-aux/PKGBUILD-git" changed_files.txt; then
|
||||||
|
echo "arch=true" >> $GITHUB_OUTPUT
|
||||||
|
else
|
||||||
|
echo "arch=false" >> $GITHUB_OUTPUT
|
||||||
|
fi
|
||||||
|
|
||||||
|
build-appimage:
|
||||||
|
name: Build AppImage
|
||||||
|
runs-on: ubuntu-22.04
|
||||||
|
needs: changes
|
||||||
|
if: needs.changes.outputs.appimage == 'true' || github.event_name == 'workflow_dispatch'
|
||||||
|
steps:
|
||||||
|
- uses: https://gitea.com/actions/checkout@v4
|
||||||
|
|
||||||
|
- name: Install required dependencies
|
||||||
|
run: |
|
||||||
|
sudo apt update
|
||||||
|
sudo apt install -y binutils coreutils desktop-file-utils gtk-update-icon-cache fakeroot fuse libgdk-pixbuf2.0-dev patchelf python3-pip python3-dev python3-setuptools squashfs-tools strace util-linux zsync git
|
||||||
|
|
||||||
|
- name: Install tools
|
||||||
|
run: |
|
||||||
|
pip3 install git+https://github.com/Frederic98/appimage-builder.git
|
||||||
|
pip3 install uv
|
||||||
|
|
||||||
|
- name: Build AppImage
|
||||||
|
run: |
|
||||||
|
cd build-aux
|
||||||
|
appimage-builder
|
||||||
|
|
||||||
|
- name: Upload AppImage
|
||||||
|
uses: https://gitea.com/actions/gitea-upload-artifact@v4
|
||||||
|
with:
|
||||||
|
name: PortProtonQt-AppImage
|
||||||
|
path: build-aux/PortProtonQt*.AppImage
|
||||||
|
|
||||||
|
build-fedora:
|
||||||
|
name: Build Fedora RPM
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
needs: changes
|
||||||
|
if: needs.changes.outputs.fedora == 'true' || github.event_name == 'workflow_dispatch'
|
||||||
|
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
fedora_version: [41, 42, rawhide]
|
||||||
|
|
||||||
|
container:
|
||||||
|
image: fedora:${{ matrix.fedora_version }}
|
||||||
|
options: --privileged
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Install build dependencies
|
||||||
|
run: |
|
||||||
|
dnf install -y git rpmdevtools python3-devel python3-wheel python3-pip \
|
||||||
|
python3-build pyproject-rpm-macros python3-setuptools \
|
||||||
|
redhat-rpm-config nodejs npm
|
||||||
|
|
||||||
|
- name: Setup rpmbuild environment
|
||||||
|
run: |
|
||||||
|
useradd rpmbuild -u 5002 -g users || true
|
||||||
|
mkdir -p /home/rpmbuild/{BUILD,RPMS,SPECS,SRPMS,SOURCES}
|
||||||
|
chown -R rpmbuild:users /home/rpmbuild
|
||||||
|
echo '%_topdir /home/rpmbuild' > /home/rpmbuild/.rpmmacros
|
||||||
|
|
||||||
|
- name: Checkout repo
|
||||||
|
uses: https://gitea.com/actions/checkout@v4
|
||||||
|
|
||||||
|
- name: Copy fedora-git.spec
|
||||||
|
run: |
|
||||||
|
cp build-aux/fedora-git.spec /home/rpmbuild/SPECS/${{ env.PACKAGE }}.spec
|
||||||
|
chown -R rpmbuild:users /home/rpmbuild
|
||||||
|
|
||||||
|
- name: Build RPM
|
||||||
|
run: |
|
||||||
|
su rpmbuild -c "rpmbuild -ba /home/rpmbuild/SPECS/${{ env.PACKAGE }}.spec"
|
||||||
|
|
||||||
|
- name: Upload RPM package
|
||||||
|
uses: https://gitea.com/actions/gitea-upload-artifact@v4
|
||||||
|
with:
|
||||||
|
name: PortProtonQt-RPM-Fedora-${{ matrix.fedora_version }}
|
||||||
|
path: /home/rpmbuild/RPMS/**/*.rpm
|
||||||
|
|
||||||
|
build-arch:
|
||||||
|
name: Build Arch Package
|
||||||
|
runs-on: ubuntu-22.04
|
||||||
|
needs: changes
|
||||||
|
if: needs.changes.outputs.arch == 'true' || github.event_name == 'workflow_dispatch'
|
||||||
|
container:
|
||||||
|
image: archlinux:base-devel
|
||||||
|
volumes:
|
||||||
|
- /usr:/usr-host
|
||||||
|
- /opt:/opt-host
|
||||||
|
options: --privileged
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Prepare container
|
||||||
|
run: |
|
||||||
|
pacman -Sy --noconfirm --disable-download-timeout --needed git wget gnupg nodejs npm
|
||||||
|
sed -i 's/#MAKEFLAGS="-j2"/MAKEFLAGS="-j$(nproc) -l$(nproc)"/g' /etc/makepkg.conf
|
||||||
|
sed -i 's/OPTIONS=(.*)/OPTIONS=(strip docs !libtool !staticlibs emptydirs zipman purge lto)/g' /etc/makepkg.conf
|
||||||
|
yes | pacman -Scc
|
||||||
|
pacman-key --init
|
||||||
|
pacman -S --noconfirm archlinux-keyring
|
||||||
|
mkdir -p /__w/portproton-repo
|
||||||
|
pacman-key --recv-key 3056513887B78AEB --keyserver keyserver.ubuntu.com
|
||||||
|
pacman-key --lsign-key 3056513887B78AEB
|
||||||
|
pacman -U --noconfirm 'https://cdn-mirror.chaotic.cx/chaotic-aur/chaotic-keyring.pkg.tar.zst'
|
||||||
|
pacman -U --noconfirm 'https://cdn-mirror.chaotic.cx/chaotic-aur/chaotic-mirrorlist.pkg.tar.zst'
|
||||||
|
cat << EOM >> /etc/pacman.conf
|
||||||
|
|
||||||
|
[chaotic-aur]
|
||||||
|
Include = /etc/pacman.d/chaotic-mirrorlist
|
||||||
|
EOM
|
||||||
|
pacman -Syy
|
||||||
|
useradd -m user -G wheel && echo "user ALL=(ALL) NOPASSWD: ALL" >> /etc/sudoers
|
||||||
|
echo "PACKAGER=\"Boris Yumankulov <boria138@altlinux.org>\"" >> /etc/makepkg.conf
|
||||||
|
chown user -R /tmp
|
||||||
|
chown user -R ..
|
||||||
|
|
||||||
|
- name: Build
|
||||||
|
run: |
|
||||||
|
cd /__w/portproton-repo
|
||||||
|
git clone https://git.linux-gaming.ru/Boria138/PortProtonQt.git
|
||||||
|
cd /__w/portproton-repo/PortProtonQt/build-aux
|
||||||
|
chown user -R ..
|
||||||
|
su user -c "yes '' | makepkg --noconfirm -s -p PKGBUILD-git"
|
||||||
|
|
||||||
|
- name: Checkout
|
||||||
|
uses: https://gitea.com/actions/checkout@v4
|
||||||
|
|
||||||
|
- name: Upload Arch package
|
||||||
|
uses: https://gitea.com/actions/gitea-upload-artifact@v4
|
||||||
|
with:
|
||||||
|
name: PortProtonQt-Arch
|
||||||
|
path: ${{ env.PKGDEST }}/*
|
@@ -1,4 +1,4 @@
|
|||||||
name: Code and build check
|
name: Code check
|
||||||
|
|
||||||
on:
|
on:
|
||||||
pull_request:
|
pull_request:
|
||||||
@@ -35,20 +35,3 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
source .venv/bin/activate
|
source .venv/bin/activate
|
||||||
pre-commit run --show-diff-on-failure --color=always --all-files
|
pre-commit run --show-diff-on-failure --color=always --all-files
|
||||||
|
|
||||||
build-uv:
|
|
||||||
name: Build with uv
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- uses: https://gitea.com/actions/checkout@v4
|
|
||||||
|
|
||||||
- name: Install uv
|
|
||||||
uses: https://github.com/astral-sh/setup-uv@v6
|
|
||||||
with:
|
|
||||||
enable-cache: true
|
|
||||||
|
|
||||||
- name: Sync dependencies
|
|
||||||
run: uv sync
|
|
||||||
|
|
||||||
- name: Build project
|
|
||||||
run: uv build
|
|
||||||
|
@@ -3,7 +3,7 @@
|
|||||||
Все заметные изменения в этом проекте фиксируются в этом файле.
|
Все заметные изменения в этом проекте фиксируются в этом файле.
|
||||||
Формат основан на [Keep a Changelog](https://keepachangelog.com/) и придерживается принципов [Semantic Versioning](https://semver.org/).
|
Формат основан на [Keep a Changelog](https://keepachangelog.com/) и придерживается принципов [Semantic Versioning](https://semver.org/).
|
||||||
|
|
||||||
## [Unreleased]
|
## [0.1.4] - 2025-07-21
|
||||||
|
|
||||||
### Added
|
### Added
|
||||||
- Переводы в переопределениях (за подробностями в документацию)
|
- Переводы в переопределениях (за подробностями в документацию)
|
||||||
@@ -17,11 +17,13 @@
|
|||||||
- Бейдж PortProton теперь открывает PortProtonDB
|
- Бейдж PortProton теперь открывает PortProtonDB
|
||||||
- Отключено переключение полноэкранного режима через F11 или кнопку Select на геймпаде в gamescope сессии
|
- Отключено переключение полноэкранного режима через F11 или кнопку Select на геймпаде в gamescope сессии
|
||||||
- Удалён аргумент `--session` так как тестирование gamescope сессии завершено
|
- Удалён аргумент `--session` так как тестирование gamescope сессии завершено
|
||||||
|
- В контекстном меню игр без exe файла теперь отображается только пункт "Удалить из PortProton"
|
||||||
|
|
||||||
### Fixed
|
### Fixed
|
||||||
- Запрос к GitHub API при загрузке legendary теперь не игнорирует настройки прокси
|
- Запрос к GitHub API при загрузке legendary теперь не игнорирует настройки прокси
|
||||||
- Путь к portprotonqt-session-select в оверлее
|
- Путь к portprotonqt-session-select в оверлее
|
||||||
- Работа exiftool в AppImage
|
- Работа exiftool в AppImage
|
||||||
|
- Открытие контекстного меню у игр без exe
|
||||||
|
|
||||||
### Contributors
|
### Contributors
|
||||||
- @Vector_null
|
- @Vector_null
|
||||||
|
@@ -45,7 +45,7 @@ AppDir:
|
|||||||
id: ru.linux_gaming.PortProtonQt
|
id: ru.linux_gaming.PortProtonQt
|
||||||
name: PortProtonQt
|
name: PortProtonQt
|
||||||
icon: ru.linux_gaming.PortProtonQt
|
icon: ru.linux_gaming.PortProtonQt
|
||||||
version: 0.1.3
|
version: 0.1.4
|
||||||
exec: usr/bin/python3
|
exec: usr/bin/python3
|
||||||
exec_args: "-m portprotonqt.app $@"
|
exec_args: "-m portprotonqt.app $@"
|
||||||
apt:
|
apt:
|
||||||
@@ -82,4 +82,5 @@ AppDir:
|
|||||||
PERLLIB: '${APPDIR}/usr/share/perl5:${APPDIR}/usr/lib/x86_64-linux-gnu/perl/5.34:${APPDIR}/usr/share/perl/5.34'
|
PERLLIB: '${APPDIR}/usr/share/perl5:${APPDIR}/usr/lib/x86_64-linux-gnu/perl/5.34:${APPDIR}/usr/share/perl/5.34'
|
||||||
AppImage:
|
AppImage:
|
||||||
sign-key: None
|
sign-key: None
|
||||||
|
comp: xz
|
||||||
arch: x86_64
|
arch: x86_64
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
pkgname=portprotonqt
|
pkgname=portprotonqt
|
||||||
pkgver=0.1.3
|
pkgver=0.1.4
|
||||||
pkgrel=1
|
pkgrel=1
|
||||||
pkgdesc="Modern GUI for managing and launching games from PortProton, Steam, and Epic Games Store"
|
pkgdesc="Modern GUI for managing and launching games from PortProton, Steam, and Epic Games Store"
|
||||||
arch=('any')
|
arch=('any')
|
||||||
|
@@ -1,5 +1,5 @@
|
|||||||
%global pypi_name portprotonqt
|
%global pypi_name portprotonqt
|
||||||
%global pypi_version 0.1.3
|
%global pypi_version 0.1.4
|
||||||
%global oname PortProtonQt
|
%global oname PortProtonQt
|
||||||
%global _python_no_extras_requires 1
|
%global _python_no_extras_requires 1
|
||||||
|
|
||||||
|
@@ -12,7 +12,7 @@ logger = get_logger(__name__)
|
|||||||
|
|
||||||
__app_id__ = "ru.linux_gaming.PortProtonQt"
|
__app_id__ = "ru.linux_gaming.PortProtonQt"
|
||||||
__app_name__ = "PortProtonQt"
|
__app_name__ = "PortProtonQt"
|
||||||
__app_version__ = "0.1.3"
|
__app_version__ = "0.1.4"
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
app = QApplication(sys.argv)
|
app = QApplication(sys.argv)
|
||||||
|
@@ -148,10 +148,7 @@ class ContextMenuManager:
|
|||||||
return False
|
return False
|
||||||
current_exe = os.path.basename(exe_path)
|
current_exe = os.path.basename(exe_path)
|
||||||
|
|
||||||
# Check if the current_exe matches the target_exe in MainWindow
|
return hasattr(self.parent, 'target_exe') and self.parent.target_exe == current_exe
|
||||||
if hasattr(self.parent, 'target_exe') and self.parent.target_exe == current_exe:
|
|
||||||
return True
|
|
||||||
return False
|
|
||||||
|
|
||||||
def show_context_menu(self, game_card, pos: QPoint):
|
def show_context_menu(self, game_card, pos: QPoint):
|
||||||
"""
|
"""
|
||||||
@@ -161,7 +158,6 @@ class ContextMenuManager:
|
|||||||
game_card: The GameCard instance requesting the context menu.
|
game_card: The GameCard instance requesting the context menu.
|
||||||
pos: The position (in widget coordinates) where the menu should appear.
|
pos: The position (in widget coordinates) where the menu should appear.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def get_safe_icon(icon_name: str) -> QIcon:
|
def get_safe_icon(icon_name: str) -> QIcon:
|
||||||
icon = self.theme_manager.get_icon(icon_name)
|
icon = self.theme_manager.get_icon(icon_name)
|
||||||
if isinstance(icon, QIcon):
|
if isinstance(icon, QIcon):
|
||||||
@@ -173,7 +169,18 @@ class ContextMenuManager:
|
|||||||
menu = QMenu(self.parent)
|
menu = QMenu(self.parent)
|
||||||
menu.setStyleSheet(self.theme.CONTEXT_MENU_STYLE)
|
menu.setStyleSheet(self.theme.CONTEXT_MENU_STYLE)
|
||||||
|
|
||||||
# Check if the game is running
|
# For non-Steam and non-Epic games, check if exe exists
|
||||||
|
if game_card.game_source not in ("steam", "epic"):
|
||||||
|
exec_line = self._get_exec_line(game_card.name, game_card.exec_line)
|
||||||
|
exe_path = self._parse_exe_path(exec_line, game_card.name) if exec_line else None
|
||||||
|
if not exe_path:
|
||||||
|
# Show only "Delete from PortProton" if no valid exe
|
||||||
|
delete_action = menu.addAction(get_safe_icon("delete"), _("Delete from PortProton"))
|
||||||
|
delete_action.triggered.connect(lambda: self.delete_game(game_card.name, game_card.exec_line))
|
||||||
|
menu.exec(game_card.mapToGlobal(pos))
|
||||||
|
return
|
||||||
|
|
||||||
|
# Normal menu for games with valid exe or from Steam/Epic
|
||||||
is_running = self._is_game_running(game_card)
|
is_running = self._is_game_running(game_card)
|
||||||
action_text = _("Stop Game") if is_running else _("Launch Game")
|
action_text = _("Stop Game") if is_running else _("Launch Game")
|
||||||
action_icon = "stop" if is_running else "play"
|
action_icon = "stop" if is_running else "play"
|
||||||
@@ -697,15 +704,12 @@ Icon={icon_path}
|
|||||||
return None
|
return None
|
||||||
return exec_line
|
return exec_line
|
||||||
|
|
||||||
def _parse_exe_path(self, exec_line, game_name):
|
def _parse_exe_path(self, exec_line: str, game_name: str) -> str | None:
|
||||||
"""Parse the executable path from exec_line."""
|
"""Parse the executable path from exec_line."""
|
||||||
try:
|
try:
|
||||||
entry_exec_split = shlex.split(exec_line)
|
entry_exec_split = shlex.split(exec_line)
|
||||||
if not entry_exec_split:
|
if not entry_exec_split:
|
||||||
self.signals.show_warning_dialog.emit(
|
logger.debug("Invalid executable command for '%s': %s", game_name, exec_line)
|
||||||
_("Error"),
|
|
||||||
_("Invalid executable command: {exec_line}").format(exec_line=exec_line)
|
|
||||||
)
|
|
||||||
return None
|
return None
|
||||||
if entry_exec_split[0] == "env" and len(entry_exec_split) >= 3:
|
if entry_exec_split[0] == "env" and len(entry_exec_split) >= 3:
|
||||||
exe_path = entry_exec_split[2]
|
exe_path = entry_exec_split[2]
|
||||||
@@ -714,17 +718,11 @@ Icon={icon_path}
|
|||||||
else:
|
else:
|
||||||
exe_path = entry_exec_split[-1]
|
exe_path = entry_exec_split[-1]
|
||||||
if not exe_path or not os.path.exists(exe_path):
|
if not exe_path or not os.path.exists(exe_path):
|
||||||
self.signals.show_warning_dialog.emit(
|
logger.debug("Executable not found for '%s': %s", game_name, exe_path or "None")
|
||||||
_("Error"),
|
|
||||||
_("Executable not found: {path}").format(path=exe_path or "None")
|
|
||||||
)
|
|
||||||
return None
|
return None
|
||||||
return exe_path
|
return exe_path
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
self.signals.show_warning_dialog.emit(
|
logger.debug("Failed to parse executable for '%s': %s", game_name, e)
|
||||||
_("Error"),
|
|
||||||
_("Failed to parse executable: {error}").format(error=str(e))
|
|
||||||
)
|
|
||||||
return None
|
return None
|
||||||
|
|
||||||
def _remove_file(self, file_path, error_message, success_message, game_name, location=""):
|
def _remove_file(self, file_path, error_message, success_message, game_name, location=""):
|
||||||
|
@@ -4,7 +4,7 @@ build-backend = "setuptools.build_meta"
|
|||||||
|
|
||||||
[project]
|
[project]
|
||||||
name = "portprotonqt"
|
name = "portprotonqt"
|
||||||
version = "0.1.3"
|
version = "0.1.4"
|
||||||
description = "A project to rewrite PortProton (PortWINE) using PySide"
|
description = "A project to rewrite PortProton (PortWINE) using PySide"
|
||||||
readme = "README.md"
|
readme = "README.md"
|
||||||
license = { text = "GPL-3.0" }
|
license = { text = "GPL-3.0" }
|
||||||
|
Reference in New Issue
Block a user