mirror of
https://gitee.com/gfdgd-xi/deep-wine-runner
synced 2025-01-26 16:08:05 +08:00
dxvk目录移除
This commit is contained in:
parent
e18b963dbb
commit
0b27c043ea
231
dxvk/auto.sh
231
dxvk/auto.sh
@ -1,231 +0,0 @@
|
|||||||
#!/usr/bin/env bash
|
|
||||||
function wait(){
|
|
||||||
echo ""
|
|
||||||
}
|
|
||||||
# default directories
|
|
||||||
dxvk_lib32=${dxvk_lib32:-"x32"}
|
|
||||||
dxvk_lib64=${dxvk_lib64:-"x64"}
|
|
||||||
|
|
||||||
# figure out where we are
|
|
||||||
basedir=$(dirname "$(readlink -f $0)")
|
|
||||||
|
|
||||||
# figure out which action to perform
|
|
||||||
action="$1"
|
|
||||||
|
|
||||||
case "$action" in
|
|
||||||
install)
|
|
||||||
;;
|
|
||||||
uninstall)
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
echo "Unrecognized action: $action"
|
|
||||||
echo "Usage: $0 [install|uninstall] [--without-dxgi] [--with-d3d10] [--symlink]"
|
|
||||||
wait
|
|
||||||
exit 1
|
|
||||||
esac
|
|
||||||
|
|
||||||
# process arguments
|
|
||||||
shift
|
|
||||||
|
|
||||||
with_dxgi=true
|
|
||||||
with_d3d10=false
|
|
||||||
file_cmd="cp -v"
|
|
||||||
|
|
||||||
while (($# > 0)); do
|
|
||||||
case "$1" in
|
|
||||||
"--without-dxgi")
|
|
||||||
with_dxgi=false
|
|
||||||
;;
|
|
||||||
"--with-d3d10")
|
|
||||||
with_d3d10=true
|
|
||||||
;;
|
|
||||||
"--symlink")
|
|
||||||
file_cmd="ln -s -v"
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
shift
|
|
||||||
done
|
|
||||||
|
|
||||||
# check wine prefix before invoking wine, so that we
|
|
||||||
# don't accidentally create one if the user screws up
|
|
||||||
if [ -n "$WINEPREFIX" ] && ! [ -f "$WINEPREFIX/system.reg" ]; then
|
|
||||||
echo "$WINEPREFIX:"' Not a valid wine prefix.' >&2
|
|
||||||
wait
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# find wine executable
|
|
||||||
export WINEDEBUG=-all
|
|
||||||
# disable mscoree and mshtml to avoid downloading
|
|
||||||
# wine gecko and mono
|
|
||||||
export WINEDLLOVERRIDES="mscoree,mshtml="
|
|
||||||
# 专门添加,为了可以使用自定义的 wine
|
|
||||||
wine=$WINE
|
|
||||||
wine64=$WINE64
|
|
||||||
wineboot="$WINE wineboot"
|
|
||||||
if [[ $WINE == "" ]];then
|
|
||||||
wine="wine"
|
|
||||||
fi
|
|
||||||
if [[ $WINE64 == "" ]];then
|
|
||||||
wine64="wine64"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# $PATH is the way for user to control where wine is located (including custom Wine versions).
|
|
||||||
# Pure 64-bit Wine (non Wow64) requries skipping 32-bit steps.
|
|
||||||
# In such case, wine64 and winebooot will be present, but wine binary will be missing,
|
|
||||||
# however it can be present in other PATHs, so it shouldn't be used, to avoid versions mixing.
|
|
||||||
wine_path=$(dirname "$(which $wineboot)")
|
|
||||||
wow64=true
|
|
||||||
if ! [ -f "$wine_path/$wine" ]; then
|
|
||||||
wine=$wine64
|
|
||||||
wow64=false
|
|
||||||
wineboot="$wine64 wineboot"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# resolve 32-bit and 64-bit system32 path
|
|
||||||
winever=$($wine --version | grep wine)
|
|
||||||
if [ -z "$winever" ]; then
|
|
||||||
echo "$wine:"' Not a wine executable. Check your $wine.' >&2
|
|
||||||
wait
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# ensure wine placeholder dlls are recreated
|
|
||||||
# if they are missing
|
|
||||||
$wineboot -u
|
|
||||||
|
|
||||||
win64_sys_path=$($wine64 winepath -u 'C:\windows\system32' 2> /dev/null)
|
|
||||||
win64_sys_path="${win64_sys_path/$'\r'/}"
|
|
||||||
if $wow64; then
|
|
||||||
win32_sys_path=$($wine winepath -u 'C:\windows\system32' 2> /dev/null)
|
|
||||||
win32_sys_path="${win32_sys_path/$'\r'/}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -z "$win32_sys_path" ] && [ -z "$win64_sys_path" ]; then
|
|
||||||
echo 'Failed to resolve C:\windows\system32.' >&2
|
|
||||||
wait
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# create native dll override
|
|
||||||
overrideDll() {
|
|
||||||
$wine reg add 'HKEY_CURRENT_USER\Software\Wine\DllOverrides' /v $1 /d native /f >/dev/null 2>&1
|
|
||||||
if [ $? -ne 0 ]; then
|
|
||||||
echo -e "Failed to add override for $1"
|
|
||||||
wait
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# remove dll override
|
|
||||||
restoreDll() {
|
|
||||||
$wine reg delete 'HKEY_CURRENT_USER\Software\Wine\DllOverrides' /v $1 /f > /dev/null 2>&1
|
|
||||||
if [ $? -ne 0 ]; then
|
|
||||||
echo "Failed to remove override for $1"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# copy or link dxvk dll, back up original file
|
|
||||||
installFile() {
|
|
||||||
dstfile="${1}/${3}.dll"
|
|
||||||
srcfile="${basedir}/${2}/${3}.dll"
|
|
||||||
|
|
||||||
if [ -f "${srcfile}.so" ]; then
|
|
||||||
srcfile="${srcfile}.so"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! [ -f "${srcfile}" ]; then
|
|
||||||
echo "${srcfile}: File not found. Skipping." >&2
|
|
||||||
return 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -n "$1" ]; then
|
|
||||||
if [ -f "${dstfile}" ] || [ -h "${dstfile}" ]; then
|
|
||||||
if ! [ -f "${dstfile}.old" ]; then
|
|
||||||
mv -v "${dstfile}" "${dstfile}.old"
|
|
||||||
else
|
|
||||||
rm -v "${dstfile}"
|
|
||||||
fi
|
|
||||||
$file_cmd "${srcfile}" "${dstfile}"
|
|
||||||
else
|
|
||||||
echo "${dstfile}: File not found in wine prefix" >&2
|
|
||||||
return 1
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
return 0
|
|
||||||
}
|
|
||||||
|
|
||||||
# remove dxvk dll, restore original file
|
|
||||||
uninstallFile() {
|
|
||||||
dstfile="${1}/${3}.dll"
|
|
||||||
srcfile="${basedir}/${2}/${3}.dll"
|
|
||||||
|
|
||||||
if [ -f "${srcfile}.so" ]; then
|
|
||||||
srcfile="${srcfile}.so"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! [ -f "${srcfile}" ]; then
|
|
||||||
echo "${srcfile}: File not found. Skipping." >&2
|
|
||||||
return 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! [ -f "${dstfile}" ] && ! [ -h "${dstfile}" ]; then
|
|
||||||
echo "${dstfile}: File not found. Skipping." >&2
|
|
||||||
return 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -f "${dstfile}.old" ]; then
|
|
||||||
rm -v "${dstfile}"
|
|
||||||
mv -v "${dstfile}.old" "${dstfile}"
|
|
||||||
return 0
|
|
||||||
else
|
|
||||||
return 1
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
install() {
|
|
||||||
installFile "$win64_sys_path" "$dxvk_lib64" "$1"
|
|
||||||
inst64_ret="$?"
|
|
||||||
|
|
||||||
inst32_ret=-1
|
|
||||||
if $wow64; then
|
|
||||||
installFile "$win32_sys_path" "$dxvk_lib32" "$1"
|
|
||||||
inst32_ret="$?"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if (( ($inst32_ret == 0) || ($inst64_ret == 0) )); then
|
|
||||||
overrideDll "$1"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
uninstall() {
|
|
||||||
uninstallFile "$win64_sys_path" "$dxvk_lib64" "$1"
|
|
||||||
uninst64_ret="$?"
|
|
||||||
|
|
||||||
uninst32_ret=-1
|
|
||||||
if $wow64; then
|
|
||||||
uninstallFile "$win32_sys_path" "$dxvk_lib32" "$1"
|
|
||||||
uninst32_ret="$?"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if (( ($uninst32_ret == 0) || ($uninst64_ret == 0) )); then
|
|
||||||
restoreDll "$1"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# skip dxgi during install if not explicitly
|
|
||||||
# enabled, but always try to uninstall it
|
|
||||||
if $with_dxgi || [ "$action" == "uninstall" ]; then
|
|
||||||
$action dxgi
|
|
||||||
fi
|
|
||||||
|
|
||||||
$action d3d9
|
|
||||||
|
|
||||||
if $with_d3d10 || [ "$action" == "uninstall" ]; then
|
|
||||||
$action d3d10
|
|
||||||
$action d3d10_1
|
|
||||||
fi
|
|
||||||
|
|
||||||
$action d3d10core
|
|
||||||
$action d3d11
|
|
||||||
wait
|
|
@ -1,232 +0,0 @@
|
|||||||
#!/usr/bin/env bash
|
|
||||||
function wait(){
|
|
||||||
echo Press Enter To Exit
|
|
||||||
read
|
|
||||||
}
|
|
||||||
# default directories
|
|
||||||
dxvk_lib32=${dxvk_lib32:-"x32"}
|
|
||||||
dxvk_lib64=${dxvk_lib64:-"x64"}
|
|
||||||
|
|
||||||
# figure out where we are
|
|
||||||
basedir=$(dirname "$(readlink -f $0)")
|
|
||||||
|
|
||||||
# figure out which action to perform
|
|
||||||
action="$1"
|
|
||||||
|
|
||||||
case "$action" in
|
|
||||||
install)
|
|
||||||
;;
|
|
||||||
uninstall)
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
echo "Unrecognized action: $action"
|
|
||||||
echo "Usage: $0 [install|uninstall] [--without-dxgi] [--with-d3d10] [--symlink]"
|
|
||||||
wait
|
|
||||||
exit 1
|
|
||||||
esac
|
|
||||||
|
|
||||||
# process arguments
|
|
||||||
shift
|
|
||||||
|
|
||||||
with_dxgi=true
|
|
||||||
with_d3d10=false
|
|
||||||
file_cmd="cp -v"
|
|
||||||
|
|
||||||
while (($# > 0)); do
|
|
||||||
case "$1" in
|
|
||||||
"--without-dxgi")
|
|
||||||
with_dxgi=false
|
|
||||||
;;
|
|
||||||
"--with-d3d10")
|
|
||||||
with_d3d10=true
|
|
||||||
;;
|
|
||||||
"--symlink")
|
|
||||||
file_cmd="ln -s -v"
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
shift
|
|
||||||
done
|
|
||||||
|
|
||||||
# check wine prefix before invoking wine, so that we
|
|
||||||
# don't accidentally create one if the user screws up
|
|
||||||
if [ -n "$WINEPREFIX" ] && ! [ -f "$WINEPREFIX/system.reg" ]; then
|
|
||||||
echo "$WINEPREFIX:"' Not a valid wine prefix.' >&2
|
|
||||||
wait
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# find wine executable
|
|
||||||
export WINEDEBUG=-all
|
|
||||||
# disable mscoree and mshtml to avoid downloading
|
|
||||||
# wine gecko and mono
|
|
||||||
export WINEDLLOVERRIDES="mscoree,mshtml="
|
|
||||||
# 专门添加,为了可以使用自定义的 wine
|
|
||||||
wine=$WINE
|
|
||||||
wine64=$WINE64
|
|
||||||
wineboot="$WINE wineboot"
|
|
||||||
if [[ $WINE == "" ]];then
|
|
||||||
wine="wine"
|
|
||||||
fi
|
|
||||||
if [[ $WINE64 == "" ]];then
|
|
||||||
wine64="wine64"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# $PATH is the way for user to control where wine is located (including custom Wine versions).
|
|
||||||
# Pure 64-bit Wine (non Wow64) requries skipping 32-bit steps.
|
|
||||||
# In such case, wine64 and winebooot will be present, but wine binary will be missing,
|
|
||||||
# however it can be present in other PATHs, so it shouldn't be used, to avoid versions mixing.
|
|
||||||
wine_path=$(dirname "$(which $wineboot)")
|
|
||||||
wow64=true
|
|
||||||
if ! [ -f "$wine_path/$wine" ]; then
|
|
||||||
wine=$wine64
|
|
||||||
wow64=false
|
|
||||||
wineboot="$wine64 wineboot"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# resolve 32-bit and 64-bit system32 path
|
|
||||||
winever=$($wine --version | grep wine)
|
|
||||||
if [ -z "$winever" ]; then
|
|
||||||
echo "$wine:"' Not a wine executable. Check your $wine.' >&2
|
|
||||||
wait
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# ensure wine placeholder dlls are recreated
|
|
||||||
# if they are missing
|
|
||||||
$wineboot -u
|
|
||||||
|
|
||||||
win64_sys_path=$($wine64 winepath -u 'C:\windows\system32' 2> /dev/null)
|
|
||||||
win64_sys_path="${win64_sys_path/$'\r'/}"
|
|
||||||
if $wow64; then
|
|
||||||
win32_sys_path=$($wine winepath -u 'C:\windows\system32' 2> /dev/null)
|
|
||||||
win32_sys_path="${win32_sys_path/$'\r'/}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -z "$win32_sys_path" ] && [ -z "$win64_sys_path" ]; then
|
|
||||||
echo 'Failed to resolve C:\windows\system32.' >&2
|
|
||||||
wait
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# create native dll override
|
|
||||||
overrideDll() {
|
|
||||||
$wine reg add 'HKEY_CURRENT_USER\Software\Wine\DllOverrides' /v $1 /d native /f >/dev/null 2>&1
|
|
||||||
if [ $? -ne 0 ]; then
|
|
||||||
echo -e "Failed to add override for $1"
|
|
||||||
wait
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# remove dll override
|
|
||||||
restoreDll() {
|
|
||||||
$wine reg delete 'HKEY_CURRENT_USER\Software\Wine\DllOverrides' /v $1 /f > /dev/null 2>&1
|
|
||||||
if [ $? -ne 0 ]; then
|
|
||||||
echo "Failed to remove override for $1"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# copy or link dxvk dll, back up original file
|
|
||||||
installFile() {
|
|
||||||
dstfile="${1}/${3}.dll"
|
|
||||||
srcfile="${basedir}/${2}/${3}.dll"
|
|
||||||
|
|
||||||
if [ -f "${srcfile}.so" ]; then
|
|
||||||
srcfile="${srcfile}.so"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! [ -f "${srcfile}" ]; then
|
|
||||||
echo "${srcfile}: File not found. Skipping." >&2
|
|
||||||
return 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -n "$1" ]; then
|
|
||||||
if [ -f "${dstfile}" ] || [ -h "${dstfile}" ]; then
|
|
||||||
if ! [ -f "${dstfile}.old" ]; then
|
|
||||||
mv -v "${dstfile}" "${dstfile}.old"
|
|
||||||
else
|
|
||||||
rm -v "${dstfile}"
|
|
||||||
fi
|
|
||||||
$file_cmd "${srcfile}" "${dstfile}"
|
|
||||||
else
|
|
||||||
echo "${dstfile}: File not found in wine prefix" >&2
|
|
||||||
return 1
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
return 0
|
|
||||||
}
|
|
||||||
|
|
||||||
# remove dxvk dll, restore original file
|
|
||||||
uninstallFile() {
|
|
||||||
dstfile="${1}/${3}.dll"
|
|
||||||
srcfile="${basedir}/${2}/${3}.dll"
|
|
||||||
|
|
||||||
if [ -f "${srcfile}.so" ]; then
|
|
||||||
srcfile="${srcfile}.so"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! [ -f "${srcfile}" ]; then
|
|
||||||
echo "${srcfile}: File not found. Skipping." >&2
|
|
||||||
return 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! [ -f "${dstfile}" ] && ! [ -h "${dstfile}" ]; then
|
|
||||||
echo "${dstfile}: File not found. Skipping." >&2
|
|
||||||
return 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -f "${dstfile}.old" ]; then
|
|
||||||
rm -v "${dstfile}"
|
|
||||||
mv -v "${dstfile}.old" "${dstfile}"
|
|
||||||
return 0
|
|
||||||
else
|
|
||||||
return 1
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
install() {
|
|
||||||
installFile "$win64_sys_path" "$dxvk_lib64" "$1"
|
|
||||||
inst64_ret="$?"
|
|
||||||
|
|
||||||
inst32_ret=-1
|
|
||||||
if $wow64; then
|
|
||||||
installFile "$win32_sys_path" "$dxvk_lib32" "$1"
|
|
||||||
inst32_ret="$?"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if (( ($inst32_ret == 0) || ($inst64_ret == 0) )); then
|
|
||||||
overrideDll "$1"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
uninstall() {
|
|
||||||
uninstallFile "$win64_sys_path" "$dxvk_lib64" "$1"
|
|
||||||
uninst64_ret="$?"
|
|
||||||
|
|
||||||
uninst32_ret=-1
|
|
||||||
if $wow64; then
|
|
||||||
uninstallFile "$win32_sys_path" "$dxvk_lib32" "$1"
|
|
||||||
uninst32_ret="$?"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if (( ($uninst32_ret == 0) || ($uninst64_ret == 0) )); then
|
|
||||||
restoreDll "$1"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
# skip dxgi during install if not explicitly
|
|
||||||
# enabled, but always try to uninstall it
|
|
||||||
if $with_dxgi || [ "$action" == "uninstall" ]; then
|
|
||||||
$action dxgi
|
|
||||||
fi
|
|
||||||
|
|
||||||
$action d3d9
|
|
||||||
|
|
||||||
if $with_d3d10 || [ "$action" == "uninstall" ]; then
|
|
||||||
$action d3d10
|
|
||||||
$action d3d10_1
|
|
||||||
fi
|
|
||||||
|
|
||||||
$action d3d10core
|
|
||||||
$action d3d11
|
|
||||||
wait
|
|
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Loading…
x
Reference in New Issue
Block a user