forked from CastroFidel/winehelper
Compare commits
16 Commits
a69493df73
...
0.5.4.1
Author | SHA1 | Date | |
---|---|---|---|
|
759421d725 | ||
|
bf3a30487e | ||
|
13efa924d8 | ||
|
721fd5e76e | ||
|
7f3f330fc4 | ||
|
1e19fa3c56 | ||
|
a57df9a259 | ||
|
3f22b3540e | ||
|
861b6743fd | ||
|
aa267ad9ef | ||
|
3e91bcf241 | ||
|
5571f74125 | ||
|
a15b2621b6 | ||
|
fd00b61c71 | ||
|
74eaf34c00 | ||
|
2483f4c66c |
@@ -1,5 +1,14 @@
|
|||||||
История изменений:
|
История изменений:
|
||||||
|
|
||||||
|
0.5.4:
|
||||||
|
* обновлен графический режим Qt5:
|
||||||
|
- добавлена возможность установки системных зависимостей
|
||||||
|
- исправлены/улучшены основные функции
|
||||||
|
- добавлено управление префиксами (в разработке)
|
||||||
|
- добавлена возможность создания ярлыка
|
||||||
|
* добавлено автоматическое создание иконки для ярлыков (desktop файлов)
|
||||||
|
* префикс tflex17 переименован в tflex (т.к. 18-я версия работает в том же префиксе)
|
||||||
|
|
||||||
0.5.3:
|
0.5.3:
|
||||||
* исправлена установка grdcontrol для t-flex-*
|
* исправлена установка grdcontrol для t-flex-*
|
||||||
* обновлен графический режим Qt5
|
* обновлен графический режим Qt5
|
||||||
|
@@ -4,7 +4,7 @@ _winehelper_completions() {
|
|||||||
COMPREPLY=()
|
COMPREPLY=()
|
||||||
cur="${COMP_WORDS[COMP_CWORD]}"
|
cur="${COMP_WORDS[COMP_CWORD]}"
|
||||||
prev="${COMP_WORDS[COMP_CWORD-1]}"
|
prev="${COMP_WORDS[COMP_CWORD-1]}"
|
||||||
opts="--help --version --debug install installed -r -i remove-all --clear-pfx killall remove-prefix backup-prefix restore-prefix create-prefix --changelog changelog"
|
opts="--help --version --debug install installed install-dxvk install-vkd3d -r -i remove-all --clear-pfx killall remove-prefix backup-prefix restore-prefix create-prefix --changelog changelog"
|
||||||
wine_cmd="winecfg winereg winefile wineconsole winetricks desktop regedit explorer cmd run"
|
wine_cmd="winecfg winereg winefile wineconsole winetricks desktop regedit explorer cmd run"
|
||||||
|
|
||||||
case "${prev}" in
|
case "${prev}" in
|
||||||
|
@@ -8,6 +8,8 @@ _winehelper() {
|
|||||||
'--version[Показать информацию о пакете и его версии]'
|
'--version[Показать информацию о пакете и его версии]'
|
||||||
'--debug[Режим отладки]'
|
'--debug[Режим отладки]'
|
||||||
'install[Запустить скрипт установки программы]'
|
'install[Запустить скрипт установки программы]'
|
||||||
|
'install-dxvk[Установить/удалить DXVK]'
|
||||||
|
'install-vkd3d[Установить/удалить VKD3D]'
|
||||||
'installed[Список установленных программ]'
|
'installed[Список установленных программ]'
|
||||||
'-r[Запуск программы (отладка)]'
|
'-r[Запуск программы (отладка)]'
|
||||||
'-i[Запустить скрипт установки программы]'
|
'-i[Запустить скрипт установки программы]'
|
||||||
@@ -61,6 +63,12 @@ _winehelper() {
|
|||||||
restore-prefix)
|
restore-prefix)
|
||||||
_files
|
_files
|
||||||
;;
|
;;
|
||||||
|
install-dxvk)
|
||||||
|
_get_component_versions 'install-dxvk'
|
||||||
|
;;
|
||||||
|
install-vkd3d)
|
||||||
|
_get_component_versions 'install-vkd3d'
|
||||||
|
;;
|
||||||
*)
|
*)
|
||||||
_values 'winehelper options' "${opts[@]}" "${wine_cmd[@]}"
|
_values 'winehelper options' "${opts[@]}" "${wine_cmd[@]}"
|
||||||
;;
|
;;
|
||||||
@@ -69,6 +77,16 @@ _winehelper() {
|
|||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
|
_get_component_versions () {
|
||||||
|
local component_command=$1
|
||||||
|
local -a versions
|
||||||
|
|
||||||
|
versions=( ${(f)"$(winehelper "${component_command}" list 2>/dev/null | grep ' - ' | sed 's/ - //')" } )
|
||||||
|
versions+=(none list)
|
||||||
|
|
||||||
|
_values 'versions' "${versions[@]}"
|
||||||
|
}
|
||||||
|
|
||||||
_get_prefixes () {
|
_get_prefixes () {
|
||||||
prefixes=( ${(f)"$(ls -1 ~/.local/share/winehelper/prefixes 2>/dev/null)"} )
|
prefixes=( ${(f)"$(ls -1 ~/.local/share/winehelper/prefixes 2>/dev/null)"} )
|
||||||
|
|
||||||
|
222
winehelper
222
winehelper
@@ -509,6 +509,18 @@ var_ld_library_path_update () {
|
|||||||
return 0
|
return 0
|
||||||
}
|
}
|
||||||
|
|
||||||
|
find_prefix () {
|
||||||
|
# Автоматическое определение префикса, если он не задан
|
||||||
|
if [[ -z "$WINEPREFIX" ]] && [[ "$1" == "$WH_PREFIXES_DIR"* ]]; then
|
||||||
|
local extracted_prefix
|
||||||
|
extracted_prefix="$(echo "$1" | grep -o ".*/prefixes/[^/]*")"
|
||||||
|
if [[ -d "$extracted_prefix" ]]; then
|
||||||
|
export WINEPREFIX="$extracted_prefix"
|
||||||
|
print_info "Префикс автоматически определен: $(basename "$WINEPREFIX")"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
create_desktop () {
|
create_desktop () {
|
||||||
local name_desktop exe_file desktop_filename icon_file desktop_path icon_arg desktop_filename_arg
|
local name_desktop exe_file desktop_filename icon_file desktop_path icon_arg desktop_filename_arg
|
||||||
name_desktop="$1"
|
name_desktop="$1"
|
||||||
@@ -525,7 +537,7 @@ create_desktop () {
|
|||||||
|
|
||||||
# Проверяем обязательные аргументы и наличие exe-файла
|
# Проверяем обязательные аргументы и наличие exe-файла
|
||||||
if [[ -z "$name_desktop" ]] || [[ -z "$exe_file" ]] ; then
|
if [[ -z "$name_desktop" ]] || [[ -z "$exe_file" ]] ; then
|
||||||
fatal "Использование: $0 create-desktop \"Имя ярлыка\" \"/путь/к/файлу.exe\" [иконка|auto] [имя_desktop_файла]"
|
fatal "Использование: $0 desktop \"Имя ярлыка\" \"/путь/к/файлу.exe\" [иконка|auto] [имя_desktop_файла]"
|
||||||
elif [[ ! -f "$exe_file" ]] ; then
|
elif [[ ! -f "$exe_file" ]] ; then
|
||||||
print_warning "Для создания ярлыка не найден исполняемый файл: $exe_file"
|
print_warning "Для создания ярлыка не найден исполняемый файл: $exe_file"
|
||||||
|
|
||||||
@@ -545,6 +557,8 @@ create_desktop () {
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
find_prefix "$exe_file"
|
||||||
|
|
||||||
# --- Логика обработки иконки ---
|
# --- Логика обработки иконки ---
|
||||||
local user_icons_dir="$WINEPREFIX/icons"
|
local user_icons_dir="$WINEPREFIX/icons"
|
||||||
create_new_dir "$user_icons_dir"
|
create_new_dir "$user_icons_dir"
|
||||||
@@ -762,9 +776,10 @@ init_wined3d () {
|
|||||||
init_dxvk () {
|
init_dxvk () {
|
||||||
check_variables USE_DXVK_VER "$1"
|
check_variables USE_DXVK_VER "$1"
|
||||||
|
|
||||||
get_dxvk () {
|
get_dxvk() {
|
||||||
DXVK_URL="$1"
|
local DXVK_URL="$1"
|
||||||
DXVK_PACKAGE="${WH_VULKAN_LIBDIR}/dxvk-${DXVK_VAR_VER}.tar.$(echo ${DXVK_URL#*.tar.})"
|
local DXVK_VAR_VER="$2"
|
||||||
|
local DXVK_PACKAGE="${WH_VULKAN_LIBDIR}/${DXVK_VAR_VER}.tar.$(echo "${DXVK_URL#*.tar.}")"
|
||||||
if try_download "$DXVK_URL" "$DXVK_PACKAGE" check256sum \
|
if try_download "$DXVK_URL" "$DXVK_PACKAGE" check256sum \
|
||||||
&& unpack "$DXVK_PACKAGE" "$WH_VULKAN_LIBDIR"
|
&& unpack "$DXVK_PACKAGE" "$WH_VULKAN_LIBDIR"
|
||||||
then
|
then
|
||||||
@@ -775,8 +790,8 @@ init_dxvk () {
|
|||||||
}
|
}
|
||||||
|
|
||||||
for DXVK_VAR_VER in "$USE_DXVK_VER" $@ ; do
|
for DXVK_VAR_VER in "$USE_DXVK_VER" $@ ; do
|
||||||
if [[ ! -d "${WH_VULKAN_LIBDIR}/dxvk-$DXVK_VAR_VER" ]] ; then
|
if [[ ! -d "${WH_VULKAN_LIBDIR}/${DXVK_VAR_VER}" ]] ; then
|
||||||
get_dxvk "$CLOUD_URL/dxvk-${DXVK_VAR_VER}.tar.xz"
|
get_dxvk "$CLOUD_URL/${DXVK_VAR_VER}.tar.xz" "$DXVK_VAR_VER"
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
@@ -789,8 +804,8 @@ init_dxvk () {
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
for dxvkfiles in $DXVK_FILES ; do
|
for dxvkfiles in $DXVK_FILES ; do
|
||||||
try_copy_other_dll_to_pfx_64 "${WH_VULKAN_LIBDIR}/dxvk-$USE_DXVK_VER/x64/$dxvkfiles.dll"
|
try_copy_other_dll_to_pfx_64 "${WH_VULKAN_LIBDIR}/${USE_DXVK_VER}/x64/$dxvkfiles.dll"
|
||||||
if try_copy_other_dll_to_pfx_32 "${WH_VULKAN_LIBDIR}/dxvk-$USE_DXVK_VER/x32/$dxvkfiles.dll"
|
if try_copy_other_dll_to_pfx_32 "${WH_VULKAN_LIBDIR}/${USE_DXVK_VER}/x32/$dxvkfiles.dll"
|
||||||
then var_winedlloverride_update "$dxvkfiles=n"
|
then var_winedlloverride_update "$dxvkfiles=n"
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
@@ -799,9 +814,10 @@ init_dxvk () {
|
|||||||
init_vkd3d () {
|
init_vkd3d () {
|
||||||
check_variables USE_VKD3D_VER "$1"
|
check_variables USE_VKD3D_VER "$1"
|
||||||
|
|
||||||
get_vkd3d () {
|
get_vkd3d() {
|
||||||
VKD3D_URL="$1"
|
local VKD3D_URL="$1"
|
||||||
VKD3D_PACKAGE="${WH_VULKAN_LIBDIR}/vkd3d-proton-${VKD3D_VAR_VER}.tar.$(echo ${VKD3D_URL#*.tar.})"
|
local VKD3D_VAR_VER="$2"
|
||||||
|
local VKD3D_PACKAGE="${WH_VULKAN_LIBDIR}/${VKD3D_VAR_VER}.tar.$(echo "${VKD3D_URL#*.tar.}")"
|
||||||
if try_download "$VKD3D_URL" "$VKD3D_PACKAGE" check256sum \
|
if try_download "$VKD3D_URL" "$VKD3D_PACKAGE" check256sum \
|
||||||
&& unpack "$VKD3D_PACKAGE" "$WH_VULKAN_LIBDIR"
|
&& unpack "$VKD3D_PACKAGE" "$WH_VULKAN_LIBDIR"
|
||||||
then
|
then
|
||||||
@@ -812,15 +828,15 @@ init_vkd3d () {
|
|||||||
}
|
}
|
||||||
|
|
||||||
for VKD3D_VAR_VER in "$USE_VKD3D_VER" $@ ; do
|
for VKD3D_VAR_VER in "$USE_VKD3D_VER" $@ ; do
|
||||||
if [[ ! -d "${WH_VULKAN_LIBDIR}/vkd3d-proton-$VKD3D_VAR_VER" ]] ; then
|
if [[ ! -d "${WH_VULKAN_LIBDIR}/${VKD3D_VAR_VER}" ]] ; then
|
||||||
get_vkd3d "$CLOUD_URL/vkd3d-proton-${VKD3D_VAR_VER}.tar.xz"
|
get_vkd3d "$CLOUD_URL/${VKD3D_VAR_VER}.tar.xz" "$VKD3D_VAR_VER"
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
VKD3D_FILES="d3d12 d3d12core libvkd3d-shader-1 libvkd3d-1" # libvkd3d-proton-utils-3
|
VKD3D_FILES="d3d12 d3d12core libvkd3d-shader-1 libvkd3d-1" # libvkd3d-proton-utils-3
|
||||||
for vkd3dfiles in $VKD3D_FILES ; do
|
for vkd3dfiles in $VKD3D_FILES ; do
|
||||||
try_copy_other_dll_to_pfx_64 "${WH_VULKAN_LIBDIR}/vkd3d-proton-$USE_VKD3D_VER/x64/$vkd3dfiles.dll"
|
try_copy_other_dll_to_pfx_64 "${WH_VULKAN_LIBDIR}/${USE_VKD3D_VER}/x64/$vkd3dfiles.dll"
|
||||||
if try_copy_other_dll_to_pfx_32 "${WH_VULKAN_LIBDIR}/vkd3d-proton-$USE_VKD3D_VER/x86/$vkd3dfiles.dll"
|
if try_copy_other_dll_to_pfx_32 "${WH_VULKAN_LIBDIR}/${USE_VKD3D_VER}/x86/$vkd3dfiles.dll"
|
||||||
then var_winedlloverride_update "$vkd3dfiles=n"
|
then var_winedlloverride_update "$vkd3dfiles=n"
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
@@ -1997,6 +2013,164 @@ restore_prefix() {
|
|||||||
return 0
|
return 0
|
||||||
}
|
}
|
||||||
|
|
||||||
|
update_last_conf_var() {
|
||||||
|
local var_name="$1"
|
||||||
|
local new_value="$2"
|
||||||
|
local conf_file="$WINEPREFIX/last.conf"
|
||||||
|
|
||||||
|
if [[ ! -f "$conf_file" ]] ; then
|
||||||
|
print_warning "Файл last.conf не найден, не могу обновить переменную $var_name."
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if grep -q "export $var_name=" "$conf_file"; then
|
||||||
|
sed -i "s|^export $var_name=.*|export $var_name=\"$new_value\"|" "$conf_file"
|
||||||
|
else
|
||||||
|
echo "export $var_name=\"$new_value\"" >> "$conf_file"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
list_component_versions() {
|
||||||
|
local component_group="$1"
|
||||||
|
local sha256_file="$DATA_PATH/sha256sum.list"
|
||||||
|
[[ ! -f "$sha256_file" ]] && fatal "Файл с версиями не найден: $sha256_file"
|
||||||
|
|
||||||
|
print_info "Доступные версии для $component_group:"
|
||||||
|
|
||||||
|
awk -v group="$component_group" '
|
||||||
|
/^#+\s*([^#]+?)\s*#*$/ {
|
||||||
|
current_group = $0
|
||||||
|
gsub(/^#+\s*|\s*#*$/, "", current_group)
|
||||||
|
}
|
||||||
|
/^[a-f0-9]{64}/ {
|
||||||
|
if (current_group == group) {
|
||||||
|
filename = $2
|
||||||
|
sub(/\.tar\.xz$/, "", filename)
|
||||||
|
print " - " filename
|
||||||
|
}
|
||||||
|
}
|
||||||
|
' "$sha256_file" | sort -Vr
|
||||||
|
}
|
||||||
|
|
||||||
|
select_component_version() {
|
||||||
|
local component_group="$1"
|
||||||
|
local sha256_file="$DATA_PATH/sha256sum.list"
|
||||||
|
[[ ! -f "$sha256_file" ]] && fatal "Файл с версиями не найден: $sha256_file"
|
||||||
|
|
||||||
|
local versions=()
|
||||||
|
local current_group=""
|
||||||
|
while IFS= read -r line; do
|
||||||
|
if [[ "$line" =~ ^#+[[:space:]]([^#[:space:]]+)[[:space:]]#* ]] ; then
|
||||||
|
current_group="${BASH_REMATCH[1]}"
|
||||||
|
elif [[ "$current_group" == "$component_group" ]] && [[ "$line" =~ [a-f0-9]{64} ]] ; then
|
||||||
|
local filename
|
||||||
|
filename=$(echo "$line" | awk '{print $2}')
|
||||||
|
local version_name=${filename%.tar.xz}
|
||||||
|
versions+=("$version_name")
|
||||||
|
fi
|
||||||
|
done < "$sha256_file"
|
||||||
|
|
||||||
|
IFS=$'\n' versions=($(sort -Vr <<<"${versions[*]}"))
|
||||||
|
unset IFS
|
||||||
|
|
||||||
|
if [[ ${#versions[@]} -eq 0 ]] ; then
|
||||||
|
print_warning "Не найдено доступных версий для $component_group." >&2
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
print_info "Выберите версию $component_group для установки:" >&2
|
||||||
|
echo >&2
|
||||||
|
|
||||||
|
local items_to_print=(" 0) Отмена")
|
||||||
|
for i in "${!versions[@]}" ; do
|
||||||
|
items_to_print+=(" $((i+1))) ${versions[$i]}")
|
||||||
|
done
|
||||||
|
|
||||||
|
local num_items=${#items_to_print[@]}
|
||||||
|
local term_width=${COLUMNS:-80}
|
||||||
|
local max_len=0
|
||||||
|
for item in "${items_to_print[@]}" ; do
|
||||||
|
(( ${#item} > max_len )) && max_len=${#item}
|
||||||
|
done
|
||||||
|
|
||||||
|
((max_len+=2))
|
||||||
|
local num_cols=$(( term_width / max_len ))
|
||||||
|
(( num_cols = num_cols > 0 ? num_cols : 1 ))
|
||||||
|
local num_rows=$(( (num_items + num_cols - 1) / num_cols ))
|
||||||
|
|
||||||
|
for ((i=0; i<num_rows; i++)) ; do
|
||||||
|
for ((j=0; j<num_cols; j++)) ; do
|
||||||
|
local index=$(( i + j * num_rows ))
|
||||||
|
(( index < num_items )) && printf "%-*s" "$max_len" "${items_to_print[index]}" >&2
|
||||||
|
done
|
||||||
|
echo >&2
|
||||||
|
done
|
||||||
|
|
||||||
|
local max_choice=${#versions[@]}
|
||||||
|
local user_choice
|
||||||
|
while true; do
|
||||||
|
echo >&2
|
||||||
|
read -p "Введите номер (0-$max_choice): " user_choice
|
||||||
|
if [[ "$user_choice" =~ ^[0-9]+$ ]] && (( user_choice >= 0 && user_choice <= max_choice )) ; then
|
||||||
|
if [[ "$user_choice" == "0" ]] ; then
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
echo "${versions[$((user_choice-1))]}"
|
||||||
|
return 0
|
||||||
|
else
|
||||||
|
print_error "Неверный выбор. Введите число от 0 до $max_choice." >&2
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
run_install_dxvk() {
|
||||||
|
local version="$1"
|
||||||
|
if [[ -z "$version" ]] ; then
|
||||||
|
version=$(select_component_version "DXVK")
|
||||||
|
[[ $? -ne 0 ]] && print_info "Установка DXVK отменена." && return
|
||||||
|
elif [[ "$version" == "list" ]]; then
|
||||||
|
list_component_versions "DXVK"
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
check_prefix_var
|
||||||
|
init_database
|
||||||
|
init_wine_ver
|
||||||
|
init_wineprefix
|
||||||
|
if [[ "$version" == "none" ]] ; then
|
||||||
|
print_info "Удаление DXVK..."
|
||||||
|
init_wined3d
|
||||||
|
update_last_conf_var "DXVK_VER" ""
|
||||||
|
else
|
||||||
|
init_dxvk "$version"
|
||||||
|
update_last_conf_var "DXVK_VER" "$USE_DXVK_VER"
|
||||||
|
fi
|
||||||
|
wait_wineserver
|
||||||
|
}
|
||||||
|
|
||||||
|
run_install_vkd3d() {
|
||||||
|
local version="$1"
|
||||||
|
if [[ -z "$version" ]] ; then
|
||||||
|
version=$(select_component_version "VKD3D")
|
||||||
|
[[ $? -ne 0 ]] && print_info "Установка VKD3D отменена." && return
|
||||||
|
elif [[ "$version" == "list" ]] ; then
|
||||||
|
list_component_versions "VKD3D"
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
check_prefix_var
|
||||||
|
init_database
|
||||||
|
init_wine_ver
|
||||||
|
init_wineprefix
|
||||||
|
if [[ "$version" == "none" ]] ; then
|
||||||
|
print_info "Удаление VKD3D..."
|
||||||
|
init_wined3d
|
||||||
|
update_last_conf_var "VKD3D_VER" ""
|
||||||
|
else
|
||||||
|
init_vkd3d "$version"
|
||||||
|
update_last_conf_var "VKD3D_VER" "$USE_VKD3D_VER"
|
||||||
|
fi
|
||||||
|
wait_wineserver
|
||||||
|
}
|
||||||
|
|
||||||
wh_info () {
|
wh_info () {
|
||||||
echo "Использование: $SCRIPT_NAME [команда]
|
echo "Использование: $SCRIPT_NAME [команда]
|
||||||
|
|
||||||
@@ -2005,6 +2179,9 @@ wh_info () {
|
|||||||
install [скрипт] запустить скрипт установки программы
|
install [скрипт] запустить скрипт установки программы
|
||||||
install [скрипт] --clear-pfx не использовать готовый префикс для установки ПО
|
install [скрипт] --clear-pfx не использовать готовый префикс для установки ПО
|
||||||
|
|
||||||
|
install-dxvk [версия|none|list] установить, удалить или показать версии DXVK
|
||||||
|
install-vkd3d [версия|none|list] установить, удалить или показать версии VKD3D
|
||||||
|
|
||||||
installed список установленных программ
|
installed список установленных программ
|
||||||
run [программа] запуск программы (отладка)
|
run [программа] запуск программы (отладка)
|
||||||
remove-all удалить WineHelper и все связанные данные
|
remove-all удалить WineHelper и все связанные данные
|
||||||
@@ -2052,6 +2229,8 @@ case "$arg1" in
|
|||||||
winetricks) prepair_wine ; "$WH_WINETRICKS" -q "$@" ;;
|
winetricks) prepair_wine ; "$WH_WINETRICKS" -q "$@" ;;
|
||||||
desktop) create_desktop "$@" ; exit 0 ;;
|
desktop) create_desktop "$@" ; exit 0 ;;
|
||||||
install|-i) run_autoinstall "$@" ;;
|
install|-i) run_autoinstall "$@" ;;
|
||||||
|
install-dxvk) run_install_dxvk "$@" ;;
|
||||||
|
install-vkd3d) run_install_vkd3d "$@" ;;
|
||||||
installed) check_installed_programs "$1" ;;
|
installed) check_installed_programs "$1" ;;
|
||||||
run|-r) run_installed_programs "$1" ;;
|
run|-r) run_installed_programs "$1" ;;
|
||||||
backup-prefix) backup_prefix "$@" ;;
|
backup-prefix) backup_prefix "$@" ;;
|
||||||
@@ -2064,17 +2243,8 @@ case "$arg1" in
|
|||||||
*)
|
*)
|
||||||
if [[ -f "$arg1" ]] ; then
|
if [[ -f "$arg1" ]] ; then
|
||||||
WIN_FILE_EXEC="$(readlink -f "$arg1")"
|
WIN_FILE_EXEC="$(readlink -f "$arg1")"
|
||||||
|
WIN_FILE_NAME="$(basename "$WIN_FILE_EXEC")"
|
||||||
# Автоматическое определение префикса, если он не задан
|
find_prefix "$WIN_FILE_EXEC"
|
||||||
if [[ -z "$WINEPREFIX" ]] && [[ "$WIN_FILE_EXEC" == "$WH_PREFIXES_DIR"* ]]; then
|
|
||||||
extracted_prefix="$(echo "$WIN_FILE_EXEC" | grep -o ".*/prefixes/[^/]*")"
|
|
||||||
if [[ -d "$extracted_prefix" ]]; then
|
|
||||||
export WINEPREFIX="$extracted_prefix"
|
|
||||||
print_info "Префикс автоматически определен: $(basename "$WINEPREFIX")"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
WIN_FILE_NAME="$(basename "$arg1")"
|
|
||||||
case "${WIN_FILE_NAME,,}" in
|
case "${WIN_FILE_NAME,,}" in
|
||||||
*.exe) prepair_wine ; wine_run $WINE_WIN_START "$WIN_FILE_EXEC" "$@" ;;
|
*.exe) prepair_wine ; wine_run $WINE_WIN_START "$WIN_FILE_EXEC" "$@" ;;
|
||||||
*.msi) prepair_wine ; wine_run msiexec /i "$WIN_FILE_EXEC" "$@" ;;
|
*.msi) prepair_wine ; wine_run msiexec /i "$WIN_FILE_EXEC" "$@" ;;
|
||||||
|
File diff suppressed because it is too large
Load Diff
Reference in New Issue
Block a user