diff --git a/data_from_portwine/changelog_eng b/data_from_portwine/changelog_eng index 3d05b8c..41bd9c0 100644 --- a/data_from_portwine/changelog_eng +++ b/data_from_portwine/changelog_eng @@ -2,6 +2,15 @@ You can help us in the development of the project on the website: boosty.to/port ----------------------------------------- Changelog: +###Scripts version 2122### +* added the pp-games-lib plugin to the new PortProton/data/plugins/ details directory on github (plugin author: comrade zorn) https://github.com/zorn-v/PortProton-games-library +* updated scripts for installing and launching League of Legends (updated WINE_LOL_GE_7.0-4 - from now on there is no need to enter the root password to launch League of Legends) +* for GALLIUM_NINE to work, PROTON_GE is used by default +* in GALLIUM_NINE mode, the operation of launchers (such as Epic Games) has been fixed +* for Wargaming Game Center, the startup argument "--disable-gpu" is disabled automatically when using VULKAN mode. +* when using the DOTNET prefix, the black screen display in some applications has been fixed +* added a choice of downloading and automatic installation of WINE versions from Kron4ek + ###Scripts version 2121### * updated "PROTON_GE" to version 7-26 * fixed creation of shortcuts for WGC (to automatically fix existing shortcuts, just run the WGC installer from PortProton) diff --git a/data_from_portwine/changelog_rus b/data_from_portwine/changelog_rus index 7ecdade..ed45988 100755 --- a/data_from_portwine/changelog_rus +++ b/data_from_portwine/changelog_rus @@ -2,6 +2,15 @@ ----------------------------------------- История изменений: +###Scripts version 2122### +* добавлен плагин pp-games-lib в новый каталог PortProton/data/plugins/ подробности на github (автор плагина: товарищ zorn) https://github.com/zorn-v/PortProton-games-library +* обновлены срипты установки и запуска League of Legends (обновлен WINE_LOL_GE_7.0-4 - отныне нет необходимости вводить пароль рут для запуска League of Legends) +* для работы GALLIUM_NINE по умолчанию используется PROTON_GE +* в режиме GALLIUM_NINE исправлена работа лаунчеров (таких как Epic Games) +* для Wargaming Game Center аргумент запуска "--disable-gpu" отключаестя автоматически при исползовании режима VULKAN. +* при использовании префикса DOTNET исправлено отображение черного экрана в некоторых приложениях +* добавлен выбор скачивания и автоматической установки версий WINE от Kron4ek + ###Scripts version 2121### * обновлен "PROTON_GE" до версии 7-26 * исправлено создание ярлыков для WGC (для атоматического исправления уже существующих ярлыков, просто запустите установщик WGC из PortProton) diff --git a/data_from_portwine/plugins/pp-games-lib b/data_from_portwine/plugins/pp-games-lib new file mode 100755 index 0000000..9c70f2d --- /dev/null +++ b/data_from_portwine/plugins/pp-games-lib @@ -0,0 +1,409 @@ +#!/usr/bin/env python3 + +import os +import re +import shlex +import shutil +from configparser import ConfigParser +from pathlib import Path +from subprocess import run +from types import SimpleNamespace +try: + from PyQt6.QtCore import * # type: ignore + from PyQt6.QtGui import * # type: ignore + from PyQt6.QtWidgets import * # type: ignore +except ModuleNotFoundError: + from PyQt5.QtCore import * + from PyQt5.QtGui import * + from PyQt5.QtWidgets import * + +settings = QSettings('PPGL', 'PortProtonGamesLib') +g = SimpleNamespace() + +class MainWindow(QMainWindow): + def __init__(self): + super().__init__() + + self.resize(QSize(800, 600)) + geometry = settings.value('geometry_main') + if geometry: + self.restoreGeometry(geometry) + + shortcut = ConfigParser() + shortcut.read(os.getenv('HOME') + '/.local/share/applications/PortProton.desktop') + scripts_dir = shortcut.get('Desktop Entry', 'Path', fallback=os.getenv('HOME') + '/.local/share/PortWINE/PortProton/data/scripts') + if not scripts_dir or not Path(scripts_dir).is_dir(): + QMessageBox.critical(self, 'Error', 'Can not find installed PortProton') + exit(1) + g.scripts_dir = scripts_dir.rstrip('/') + g.pp_icon = shortcut.get('Desktop Entry', 'Icon', fallback='/usr/share/pixmaps/portproton.png') + pp_icon = QIcon(g.pp_icon) + self.setWindowIcon(pp_icon) + self.setWindowTitle('PortProton games library') + + g.base_dir = str(Path(scripts_dir + '/../..').resolve()) + g.install_pfx = g.base_dir + '/data/prefixes/INSTALL' + g.shortcuts_dir = g.base_dir + '/shortcuts' + g.games_dir = g.base_dir + '/games' + + Path(g.shortcuts_dir).mkdir(parents=True, exist_ok=True) + Path(g.games_dir).mkdir(parents=True, exist_ok=True) + + sep = QFrame(self) + sep.setFrameShape(QFrame.Shape.VLine) + sep.setFrameShadow(QFrame.Shadow.Sunken) + self._status_size = QLabel(self) + self._status_dir = QLabel(self) + self.statusBar().setVisible(False) + self.statusBar().addWidget(self._status_dir, 1) + self.statusBar().addWidget(sep) + self.statusBar().addWidget(self._status_size) + + + self.game_list = GameList(self) + self.setCentralWidget(self.game_list) + + self.toolbar = self.addToolBar('Main') + self.toolbar.setIconSize(QSize(32, 32)) + self.toolbar.setToolButtonStyle(Qt.ToolButtonStyle.ToolButtonTextBesideIcon) + self.toolbar.setMovable(False) + action = QAction(self.style().standardIcon(QStyle.StandardPixmap.SP_FileDialogNewFolder), 'Install new game', self) + action.triggered.connect(self.install_game) + self.toolbar.addAction(action) + action = QAction(self.style().standardIcon(QStyle.StandardPixmap.SP_FileLinkIcon), 'Add game entry', self) + action.triggered.connect(self.add_game) + self.toolbar.addAction(action) + action = QAction(self.style().standardIcon(QStyle.StandardPixmap.SP_BrowserReload), 'Reload list', self) + action.triggered.connect(self.reload_list) + self.toolbar.addAction(action) + action = QAction(self.style().standardIcon(QStyle.StandardPixmap.SP_TrashIcon), 'Drop install prefix', self) + action.triggered.connect(self.drop_prefix) + self.toolbar.addAction(action) + spacer = QWidget(self) + spacer.setSizePolicy(QSizePolicy.Policy.Expanding, QSizePolicy.Policy.Preferred) + self.toolbar.addWidget(spacer) + action = QAction(pp_icon, 'PortProton', self) + action.triggered.connect(self.run_pp) + self.toolbar.addAction(action) + + def install_game(self): + InstallGame(self) + + def add_game(self): + InstallGame(self, False) + + def reload_list(self): + self.game_list.reload() + + def drop_prefix(self): + res = QMessageBox.question(self, 'Are you shure ?', 'Do you really want to remove
' + g.install_pfx + ' ?') + if res == QMessageBox.StandardButton.Yes: + shutil.rmtree(g.install_pfx, True) + + def run_pp(self): + self.setDisabled(True) + app.processEvents() + run([g.scripts_dir + '/start.sh']) + self.setDisabled(False) + + def set_status(self, item): + self.statusBar().setVisible(bool(item)) + if item: + self._status_size.setText('Size: ' + item.dir_size_human) + self._status_dir.setText(' ' + item.game_dir) + + def closeEvent(self, event): + geometry = self.saveGeometry() + settings.setValue('geometry_main', geometry) + super().closeEvent(event) + +class LoadListThread(QThread): + completed = pyqtSignal(list) + def __init__(self, parent, install_dir): + super().__init__(parent) + self.install_dir = install_dir + def run(self): + exe_list = list(Path(self.install_dir).glob('**/*.exe')) + self.completed.emit(exe_list) + +class InstallGame(QDialog): + def __init__(self, parent, installing=True): + super().__init__(parent) + self._installing = installing + self.install_dir = g.install_pfx + '/drive_c/Games' if installing else g.games_dir + self._exe_list_widget = QListWidget(self) + self._exe_list_widget.setIconSize(QSize(16, 16)) + self._exe_list_widget.itemDoubleClicked.connect(self._handleDoubleClick) + layout = QVBoxLayout() + layout.addWidget(self._exe_list_widget) + + self._pbar = QProgressBar(self) + self._pbar.setMaximum(0) + layout.addWidget(self._pbar) + thread = LoadListThread(self, self.install_dir) + thread.completed.connect(self.load) + thread.start() + + if self._installing: + setup_btn = QPushButton(self) + setup_btn.setIcon(self.style().standardIcon(QStyle.StandardPixmap.SP_FileDialogStart)) + setup_btn.setText('Run another setup') + setup_btn.clicked.connect(self._runSetup) + layout.addWidget(setup_btn) + self.setLayout(layout) + self.resize(400, 300) + self.setModal(True) + self.setWindowTitle('Select game exe file') + geometry = settings.value('geometry_install') + if geometry: + self.restoreGeometry(geometry) + self.show() + + def load(self, exe_list): + if self._installing and len(exe_list) == 0: + self._runSetup() + exe_list = list(Path(self.install_dir).glob('**/*.exe')) + if len(exe_list) == 0: + return self.close() + def render_list(): + pixmap = QPixmap(16, 16) + pixmap.fill(Qt.GlobalColor.transparent) + empty_icon = QIcon(pixmap) + for exe in sorted(exe_list): + ico_file = str(exe) + '.ico' + item = QListWidgetItem(self._exe_list_widget) + item.setText(str(exe)[len(self.install_dir)+1:]) + try: + if not Path(ico_file).exists(): + run(['wrestool', '-x', '-t14', '-o', ico_file, exe], capture_output=True) + item.setIcon(QIcon(ico_file)) + except Exception: + pass + if item.icon().pixmap(16, 16).isNull(): + item.setIcon(empty_icon) + self._exe_list_widget.addItem(item) + self._pbar.setVisible(False) + thread = QThread(self) + thread.run = render_list + thread.start() + + def _runSetup(self): + downloads_dir = QStandardPaths.writableLocation(QStandardPaths.StandardLocation.DownloadLocation) + exe_file, _ = QFileDialog.getOpenFileName(self, caption='Choose setup file', filter='Exe files (*.exe)', directory=downloads_dir) + if not exe_file: + return + ppdb = shlex.quote(exe_file + '.ppdb') + script = f""" + mkdir -p {shlex.quote(g.install_pfx + '/drive_c/Games')} + echo ' + export PW_VULKAN_USE=1 + export PW_GUI_DISABLED_CS=1 + export PW_PREFIX_NAME=INSTALL + export PW_DLL_INSTALL=mfc42 + ' > {ppdb} + {shlex.quote(g.scripts_dir + '/start.sh')} {shlex.quote(exe_file)} + rm -f {ppdb} + """ + self.setDisabled(True) + app.processEvents() + run(['bash', '-c', script]) + self.setDisabled(False) + + def _handleDoubleClick(self, item): + game_dir = item.text().split('/')[0] + dlg = QInputDialog(self) + dlg.setWindowTitle('Please enter game entry name') + dlg.setLabelText('New game entry') + dlg.setTextValue(game_dir) + dlg.resize(300, 0) + ok = dlg.exec() + shortcut_name = dlg.textValue() + if not ok or not shortcut_name: + return + file_name = re.sub(r'[<>:/\\|?*]', '_', shortcut_name) + shortcut = f"{g.shortcuts_dir}/{file_name}.desktop" + if Path(shortcut).exists(): + res = QMessageBox.question(self, 'Shortcut already exuists', 'Shortcut ' + file_name + ' already exists. Overwrite ?') + if res != QMessageBox.StandardButton.Yes: + return + src_dir = self.install_dir + '/' + game_dir + dst_dir = g.games_dir + '/' + game_dir + exe_file = shlex.quote(g.games_dir + '/' + item.text()) + ppdb = shlex.quote(g.games_dir + '/' + item.text()) + '.ppdb' + self.setDisabled(True) + if self._installing and Path(dst_dir).exists(): + res = QMessageBox.question(self, 'Dir already exuists', 'Dir ' + game_dir + ' already exists. Overwrite ?') + if res != QMessageBox.StandardButton.Yes: + return + if self._installing: + os.rename(src_dir, dst_dir) + script = f""" + export INSTALLING_PORT=1 + export portwine_exe={exe_file} + cd {shlex.quote(g.scripts_dir)} + . {shlex.quote(g.scripts_dir + '/runlib')} + pw_create_gui_png + pw_init_db + [ -f {ppdb} ] && . {ppdb} + echo -e "export PW_VULKAN_USE=${{PW_VULKAN_USE:-1}}\nexport PW_GUI_DISABLED_CS=1" >> {ppdb} + """ + run(['bash', '-c', script]) + icon_path = g.base_dir + '/data/img/' + Path(item.text()).stem + '.png' + if not Path(icon_path).exists(): + icon_path = g.pp_icon + Path(shortcut).write_text(f"""[Desktop Entry] +Name={shortcut_name} +Exec=env {shlex.quote(g.scripts_dir + '/start.sh')} {exe_file} +Type=Application +Categories=Game +StartupNotify=true +Path={shlex.quote(g.scripts_dir)} +Icon={icon_path} +""", encoding='utf-8') + os.chmod(shortcut, 0o755) + win.reload_list() + self.close() + + def closeEvent(self, event): + geometry = self.saveGeometry() + settings.setValue('geometry_install', geometry) + super().closeEvent(event) + + +class GameList(QListWidget): + def __init__(self, parent): + super().__init__(parent) + self.itemActivated.connect(self.runGame) + self.currentItemChanged.connect(self.selectItem) + self.setViewMode(QListWidget.ViewMode.IconMode) + self.setResizeMode(QListWidget.ResizeMode.Adjust) + self.setIconSize(QSize(64, 64)) + self.setWordWrap(True) + self.setSpacing(3) + self.reload() + + def reload(self): + self.clear() + shortcuts = list(Path(g.shortcuts_dir).glob('*.desktop')) + for shortcut in shortcuts: + item = GameItem(self, shortcut) + self.addItem(item) + self.sortItems() + self.setCurrentIndex(QModelIndex()) + + def runGame(self, item): + win.setDisabled(True) + app.processEvents() + run(['bash', '-c', item.get('Exec')]) + win.setDisabled(False) + + def selectItem(self, item): + win.set_status(item) + + def contextMenuEvent(self, event): + selected = self.selectedItems() + if len(selected) == 0: + return + selected = selected[0] + menu = QMenu(self) + desktop = menu.addAction(self.style().standardIcon(QStyle.StandardPixmap.SP_DesktopIcon), 'Add to desktop') + restore_gui = menu.addAction(self.style().standardIcon(QStyle.StandardPixmap.SP_DialogResetButton), 'Restore PP GUI') + remove = menu.addAction(self.style().standardIcon(QStyle.StandardPixmap.SP_TrashIcon), 'Remove game entry') + uninstall = menu.addAction(self.style().standardIcon(QStyle.StandardPixmap.SP_DialogCloseButton), 'Uninstall game') + if not selected.game_dir.startswith(g.games_dir): + uninstall.setVisible(False) + action = menu.exec(self.mapToGlobal(event.pos())) + desktop_shortcut = QStandardPaths.writableLocation(QStandardPaths.StandardLocation.DesktopLocation) + '/' + Path(selected.desktop_file).name + if action == desktop: + if Path(desktop_shortcut).exists(): + res = QMessageBox.question(self, 'Shortcut already exuists', 'Desktop shortcut ' + desktop_shortcut + ' already exists. Overwrite ?') + if res != QMessageBox.StandardButton.Yes: + return + shutil.copy(selected.desktop_file, desktop_shortcut) + if action == restore_gui: + ppdb = shlex.split(selected.get('Exec'))[-1] + '.ppdb' + if not Path(ppdb).exists(): + return + with open(ppdb, 'r') as read: + with open(ppdb + '.new', 'w') as write: + while (line := read.readline()): + if 'PW_GUI_DISABLED_CS' not in line: + write.write(line) + os.rename(ppdb + '.new', ppdb) + if action == remove: + Path(desktop_shortcut).unlink(True) + Path(selected.desktop_file).unlink(True) + Path(selected.get('Icon')).unlink(True) + self.reload() + if action == uninstall: + res = QMessageBox.question(self, + 'Are you shure ?', + 'Do you really want to uninstall ' + selected.get('Name') + '
located in "'+selected.game_dir+'" ?' + ) + if res != QMessageBox.StandardButton.Yes: + return + Path(desktop_shortcut).unlink(True) + Path(selected.desktop_file).unlink(True) + Path(selected.get('Icon')).unlink(True) + if selected.game_dir.startswith(g.games_dir): + shutil.rmtree(selected.game_dir, True) + self.reload() + + +def human_size(num): + if not num: + return "-" + for unit in ["", "Ki", "Mi", "Gi", "Ti", "Pi", "Ei", "Zi"]: + if abs(num) < 1024.0: + return f"{num:.2f} {unit}B" + num /= 1024.0 + return f"{num:.2f} YiB" + +class GameItem(QListWidgetItem): + def __init__(self, parent, desktop_file): + super().__init__(parent) + self.desktop_file = desktop_file + self.config = ConfigParser() + self.config.read(desktop_file) + text = self.get('Name', Path(desktop_file).stem) + self.setToolTip(text) + self.setText(text) + icon_path = self.get('Icon') if Path(self.get('Icon')).exists() else g.pp_icon + qicon = QIcon(icon_path) + self.setIcon(qicon) + self.setTextAlignment(Qt.AlignmentFlag.AlignHCenter | Qt.AlignmentFlag.AlignTop) + self.setSizeHint(QSize(100, 105)) + self.game_dir = shlex.split(self.get('Exec'))[-1] + if self.game_dir.startswith(g.games_dir): + self.game_dir = g.games_dir + '/' + self.game_dir[len(g.games_dir)+1:].split('/')[0] + else: + self.game_dir = str(Path(self.game_dir).parent) + self._set_dir_size(None) + dir_size_cache = self.game_dir + '/.size' + if Path(dir_size_cache).exists(): + self._set_dir_size(int(Path(dir_size_cache).read_text())) + else: + def calc_dir_size(): + if not Path(self.game_dir).exists(): + return + dir_size = sum(p.stat().st_size for p in Path(self.game_dir).rglob('*')) + self._set_dir_size(dir_size) + Path(dir_size_cache).write_text(str(dir_size)) + thread = QThread(parent) + thread.run = calc_dir_size + thread.start() + + def get(self, name, fallback=None): + return self.config.get('Desktop Entry', name, fallback=fallback) + + def _set_dir_size(self, size): + self.dir_size = size + self.dir_size_human = human_size(size) + +import signal +signal.signal(signal.SIGINT, signal.SIG_DFL) + +app = QApplication([]) +win = MainWindow() +win.show() +app.exec() diff --git a/data_from_portwine/scripts/credits b/data_from_portwine/scripts/credits index 267a95a..50834a2 100755 --- a/data_from_portwine/scripts/credits +++ b/data_from_portwine/scripts/credits @@ -31,6 +31,7 @@ RusNor aldiserg an9949an andrey4korop +zorn " & "${pw_yad_new}" --plug="${KEY_CREDITS}" --tabnum=3 --text-info --scroll <<< "MIT License @@ -172,6 +173,7 @@ ua3dko vlad petrov wrager xpamych +zorn Александр Александр Абдулов Александр Кладов diff --git a/data_from_portwine/scripts/portwine_db/League of Legends b/data_from_portwine/scripts/portwine_db/League of Legends index 6b1671f..fc29c0d 100755 --- a/data_from_portwine/scripts/portwine_db/League of Legends +++ b/data_from_portwine/scripts/portwine_db/League of Legends @@ -12,8 +12,8 @@ export TEXT_OPSSL="" [[ -z `which openssl` ]] && export TEXT_OPSSL="Install openssl in your system!!!\n" export PW_COMMENT_DB="${TEXT_OPSSL}Dwnload and start League of Legends can take a long time" export WINEDLLOVERRIDES="mscoree,mshtml=" -# export LAUNCH_PARAMETERS="--launch-product=league_of_legends --launch-patchline=live" # Additional launch options -export PW_WINE_USE=WINE_LOL_GE_7.0-2 +export LAUNCH_PARAMETERS="--launch-product=league_of_legends --launch-patchline=live" # Additional launch options +export PW_WINE_USE=WINE_LOL_GE_7.0-4 export PW_VULKAN_USE=1 export PW_MUST_HAVE_DLL="" export PW_PREFIX_NAME="LEAGUE_OF_LEGENDS" @@ -42,7 +42,7 @@ check_download_wine_ver_for_lol # check_port_for_lol () { # "${pw_yad}" --progress --progress-text="Loading and start League of Legends. Please wait. It can take a long time!" \ -# --pulsate --no-buttons --undecorated --center --skip-taskbar --image="${PW_GUI_ICON_PATH}/covers/lol_cover.jpg" --image-on-top > /dev/null 2>&1 & +# --pulsate --no-buttons --undecorated --center --skip-taskbar --image="${PW_GUI_ICON_PATH}/covers/lol_cover.jpg" --image-on-top > /dev/null 4>&1 & # PW_YAD_PID_LOL="$!" # process=LeagueClientUx.exe # while [[ -z `pidof ${process}` ]] ; do @@ -67,12 +67,13 @@ check_download_wine_ver_for_lol # } add_in_start_portwine () { - if [ "$(cat /proc/sys/abi/vsyscall32)" -ne 0 ] ; then - pw_stop_progress_bar - zenity --question --title="Fix for LoL anti-cheat" \ - --text='Root rights are required to execute the command: \n"sysctl -w abi.vsyscall32=0"' --no-wrap - [ "$?" = 1 ] && exit 0 - pkexec /usr/bin/env bash -c 'sysctl -w abi.vsyscall32=0' - fi + echo "" + # if [ "$(cat /proc/sys/abi/vsyscall32)" -ne 0 ] ; then + # pw_stop_progress_bar + # zenity --question --title="Fix for LoL anti-cheat" \ + # --text='Root rights are required to execute the command: \n"sysctl -w abi.vsyscall32=0"' --no-wrap + # [ "$?" = 1 ] && exit 0 + # pkexec /usr/bin/env bash -c 'sysctl -w abi.vsyscall32=0' + # fi # check_port_for_lol & } diff --git a/data_from_portwine/scripts/portwine_db/Origin b/data_from_portwine/scripts/portwine_db/Origin index 08ff6b8..60f1e9a 100755 --- a/data_from_portwine/scripts/portwine_db/Origin +++ b/data_from_portwine/scripts/portwine_db/Origin @@ -3,76 +3,24 @@ #Origin.exe #Rating=? #####################examples########################### -##export PW_COMMENT_DB="blablabla" - -##export PW_WINDOWS_VER=10 # Set windows version 10, 7 or XP -export PW_DLL_INSTALL="vcrun2012 vcrun2019 d3dcompiler_43 d3dcompiler_47 d3dx9" # Install DDL in port prefix (used winetricks) -##export WINEDLLOVERRIDES="blabla=n,b" -##export LAUNCH_PARAMETERS="('"+com_skipIntroVideo 1"' '"+com_skipSignInManager 1"')" # Additional launch options - +export PW_DLL_INSTALL="vcrun2012 vcrun2019" # Install DDL in port prefix (used winetricks) export PW_VULKAN_USE=1 # dxvk, vkd3d or 0 for OpenGL -##export PW_DXVK_VER=1.8.1 -##export PW_VKD3D_VER=2.2 -##export PW_USE_DXR10=1 -##export PW_VULKAN_NO_ASYNC=1 # Disabled ASYNC for VULKAN -export PW_USE_NVAPI_AND_DLSS=0 -##export PW_OLD_GL_STRING=0 -##export PW_HIDE_NVIDIA_GPU=0 -##export PW_FORCE_USE_VSYNC=2 # Vsync: 0-FORCE_OFF, 1-FORCE_ON, 2-BY_DEFAULT -##export PW_VKD3D_FEATURE_LEVEL=0 -##export PW_DXGI_FROM_DXVK=0 -##export PW_VIRTUAL_DESKTOP=1 -##export VKD3D_CONFIG=force_bindless_texel_buffer,multi_queue - -##export PW_NO_FSYNC=1 # Do not use futex-based in-process synchronization primitives. (Automatically disabled on systems with no FUTEX_WAIT_MULTIPLE support. -##export PW_NO_ESYNC=1 # Do not use eventfd-based in-process synchronization primitives - -##export PULSE_LATENCY_MSEC=60 # Fix crackling audio in games - -##export PW_USE_GAMEMODE=0 # Force disabele gamemod -##export PW_FORCE_LARGE_ADDRESS_AWARE=1 # Force Wine to enable the LARGE_ADDRESS_AWARE flag for all executables. Enabled by default. -##export PW_NO_WRITE_WATCH=0 # Disable support for memory write watches in ntdll. This is a very dangerous hack and should only be applied if you have verified that the game can operate without write watches. This improves performance for some very specific games (e.g. CoreRT-based games). -##export PW_HEAP_DELAY_FREE=0 - -##export WINEARCH=win32 # defaut = win64 -##export WINEPREFIX= - -##export PW_WINEDBG_DISABLE=1 # Disabled WINEDBG -##export PW_USE_TERMINAL=0 # Force run in terminal -##export PW_LOG=0 # Enable debug mode fo terminal -##export PW_GUI_DISABLED_CS=1 # 1 = disabled GUI - -export STAGING_SHARED_MEMORY=0 - -#add_in_start_portwine () { -# export PW_USER_TEMP="$WINEPREFIX/drive_c/users/${USER}/Temp" -# if try_download "download.dm.origin.com/origin/live/OriginSetup.exe" "${PW_USER_TEMP}/OriginSetup.exe" ; then -# pw_start_progress_bar_block "Extracting files for update the Origin..." -# unzip "${PW_USER_TEMP}/OriginSetup.exe" 'update/*.zip' -d "${PW_USER_TEMP}/" -# unzip -o "${PW_USER_TEMP}/update/"*.zip -d "$WINEPREFIX/drive_c/Program Files (x86)/Origin/" -# try_remove_dir "${PW_USER_TEMP}/update" -# try_remove_file "${PW_USER_TEMP}/OriginSetup.exe" -# pw_stop_progress_bar -# pw_start_progress_bar_cs "Starting the Origin..." - -# check_origin_update () { -# while : -# do -# sleep 3 -# if [ ! -z `pgrep Origin.exe | head -n 1` ] ; then -# sleep 1 -# else -# if [ ! -z `pgrep OriginSetup* | head -n 1` ] ; then -# kill -n 9 `pgrep OriginSetup* | head -n 1` -# fi -# if [ ! -z `pgrep OriginThin* | head -n 1` ] ; then -# kill -n 9 `pgrep OriginThin* | head -n 1` -# fi -# break -# fi -# done -# } -# check_origin_update & -# fi -#} +###WINE_KRON4EK### +export PW_WINE_USE="WINE-7.13-STAGING-AMD64" +check_download_wine_ver_for_origin () { + if [ ! -d "${PORT_WINE_PATH}/data/dist/${PW_WINE_USE}" ] ; then + if try_download "https://github.com/Kron4ek/Wine-Builds/releases/download/7.13/wine-7.13-staging-amd64.tar.xz" \ + "${PORT_WINE_PATH}/data/tmp/${PW_WINE_USE}.tar.xz" ; then + if unpack_tar_xz "${PORT_WINE_PATH}/data/tmp/${PW_WINE_USE}.tar.xz" "${PORT_WINE_PATH}/data/dist/" ; then + try_remove_file "${PORT_WINE_PATH}/data/tmp/${PW_WINE_USE}.tar.xz" + UNPACK_STATUS=0 + else + try_remove_file "${PORT_WINE_PATH}/data/tmp/${PW_WINE_USE}.tar.xz" + try_remove_dir "${PORT_WINE_PATH}/data/dist/${PW_WINE_USE}" + fi + fi + [[ "${UNPACK_STATUS}" != 0 ]] && exit 1 + fi +} +check_download_wine_ver_for_origin diff --git a/data_from_portwine/scripts/portwine_db/wgc b/data_from_portwine/scripts/portwine_db/wgc index 352f941..f924567 100755 --- a/data_from_portwine/scripts/portwine_db/wgc +++ b/data_from_portwine/scripts/portwine_db/wgc @@ -7,7 +7,7 @@ export PW_COMMENT_DB="Wargaming Game Center" ################################################ export PW_WINE_USE=PROTON_GE export PW_VULKAN_USE=1 #dxvk, vkd3d or 0 for OpenGL -export LAUNCH_PARAMETERS="--disable-gpu" # Additional launch options +export LAUNCH_PARAMETERS="" # Additional launch options #export PW_USE_TERMINAL=1 export PW_WINDOWS_VER=10 # Set windows version 10, 7 or XP #export PW_USE_NVAPI_AND_DLSS=0 @@ -21,4 +21,7 @@ add_in_start_portwine () { if [[ -f "${PORT_WINE_PATH}/data/prefixes/${PW_PREFIX_NAME}/drive_c/users/${USER}/AppData/Roaming/Wargaming.net/WorldOfTanks/preferences.xml" ]] ; then sed -i 's% true % false %' "${PORT_WINE_PATH}/data/prefixes/${PW_PREFIX_NAME}/drive_c/users/${USER}/AppData/Roaming/Wargaming.net/WorldOfTanks/preferences.xml" fi + if [[ "${PW_VULKAN_USE}" == "0" || "${PW_VULKAN_USE}" == "3" ]] ; then + export LAUNCH_PARAMETERS="--disable-gpu" + fi } diff --git a/data_from_portwine/scripts/pw_autoinstall/PW_LOL b/data_from_portwine/scripts/pw_autoinstall/PW_LOL index 6330118..6ffe98d 100644 --- a/data_from_portwine/scripts/pw_autoinstall/PW_LOL +++ b/data_from_portwine/scripts/pw_autoinstall/PW_LOL @@ -6,7 +6,7 @@ export PW_AUTOINSTALL_EXE="${PW_USER_TEMP}/live.na.exe" export LAUNCH_PARAMETERS="--launch-product=league_of_legends --launch-patchline=live" export PW_MUST_HAVE_DLL="" export PW_VULKAN_USE=1 -export PW_WINE_USE=WINE_LOL_GE_7.0-2 +export PW_WINE_USE=WINE_LOL_GE_7.0-4 export WINEDLLOVERRIDES="mscoree,mshtml=" export PW_USE_D3D_EXTRAS=1 diff --git a/data_from_portwine/scripts/runlib b/data_from_portwine/scripts/runlib index ecd3451..69b4048 100755 --- a/data_from_portwine/scripts/runlib +++ b/data_from_portwine/scripts/runlib @@ -66,14 +66,14 @@ start_portwine () { xrdb -merge "${HOME}/.Xresources" fi - export NOSTEAM=1 pw_init_runtime if [[ ! -z "${PW_LOG}" && "${PW_LOG}" != 0 ]] ; then export WINEDEBUG="fixme-all,err+loaddll,err+dll,err+file,err+reg" - export DXVK_LOG_LEVEL="info" + export DXVK_LOG_LEVEL="warn" export VKD3D_DEBUG="warn" export WINE_MONO_TRACE="E:System.NotImplementedException" + export VK_LOADER_DEBUG=all else export WINEDEBUG="-all" export DXVK_LOG_LEVEL="none" @@ -351,7 +351,23 @@ start_portwine () { export PW_GALLIUM_NINE_PATH="${PW_PLUGINS_PATH}/gallium_nine_v.${PW_GALLIUM_NINE_VER}" try_force_link_file "${PW_GALLIUM_NINE_PATH}/lib32/d3d9-nine.dll.so" "${PORT_WINE_PATH}/data/prefixes/${PW_PREFIX_NAME}/drive_c/windows/syswow64/d3d9.dll" try_force_link_file "${PW_GALLIUM_NINE_PATH}/lib64/d3d9-nine.dll.so" "${PORT_WINE_PATH}/data/prefixes/${PW_PREFIX_NAME}/drive_c/windows/system32/d3d9.dll" - var_winedlloverride_update "d3d9=n;wined3d=b;d3d10,d3d11,dxvk_config,vulkan-1,winevulkan=" + var_winedlloverride_update "d3d9=n;wined3d=b;dxvk_config,vulkan-1,winevulkan=" + echo "Try link wine DXGI..." + if ! try_force_link_file "${WINEDIR}"/lib/wine/fakedlls/dxgi.dll "${PORT_WINE_PATH}/data/prefixes/${PW_PREFIX_NAME}/drive_c/windows/syswow64/dxgi.dll" + then try_force_link_file "${WINEDIR}"/lib/wine/i386-windows/dxgi.dll "${PORT_WINE_PATH}/data/prefixes/${PW_PREFIX_NAME}/drive_c/windows/syswow64/dxgi.dll" + fi + if ! try_force_link_file "${WINEDIR}"/lib64/wine/fakedlls/dxgi.dll "${PORT_WINE_PATH}/data/prefixes/${PW_PREFIX_NAME}/drive_c/windows/system32/dxgi.dll" + then try_force_link_file "${WINEDIR}"/lib64/wine/x86_64-windows/dxgi.dll "${PORT_WINE_PATH}/data/prefixes/${PW_PREFIX_NAME}/drive_c/windows/system32/dxgi.dll" + fi + echo "Try link wine d3d filese..." + for wine_build_dll in d3d11 d3d10 d3d10core d3d10_1 dxgi ; do + if ! try_force_link_file "${WINEDIR}/lib/wine/${wine_build_dll}.dll" "${PORT_WINE_PATH}/data/prefixes/${PW_PREFIX_NAME}/drive_c/windows/syswow64/${wine_build_dll}.dll" + then try_force_link_file "${WINEDIR}/lib/wine/i386-windows/${wine_build_dll}.dll" "${PORT_WINE_PATH}/data/prefixes/${PW_PREFIX_NAME}/drive_c/windows/syswow64/${wine_build_dll}.dll" + fi + if ! try_force_link_file "${WINEDIR}/lib64/wine/${wine_build_dll}.dll" "${PORT_WINE_PATH}/data/prefixes/${PW_PREFIX_NAME}/drive_c/windows/system32/${wine_build_dll}.dll" + then try_force_link_file "${WINEDIR}/lib64/wine/x86_64-windows/${wine_build_dll}.dll" "${PORT_WINE_PATH}/data/prefixes/${PW_PREFIX_NAME}/drive_c/windows/system32/${wine_build_dll}.dll" + fi + done unset FIND_D3D_MODULE D3D_MODULE_PATH FIND_D3D_MODULE=`dirname $(find /usr/ -maxdepth 4 -type f -name "d3dadapter9.so.*") 2>/dev/null` if [[ ! -z "$FIND_D3D_MODULE" ]] ; then @@ -526,6 +542,9 @@ start_portwine () { if [[ "${PW_CHECK_AUTOINSTAL}" != "1" ]] ; then pw_start_progress_bar_cover "${PW_GUI_ICON_PATH}/covers/pw_loading_cover.gif" fi + if [[ "${PW_PREFIX_NAME}" == "DOTNET" ]] && [[ "${PW_VULKAN_USE}" == "1" || "${PW_VULKAN_USE}" == "2" ]] ; then + var_winedlloverride_update "libglesv2=d" + fi add_in_start_portwine } diff --git a/data_from_portwine/scripts/var b/data_from_portwine/scripts/var index 8210f9a..c947dd9 100755 --- a/data_from_portwine/scripts/var +++ b/data_from_portwine/scripts/var @@ -1,6 +1,6 @@ #!/usr/bin/env bash #Author: Castro-Fidel (PortWINE-Linux.ru) -#SCRIPTS_NEXT_VERSION=2121 +#SCRIPTS_NEXT_VERSION=2122 ######################################################################## export PW_MANGOHUD=0 export MANGOHUD_CONFIG=cpu_stats,cpu_temp,cpu_mhz,cpu_color=2e97cb,cpu_text=CPU,gpu_stats,gpu_temp,gpu_core_clock,gpu_mem_clock,vulkan_driver,gpu_name,gpu_color=2e9762,gpu_text=GPU,vram,vram_color=ad64c1,ram,ram_color=c26693,io_color=a491d3,frame_timing=1,frametime_color=00ff00,time,arch,wine,wine_color=eb5b5b,engine_color=eb5b5b,background_alpha=0.2,font_size=24,background_color=020202,text_color=ffffff,toggle_hud=Shift_R+F12,resolution,vkbasalt @@ -42,8 +42,10 @@ export PW_GE_VER="7-26" export PW_PROTON_GE_VER="PROTON_GE_${PW_GE_VER}" export PW_WINE_FULLSCREEN_FSR="0" ###WINE_PROTON_PW_FOR_GALLIUM_NINE### -export PW_PW_VER="7.5" -export PW_PROTON_PW_VER="PROTON_PW_${PW_PW_VER}" +# export PW_PW_VER="7-26" +export PW_PROTON_PW_VER="${PW_GE_VER}" +###WINE_KRON4EK### +export PW_WINE_KRON4EK_VER="WINE-7.13-STAGING-TKG-AMD64" ################################################################# pw_install_dll_in_prefix () { diff --git a/data_from_portwine/scripts/zen_yad_gui b/data_from_portwine/scripts/zen_yad_gui index 46a8e66..ad7d9e1 100644 --- a/data_from_portwine/scripts/zen_yad_gui +++ b/data_from_portwine/scripts/zen_yad_gui @@ -239,6 +239,17 @@ gui_proton_downloader () { sed -i '/github-action/d' "${PORT_WINE_TMP_PATH}/tmp_proton_ge_git" fi + #WINE_KRON4EK + export WINE_KRON4EK=($(curl -s "https://api.github.com/repos/Kron4ek/Wine-Builds/releases" | grep "browser_download_url.*\.tar\.xz" | cut -d \" -f 4)) + try_remove_file "${PORT_WINE_TMP_PATH}/tmp_wine_kron4ek_git" + if [[ ! -z "${WINE_KRON4EK}" ]] ; then + for PGEGIT in ${WINE_KRON4EK[@]} ; do + echo ${PGEGIT} | awk -F/ '{print $NF}' | sed 's/.tar.xz//' >> "${PORT_WINE_TMP_PATH}/tmp_wine_kron4ek_git" + done + sed -i '/6.3/,$d' "${PORT_WINE_TMP_PATH}/tmp_wine_kron4ek_git" + sed -i '/-x86/d' "${PORT_WINE_TMP_PATH}/tmp_wine_kron4ek_git" + fi + #PROTON_PW export PROTON_PW_GIT=($(curl -s "https://api.github.com/repos/Castro-Fidel/wine_builds/releases" | grep "browser_download_url.*\.tar\.xz" | cut -d \" -f 4)) try_remove_file "${PORT_WINE_TMP_PATH}/tmp_proton_pw_git" @@ -258,6 +269,7 @@ gui_proton_downloader () { for INSTALLING_VERSION_IN_DIST in `ls "${PORT_WINE_PATH}/data/dist/"` ; do sed -i "/${INSTALLING_VERSION_IN_DIST}$/Id" "${PORT_WINE_TMP_PATH}/tmp_proton_ge_git" sed -i "/${INSTALLING_VERSION_IN_DIST}$/Id" "${PORT_WINE_TMP_PATH}/tmp_proton_pw_git" + sed -i "/${INSTALLING_VERSION_IN_DIST}$/Id" "${PORT_WINE_TMP_PATH}/tmp_wine_kron4ek_git" done #Installed wine ls -l ${PORT_WINE_PATH}/data/dist | awk '{print $9}' | sed '/^$/d' > ${PORT_WINE_TMP_PATH}/tmp_installed_wine @@ -266,36 +278,41 @@ gui_proton_downloader () { try_remove_file "${PORT_WINE_TMP_PATH}/tmp_proton_pw_set" try_remove_file "${PORT_WINE_TMP_PATH}/tmp_proton_set" try_remove_file "${PORT_WINE_TMP_PATH}/tmp_installed_wine_set" - `"${pw_yad}" --plug=$KEY_WINE --tabnum=2 --list --separator="" --listen \ - --column "Select WINE for download:" < "${PORT_WINE_TMP_PATH}/tmp_proton_pw_git" 1> "${PORT_WINE_TMP_PATH}/tmp_proton_pw_set"` & + `"${pw_yad}" --plug=$KEY_WINE --tabnum=1 --list --separator="" --listen \ --column "Select WINE for download:" < "${PORT_WINE_TMP_PATH}/tmp_proton_ge_git" 1> "${PORT_WINE_TMP_PATH}/tmp_proton_set"` & - `"${pw_yad}" --plug=$KEY_WINE --tabnum=3 --list --separator="" --listen \ + `"${pw_yad}" --plug=$KEY_WINE --tabnum=2 --list --separator="" --listen \ + --column "Select WINE for download:" < "${PORT_WINE_TMP_PATH}/tmp_wine_kron4ek_git" 1> "${PORT_WINE_TMP_PATH}/tmp_kron4ek_set"` & + `"${pw_yad}" --plug=$KEY_WINE --tabnum=3 --list --separator="" --listen \ + --column "Select WINE for download:" < "${PORT_WINE_TMP_PATH}/tmp_proton_pw_git" 1> "${PORT_WINE_TMP_PATH}/tmp_proton_pw_set"` & + `"${pw_yad}" --plug=$KEY_WINE --tabnum=4 --list --separator="" --listen \ --column "Select installed WINE for delete:" < "${PORT_WINE_TMP_PATH}/tmp_installed_wine" 1> "${PORT_WINE_TMP_PATH}/tmp_installed_wine_set"` & `"${pw_yad}" --key=$KEY_WINE --notebook --width=500 --height=600 --text-align=center --center \ --window-icon="$PW_GUI_ICON_PATH/port_proton.png" --title "Download..." --separator="" \ - --tab-pos=top --tab="PROTON-GE" --tab="PROTON-PW" --tab="INSTALLED"` + --tab-pos=top --tab="PROTON-GE" --tab="KRON4EK" --tab="PROTON-PW" --tab="INSTALLED"` YAD_WINE_STATUS="$?" if [[ "$YAD_WINE_STATUS" == "1" || "$YAD_WINE_STATUS" == "252" ]] ; then /usr/bin/env bash -c ${pw_full_command_line[*]} & exit 0 fi - if [ ! -z `cat "${PORT_WINE_TMP_PATH}/tmp_proton_set" | awk '{print $1}'` ] ; then export VERSION_WINE_GIT="`cat "${PORT_WINE_TMP_PATH}/tmp_proton_set"`" elif [ ! -z `cat "${PORT_WINE_TMP_PATH}/tmp_proton_pw_set" | awk '{print $1}'` ] ; then export VERSION_WINE_GIT="`cat "${PORT_WINE_TMP_PATH}/tmp_proton_pw_set"`" - elif [ ! -z `cat "${PORT_WINE_TMP_PATH}/tmp_installed_wine_set" | awk '{print $1}'` ] ; then - export VERSION_INSTALLED_WINE="`cat "${PORT_WINE_TMP_PATH}/tmp_installed_wine_set"`" + elif [ ! -z `cat "${PORT_WINE_TMP_PATH}/tmp_kron4ek_set" | awk '{print $1}'` ] ; then + export VERSION_WINE_GIT="`cat "${PORT_WINE_TMP_PATH}/tmp_kron4ek_set"`" + elif [ ! -z `cat "${PORT_WINE_TMP_PATH}/tmp_installed_wine_set" | awk '{print $1}'` ] ; then + export VERSION_INSTALLED_WINE="`cat "${PORT_WINE_TMP_PATH}/tmp_installed_wine_set"`" fi try_remove_file "${PORT_WINE_TMP_PATH}/tmp_proton_ge_git" try_remove_file "${PORT_WINE_TMP_PATH}/tmp_proton_pw_git" + try_remove_file "${PORT_WINE_TMP_PATH}/tmp_wine_kron4ek_git" try_remove_file "${PORT_WINE_TMP_PATH}/tmp_proton_set" - try_remove_file "${PORT_WINE_TMP_PATH}/tmp_installed_wine" + try_remove_file "${PORT_WINE_TMP_PATH}/tmp_installed_wine" - for GIVE_WINE_URL in ${PROTON_GE_GIT[@]} ${PROTON_PW_GIT[@]} ; do - if [ ! -z `echo ${GIVE_WINE_URL} | grep "$VERSION_WINE_GIT"` ] ; then + for GIVE_WINE_URL in ${PROTON_GE_GIT[@]} ${PROTON_PW_GIT[@]} ${WINE_KRON4EK[@]}; do + if [ ! -z `echo ${GIVE_WINE_URL} | grep -i "$VERSION_WINE_GIT"` ] ; then export URL_VERSION_PROTON_GIT="${GIVE_WINE_URL}" fi done