Compare commits
11 Commits
34a60665ea
...
0.4.9
Author | SHA1 | Date | |
---|---|---|---|
8601dd600f | |||
9df3940ec9 | |||
f1315115c7 | |||
036957c729 | |||
c1791761d1 | |||
7dae7c4739 | |||
ddb644b732 | |||
d38b2ca2fb | |||
9ff0414693 | |||
3d13f3ca33 | |||
5e07495d9b |
12
CHANGELOG
12
CHANGELOG
@ -1,5 +1,17 @@
|
||||
История изменений:
|
||||
|
||||
0.4.9:
|
||||
* добавлено автодопонение команд для zsh (zsh_completion)
|
||||
|
||||
0.4.8:
|
||||
* все скрипты для программ daobit-* переведены из ручных установок в автоматические
|
||||
|
||||
0.4.7:
|
||||
* обновлены скрипты установки и префикс для программ ved-* и ctm-*
|
||||
* обновлены скрипты установки для программ daobit-*
|
||||
* улучшено отображение шрифтов в ПО: Справки БК
|
||||
* добавлена проверка хэш-суммы для сохраненных архивов
|
||||
|
||||
0.4.6:
|
||||
* добавлено автодопонение команд для bash (bash_completion)
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
# Auto-completion for winhelper
|
||||
# Auto-completion for winehelper
|
||||
_winehelper_completions() {
|
||||
local cur prev opts
|
||||
COMPREPLY=()
|
||||
|
114
auto_completion/zsh_completion/_winehelper
Normal file
114
auto_completion/zsh_completion/_winehelper
Normal file
@ -0,0 +1,114 @@
|
||||
#compdef winehelper
|
||||
# shellcheck disable=SC2034,SC2206
|
||||
_winehelper() {
|
||||
local -a opts wine_cmd scripts installed prefixes
|
||||
|
||||
opts=(
|
||||
'--help[Вывести справку]'
|
||||
'--version[Показать информацию о пакете и его версии]'
|
||||
'--debug[Режим отладки]'
|
||||
'install[Запустить скрипт установки программы]'
|
||||
'installed[Список установленных программ]'
|
||||
'-r[Запуск программы (отладка)]'
|
||||
'-i[Запустить скрипт установки программы]'
|
||||
'remove-all[Удалить WineHelper и все связанные данные]'
|
||||
'--clear-pfx[Очистить префикс \[имя_префикса\]]'
|
||||
'killall[Убить все процессы]'
|
||||
'remove-prefix[Удалить префикс и все связанные данные]'
|
||||
'backup-prefix[Создать резерную копию префикса]'
|
||||
'restore-prefix[восстановить префикс из резервной копии "путь/до/whpack"]'
|
||||
)
|
||||
|
||||
wine_cmd=(
|
||||
winecfg
|
||||
winereg
|
||||
winefile
|
||||
wineconsole
|
||||
winetricks
|
||||
desktop
|
||||
regedit
|
||||
explorer
|
||||
cmd
|
||||
'run[Запуск программы (отладка)]'
|
||||
)
|
||||
|
||||
local context state line
|
||||
_arguments -C \
|
||||
'1:command:->cmds' \
|
||||
'2:subcommand or argument:->args'
|
||||
|
||||
case $state in
|
||||
cmds)
|
||||
_values 'winehelper options' "${opts[@]}" "${wine_cmd[@]}"
|
||||
;;
|
||||
args)
|
||||
case $words[2] in
|
||||
--debug)
|
||||
_values 'wine commands' "${wine_cmd[@]}"
|
||||
;;
|
||||
install|-i)
|
||||
_get_list_for_install
|
||||
;;
|
||||
run|installed)
|
||||
_get_installed_list
|
||||
;;
|
||||
remove-prefix|backup-prefix)
|
||||
_get_prefixes
|
||||
;;
|
||||
restore-prefix)
|
||||
_files
|
||||
;;
|
||||
*)
|
||||
_values 'winehelper options' "${opts[@]}" "${wine_cmd[@]}"
|
||||
;;
|
||||
esac
|
||||
;;
|
||||
esac
|
||||
}
|
||||
|
||||
_get_prefixes () {
|
||||
prefixes=( ${(f)"$(ls -1 ~/.local/share/winehelper/prefixes 2>/dev/null)"} )
|
||||
|
||||
if ((! ${#prefixes[@]} == 0 )); then
|
||||
_values 'prefixes' "${prefixes[@]}"
|
||||
fi
|
||||
}
|
||||
|
||||
_get_list_for_install () {
|
||||
|
||||
packages=(${(f)"$(winehelper install list 2>/dev/null |
|
||||
awk -F ' - ' '
|
||||
/^[^ ]+ - \("/ {next}
|
||||
/^[[:space:]]*$/ {next}
|
||||
/^Информация:/ {next}
|
||||
/^[^ ]+ - / {
|
||||
name=$1;
|
||||
desc=$2;
|
||||
gsub(/^[[:space:]]+|[[:space:]]+$/, "", name);
|
||||
gsub(/^[[:space:]]*"?|"?[[:space:]]*$/, "", desc);
|
||||
if (name && desc) print name ":" desc
|
||||
}
|
||||
')"})
|
||||
|
||||
packages+=(
|
||||
scadoffice:"SCAD Office"
|
||||
t-flex-cad17-applications:"Приложения для T-FLEX CAD 17"
|
||||
t-flex-cad17-resources:"Обучающие материалы T-FLEX CAD 17"
|
||||
)
|
||||
|
||||
_describe 'packages' packages
|
||||
}
|
||||
|
||||
_get_installed_list () {
|
||||
installed=(
|
||||
${(f)"$(grep -h 'Exec=env' ~/.local/share/winehelper/*.desktop 2>/dev/null |
|
||||
awk -F'/' '{print $NF}' |
|
||||
awk -F'"' '{print $1}')"}
|
||||
)
|
||||
|
||||
if ((! ${#installed[@]} == 0 )); then
|
||||
_values 'installed apps' "${installed[@]}"
|
||||
fi
|
||||
}
|
||||
|
||||
compdef _winehelper winehelper
|
@ -9,23 +9,22 @@ export BASE_PFX="daobit_pfx_x86_v01"
|
||||
export WH_WINDOWS_VER="10"
|
||||
export WINEARCH="win32"
|
||||
export INSTALL_DLL="dotnet7 dotnetdesktop7 arial renderer=gdi"
|
||||
|
||||
AUTOINSTALL_EXE="${WH_TMP_DIR}/setup_cs.exe"
|
||||
AUTOINSTALL_UNPACK="${WH_TMP_DIR}/setup_cs"
|
||||
AUTOINSTALL_SETUP="${WH_TMP_DIR}/setup_cs/SETUP.EXE"
|
||||
EXE_SETUP_NAME="setup_cs.exe"
|
||||
|
||||
if [[ -f "$2" ]] && [[ $2 =~ $EXE_SETUP_NAME$ ]] ; then
|
||||
prepair_wine
|
||||
prepair_wine
|
||||
if try_download "https://files.daobit.ru/CSERVICE/SFX/setup_cs.exe" "${AUTOINSTALL_EXE}" ; then
|
||||
|
||||
# фикс постоянного запроса обновления Windows
|
||||
get_and_set_reg_file --add 'Software\DAO\DAOSETUP' 'SkipKBCheck' 'REG_DWORD' "1" "userdef"
|
||||
|
||||
unpack "$2" "${AUTOINSTALL_UNPACK}"
|
||||
unpack "${AUTOINSTALL_EXE}" "${AUTOINSTALL_UNPACK}"
|
||||
wine_run_install "${AUTOINSTALL_SETUP}" /cd /targetdir="C:\\\\Program Files\\\\DAO\\\\CSERVICE" /auto /hide
|
||||
|
||||
WIN_FILE_EXEC="$DRIVE_C/Program Files/DAO/CSERVICE/CService32.exe"
|
||||
create_desktop "$PROG_NAME" "$WIN_FILE_EXEC" "$PROG_ICON"
|
||||
try_remove_dir "$AUTOINSTALL_UNPACK"
|
||||
else
|
||||
fatal "Не найден файл установки для $PROG_NAME. Перезапустите по примеру:
|
||||
winehelper install $1 \"/путь/до/$EXE_SETUP_NAME\""
|
||||
try_remove_file "$AUTOINSTALL_EXE"
|
||||
fi
|
@ -9,23 +9,22 @@ export BASE_PFX="daobit_pfx_x86_v01"
|
||||
export WH_WINDOWS_VER="10"
|
||||
export WINEARCH="win32"
|
||||
export INSTALL_DLL="dotnet7 dotnetdesktop7 arial renderer=gdi"
|
||||
|
||||
AUTOINSTALL_EXE="${WH_TMP_DIR}/setup_rk.exe"
|
||||
AUTOINSTALL_UNPACK="${WH_TMP_DIR}/setup_rk"
|
||||
AUTOINSTALL_SETUP="${WH_TMP_DIR}/setup_rk/setup.exe"
|
||||
EXE_SETUP_NAME="setup_rk.exe"
|
||||
|
||||
if [[ -f "$2" ]] && [[ $2 =~ $EXE_SETUP_NAME$ ]] ; then
|
||||
prepair_wine
|
||||
prepair_wine
|
||||
if try_download "https://files.daobit.ru/RATLAS/SFX/setup_rk.exe" "${AUTOINSTALL_EXE}" ; then
|
||||
|
||||
# фикс постоянного запроса обновления Windows
|
||||
get_and_set_reg_file --add 'Software\DAO\DAOSETUP' 'SkipKBCheck' 'REG_DWORD' "1" "userdef"
|
||||
|
||||
unpack "$2" "${AUTOINSTALL_UNPACK}"
|
||||
unpack "${AUTOINSTALL_EXE}" "${AUTOINSTALL_UNPACK}"
|
||||
wine_run_install "${AUTOINSTALL_SETUP}" /cd /targetdir="C:\\\\Program Files\\\\DAO\\\\RAtlas" /auto /hide
|
||||
|
||||
WIN_FILE_EXEC="$DRIVE_C/Program Files/DAO/RAtlas/ratlas.exe"
|
||||
create_desktop "$PROG_NAME" "$WIN_FILE_EXEC" "$PROG_ICON"
|
||||
try_remove_dir "$AUTOINSTALL_UNPACK"
|
||||
else
|
||||
fatal "Не найден файл установки для $PROG_NAME. Перезапустите по примеру:
|
||||
winehelper install $1 \"/путь/до/$EXE_SETUP_NAME\""
|
||||
try_remove_file "$AUTOINSTALL_EXE"
|
||||
fi
|
@ -9,23 +9,22 @@ export BASE_PFX="daobit_pfx_x86_v01"
|
||||
export WH_WINDOWS_VER="10"
|
||||
export WINEARCH="win32"
|
||||
export INSTALL_DLL="dotnet7 dotnetdesktop7 arial renderer=gdi"
|
||||
|
||||
AUTOINSTALL_EXE="${WH_TMP_DIR}/setup_ri.exe"
|
||||
AUTOINSTALL_UNPACK="${WH_TMP_DIR}/setup_ri"
|
||||
AUTOINSTALL_SETUP="${WH_TMP_DIR}/setup_ri/setup.exe"
|
||||
EXE_SETUP_NAME="setup_ri.exe"
|
||||
|
||||
if [[ -f "$2" ]] && [[ $2 =~ $EXE_SETUP_NAME$ ]] ; then
|
||||
prepair_wine
|
||||
prepair_wine
|
||||
if try_download "https://files.daobit.ru/RINFO/SFX/setup_ri.exe" "${AUTOINSTALL_EXE}" ; then
|
||||
|
||||
# фикс постоянного запроса обновления Windows
|
||||
get_and_set_reg_file --add 'Software\DAO\DAOSETUP' 'SkipKBCheck' 'REG_DWORD' "1" "userdef"
|
||||
|
||||
unpack "$2" "${AUTOINSTALL_UNPACK}"
|
||||
unpack "${AUTOINSTALL_EXE}" "${AUTOINSTALL_UNPACK}"
|
||||
wine_run_install "${AUTOINSTALL_SETUP}" /cd /targetdir="C:\\\\Program Files\\\\DAO\\\\RInfo" /auto /hide
|
||||
|
||||
WIN_FILE_EXEC="$DRIVE_C/Program Files/DAO/RInfo/rinfo.exe"
|
||||
create_desktop "$PROG_NAME" "$WIN_FILE_EXEC" "$PROG_ICON"
|
||||
try_remove_dir "$AUTOINSTALL_UNPACK"
|
||||
else
|
||||
fatal "Не найден файл установки для $PROG_NAME. Перезапустите по примеру:
|
||||
winehelper install $1 \"/путь/до/$EXE_SETUP_NAME\""
|
||||
try_remove_file "$AUTOINSTALL_EXE"
|
||||
fi
|
@ -9,23 +9,22 @@ export BASE_PFX="daobit_pfx_x86_v01"
|
||||
export WH_WINDOWS_VER="10"
|
||||
export WINEARCH="win32"
|
||||
export INSTALL_DLL="dotnet7 dotnetdesktop7 arial renderer=gdi"
|
||||
|
||||
AUTOINSTALL_EXE="${WH_TMP_DIR}/setup_rt.exe"
|
||||
AUTOINSTALL_UNPACK="${WH_TMP_DIR}/setup_rt"
|
||||
AUTOINSTALL_SETUP="${WH_TMP_DIR}/setup_rt/setup.exe"
|
||||
EXE_SETUP_NAME="setup_rt.exe"
|
||||
|
||||
if [[ -f "$2" ]] && [[ $2 =~ $EXE_SETUP_NAME$ ]] ; then
|
||||
prepair_wine
|
||||
prepair_wine
|
||||
if try_download "https://files.daobit.ru/RTARIFF/SFX/setup_rt.exe" "${AUTOINSTALL_EXE}" ; then
|
||||
|
||||
# фикс постоянного запроса обновления Windows
|
||||
get_and_set_reg_file --add 'Software\DAO\DAOSETUP' 'SkipKBCheck' 'REG_DWORD' "1" "userdef"
|
||||
|
||||
unpack "$2" "${AUTOINSTALL_UNPACK}"
|
||||
unpack "${AUTOINSTALL_EXE}" "${AUTOINSTALL_UNPACK}"
|
||||
wine_run_install "${AUTOINSTALL_SETUP}" /cd /targetdir="C:\\\\Program Files\\\\DAO\\\\RTariff" /auto /hide
|
||||
|
||||
WIN_FILE_EXEC="$DRIVE_C/Program Files/DAO/RTariff/Tariff.exe"
|
||||
create_desktop "$PROG_NAME" "$WIN_FILE_EXEC" "$PROG_ICON"
|
||||
try_remove_dir "$AUTOINSTALL_UNPACK"
|
||||
else
|
||||
fatal "Не найден файл установки для $PROG_NAME. Перезапустите по примеру:
|
||||
winehelper install $1 \"/путь/до/$EXE_SETUP_NAME\""
|
||||
try_remove_file "$AUTOINSTALL_EXE"
|
||||
fi
|
117
winehelper
117
winehelper
@ -259,11 +259,13 @@ unpack () {
|
||||
esac
|
||||
create_new_dir "$2"
|
||||
if [[ $skip_xattr == "1" ]] \
|
||||
&& $command "$1" ${outarg}"$2" 2>&1 | grep -v "xattr"
|
||||
&& $command "$1" ${outarg}"$2" 2>&1 | sed "/xattr/d"
|
||||
then print_ok "Файл $1 распакован."
|
||||
elif $command "$1" ${outarg}"$2"
|
||||
then print_ok "Файл $1 распакован."
|
||||
else fatal "Распаковать файл $1 не удалось!"
|
||||
else
|
||||
try_remove_file "$1"
|
||||
fatal "Распаковать файл $1 не удалось!"
|
||||
fi
|
||||
return 0
|
||||
}
|
||||
@ -294,31 +296,46 @@ read_page () {
|
||||
fi
|
||||
}
|
||||
|
||||
try_download () {
|
||||
local DOWNLOAD_FILE_URL="${1// /%20}"
|
||||
local OUTPUT_FILE="$2"
|
||||
local OUTPUT_FILE_NAME="$(basename "$OUTPUT_FILE")"
|
||||
check_file_sum () {
|
||||
local sha256sum_ext sha256sum_int check_file_path check_file_name
|
||||
check_file_path="$1"
|
||||
check_file_name="$(basename "$check_file_path")"
|
||||
|
||||
print_info "Скачивание файла $OUTPUT_FILE_NAME..."
|
||||
if curl -f --progress-bar -A "Mozilla/5.0 (compatible; Konqueror/2.1.1; X11)" \
|
||||
-L "$DOWNLOAD_FILE_URL" -o "$OUTPUT_FILE"
|
||||
then
|
||||
print_ok "Скачивание файла $OUTPUT_FILE_NAME прошло успешно."
|
||||
if [[ "$3" == check256sum ]] ; then
|
||||
SHA256SUM_EXT=$(sha256sum "$OUTPUT_FILE" | awk '{print $1}')
|
||||
SHA256SUM_INT="$(grep "$OUTPUT_FILE_NAME" "$DATA_PATH/sha256sum.list" | awk '{print $1}')"
|
||||
if [[ "$SHA256SUM_EXT" == "$SHA256SUM_INT" ]] ; then
|
||||
print_ok "Хэш-сумма файла $OUTPUT_FILE_NAME успешно проверена."
|
||||
return 0
|
||||
else
|
||||
fatal "Хэш-сумма файла $OUTPUT_FILE_NAME не совподает!"
|
||||
return 1
|
||||
fi
|
||||
fi
|
||||
sha256sum_ext=$(sha256sum "$check_file_path" | awk '{print $1}')
|
||||
sha256sum_int="$(grep "$check_file_name" "$DATA_PATH/sha256sum.list" | awk '{print $1}')"
|
||||
|
||||
if [[ "$sha256sum_ext" == "$sha256sum_int" ]] ; then
|
||||
print_ok "Хэш-сумма файла $check_file_name успешно проверена."
|
||||
return 0
|
||||
else
|
||||
fatal "Скачивание файла: $OUTPUT_FILE_NAME завершилось с ошибкой!"
|
||||
return 1
|
||||
try_remove_file "$check_file_path"
|
||||
fatal "Хэш-сумма файла $check_file_name не совподает!"
|
||||
fi
|
||||
}
|
||||
|
||||
try_download () {
|
||||
local download_file_url output_file output_file_name
|
||||
download_file_url="${1// /%20}"
|
||||
output_file="$2"
|
||||
output_file_name="$(basename "$output_file")"
|
||||
|
||||
if [[ -f "$output_file" ]] ; then
|
||||
print_info "Файл найден: $output_file"
|
||||
[[ $3 == "check256sum" ]] && check_file_sum "$output_file"
|
||||
return 0
|
||||
else
|
||||
print_info "Скачивание файла $output_file_name..."
|
||||
if curl -f --progress-bar -A "Mozilla/5.0 (compatible; Konqueror/2.1.1; X11)" \
|
||||
-L "$download_file_url" -o "$output_file"
|
||||
then
|
||||
print_ok "Скачивание файла $output_file_name прошло успешно."
|
||||
[[ $3 == "check256sum" ]] && check_file_sum "$output_file"
|
||||
return 0
|
||||
else
|
||||
try_remove_file "$output_file"
|
||||
fatal "Скачивание файла: $output_file_name завершилось с ошибкой!"
|
||||
return 1
|
||||
fi
|
||||
fi
|
||||
}
|
||||
|
||||
@ -681,11 +698,11 @@ init_wine_ver () {
|
||||
if [[ ! -d "$WINEDIR" ]] ; then
|
||||
WINE_URL="$CLOUD_URL/$WH_WINE_USE.tar.xz"
|
||||
local WINE_PACKAGE="$WH_TMP_DIR/${WH_WINE_USE}.tar.xz"
|
||||
if try_download "$WINE_URL" "$WINE_PACKAGE" check256sum ; then
|
||||
if unpack "$WINE_PACKAGE" "$WH_DIST_DIR/" ; then
|
||||
echo "$WH_WINE_USE" > "$WH_DIST_DIR/$WH_WINE_USE/version"
|
||||
try_remove_file "$WINE_PACKAGE"
|
||||
fi
|
||||
if try_download "$WINE_URL" "$WINE_PACKAGE" check256sum \
|
||||
&& unpack "$WINE_PACKAGE" "$WH_DIST_DIR/"
|
||||
then
|
||||
echo "$WH_WINE_USE" > "$WH_DIST_DIR/$WH_WINE_USE/version"
|
||||
try_remove_file "$WINE_PACKAGE"
|
||||
fi
|
||||
fi
|
||||
|
||||
@ -730,15 +747,8 @@ init_wine_ver () {
|
||||
CPCSP_PROXY_NAME="wine-cpcsp_proxy-$CPCSP_PROXY_VER"
|
||||
CPCSP_PROXY_URL="$CLOUD_URL/$CPCSP_PROXY_NAME.tar.xz"
|
||||
|
||||
if [[ ! -f "$WH_TMP_DIR/$CPCSP_PROXY_NAME" ]] ; then
|
||||
print_info "Загрузка $CPCSP_PROXY_NAME.tar.xz"
|
||||
if try_download "$CPCSP_PROXY_URL" "$WH_TMP_DIR/$CPCSP_PROXY_NAME.tar.xz" check256sum
|
||||
then unpack "$WH_TMP_DIR/$CPCSP_PROXY_NAME.tar.xz" "$WH_TMP_DIR"
|
||||
else try_remove_file "$WH_TMP_DIR/$CPCSP_PROXY_NAME.tar.xz"
|
||||
fi
|
||||
else
|
||||
unpack "$WH_TMP_DIR/$CPCSP_PROXY_NAME.tar.xz" "$WH_TMP_DIR"
|
||||
fi
|
||||
try_download "$CPCSP_PROXY_URL" "$WH_TMP_DIR/$CPCSP_PROXY_NAME.tar.xz" check256sum
|
||||
unpack "$WH_TMP_DIR/$CPCSP_PROXY_NAME.tar.xz" "$WH_TMP_DIR"
|
||||
|
||||
cp -fr "$WH_TMP_DIR/$CPCSP_PROXY_NAME/"i386-* "${WINEDIR}/lib/wine/"
|
||||
if [[ -d "${WINEDIR}/lib64" ]] ; then
|
||||
@ -873,23 +883,15 @@ wait_wineserver () {
|
||||
}
|
||||
|
||||
get_base_pfx () {
|
||||
local FILE_NAME_PFX="$1"
|
||||
local PFX_URL="$CLOUD_URL/${FILE_NAME_PFX}.tar.xz"
|
||||
local PFX_TMP="$WH_TMP_DIR/pfx"
|
||||
create_new_dir "$PFX_TMP"
|
||||
local pfx_file_name pfx_file_url pfx_tmp_path
|
||||
pfx_file_name="${1}.tar.xz"
|
||||
pfx_file_url="$CLOUD_URL/$pfx_file_name"
|
||||
pfx_tmp_path="$WH_TMP_DIR/pfx"
|
||||
|
||||
if [[ ! -f "$PFX_TMP/$FILE_NAME_PFX.tar.xz" ]] ; then
|
||||
print_info "Загрузка базового префикса: ${FILE_NAME_PFX}"
|
||||
if try_download "$PFX_URL" "$PFX_TMP/$FILE_NAME_PFX.tar.xz" check256sum
|
||||
then unpack --skip-xattr "$PFX_TMP/$FILE_NAME_PFX.tar.xz" "$WINEPREFIX/"
|
||||
else try_remove_file "$PFX_TMP/$FILE_NAME_PFX.tar.xz"
|
||||
fi
|
||||
else
|
||||
if ! unpack --skip-xattr "$PFX_TMP/$FILE_NAME_PFX.tar.xz" "$WINEPREFIX/" ; then
|
||||
try_remove_file "${PFX_TMP}/${FILE_NAME_PFX}.tar.xz"
|
||||
get_base_pfx "$FILE_NAME_PFX"
|
||||
fi
|
||||
fi
|
||||
create_new_dir "$pfx_tmp_path"
|
||||
print_info "Загрузка архива базового префикса: $pfx_file_name"
|
||||
try_download "$pfx_file_url" "$pfx_tmp_path/$pfx_file_name" check256sum
|
||||
unpack --skip-xattr "$pfx_tmp_path/$pfx_file_name" "$WINEPREFIX/"
|
||||
}
|
||||
|
||||
check_prefix_var () {
|
||||
@ -1080,12 +1082,11 @@ init_wineprefix () {
|
||||
if [[ $WH_USE_EXTRA_FONTS == "1" ]] \
|
||||
&& [[ ! -e "$fonts_dir/${x_fonts_name}.installed" ]]
|
||||
then
|
||||
print_info "Устанавливаем дополнительные шрифты..."
|
||||
local x_fonts_url="$CLOUD_URL/${x_fonts_name}.tar.xz"
|
||||
local x_fonts_tar="$WH_TMP_DIR/${x_fonts_name}.tar.xz"
|
||||
if [[ ! -f "$x_fonts_tar" ]] ; then
|
||||
try_download "$x_fonts_url" "$x_fonts_tar" check256sum
|
||||
fi
|
||||
|
||||
print_info "Устанавливаем дополнительные шрифты..."
|
||||
try_download "$x_fonts_url" "$x_fonts_tar" check256sum
|
||||
unpack "$x_fonts_tar" "$fonts_dir/"
|
||||
touch "$fonts_dir/${x_fonts_name}.installed"
|
||||
fi
|
||||
|
Reference in New Issue
Block a user