fix: use $HOME/.cache for logging

This commit is contained in:
hexlocation 2024-11-09 21:04:48 +01:00
parent 087a0085b7
commit ac70db79c7

View File

@ -9,8 +9,10 @@
# In case the user does not use the XDG Base Directory Specification # In case the user does not use the XDG Base Directory Specification
# https://specifications.freedesktop.org/basedir-spec/latest # https://specifications.freedesktop.org/basedir-spec/latest
XDG_DATA_HOME="$HOME/.local/share" XDG_DATA_HOME="$HOME/.local/share"
XDG_CACHE_HOME="$HOME/.cache"
if [ ! -d "$XDG_CACHE_HOME" ]; then
XDG_CACHE_HOME="$HOME/.cache"
fi
# LOGGING SYSTEM # LOGGING SYSTEM
# ##################################################################### # #####################################################################
# #
@ -54,7 +56,7 @@ on_interrupt() {
if [ -d "$INSTALL_PATH" ]; then if [ -d "$INSTALL_PATH" ]; then
if ask_user "Do you want to ${RED}delete${RESET} a newly created folder?"; then if ask_user "Do you want to ${RED}delete${RESET} a newly created folder?"; then
if rm -rfv "${INSTALL_PATH:?}" 2>> ./install_log.log; then if rm -rfv "${INSTALL_PATH:?}" 2>>./install_log.log; then
exit 0 exit 0
else else
echo -e "$ERORR The last command ended with an error." echo -e "$ERORR The last command ended with an error."
@ -81,15 +83,16 @@ ask_user() {
read -r -p "$(echo -e "${WARNING} $* (yes/no): ")" answer read -r -p "$(echo -e "${WARNING} $* (yes/no): ")" answer
case "$answer" in case "$answer" in
[yY]|[yY][eE][sS]) [yY] | [yY][eE][sS])
return 0 return 0
;; ;;
[nN]|[nN][oO]) [nN] | [nN][oO])
return 1 return 1
;; ;;
*) *)
echo "Invalid input, try again" echo "Invalid input, try again"
;;
esac esac
done done
} }
@ -107,7 +110,7 @@ check_deps() {
missed_packages=() missed_packages=()
for bin in "${!packages[@]}"; do for bin in "${!packages[@]}"; do
if ! command -v "$bin" > /dev/null; then if ! command -v "$bin" >/dev/null; then
missed_packages+=("${packages[$bin]}") missed_packages+=("${packages[$bin]}")
fi fi
done done
@ -168,7 +171,7 @@ is_path_exists() {
echo -e "$WARNING The specified path '${YELLOW}${1}${RESET}' already exists." echo -e "$WARNING The specified path '${YELLOW}${1}${RESET}' already exists."
if ask_user "Do you want to ${RED}delete${RESET} previous installation?"; then if ask_user "Do you want to ${RED}delete${RESET} previous installation?"; then
if rm -rfv "${1:?}" 2>> ./install_log.log; then if rm -rfv "${1:?}" 2>>./install_log.log; then
echo -e "$LOG Deleted old installation." echo -e "$LOG Deleted old installation."
else else
echo -e "$ERROR Something went wrong." echo -e "$ERROR Something went wrong."
@ -186,11 +189,11 @@ setup_wine() {
local vc_libraries=("vcrun2003" "vcrun2005" "vcrun2010" "vcrun2012" "vcrun2013" "vcrun2022") local vc_libraries=("vcrun2003" "vcrun2005" "vcrun2010" "vcrun2012" "vcrun2013" "vcrun2022")
echo -e "$LOG Setting up wine prefix." echo -e "$LOG Setting up wine prefix."
winecfg /v win10 2> /dev/null winecfg /v win10 2>/dev/null
echo -e "$LOG Downloading and installing core components for wine prefix. This could take some time." echo -e "$LOG Downloading and installing core components for wine prefix. This could take some time."
if ! winetricks --unattended corefonts win10 vkd3d dxvk2030 msxml3 msxml6 gdiplus &> ./install_log.log; then if ! winetricks --unattended corefonts win10 vkd3d dxvk2030 msxml3 msxml6 gdiplus &>./install_log.log; then
echo -e "$ERORR Winetricks terminated with an error." echo -e "$ERORR Winetricks terminated with an error."
echo -e "$ERROR Please open an issue by mentioning the contents of ${YELLOW}./install_log.log${RESET}." echo -e "$ERROR Please open an issue by mentioning the contents of ${YELLOW}./install_log.log${RESET}."
exit 1 exit 1
@ -200,10 +203,10 @@ setup_wine() {
echo "---------------------------------------------------------------------" echo "---------------------------------------------------------------------"
echo " Downloading Visual C++ Libraries " echo " Downloading Visual C++ Libraries "
echo "---------------------------------------------------------------------" echo "---------------------------------------------------------------------"
} >> ./install_log.log # Thanks to Katy248 for the idea. } >>./install_log.log # Thanks to Katy248 for the idea.
echo -e "$LOG Downloading and installing Visual C++ libraries." echo -e "$LOG Downloading and installing Visual C++ libraries."
if ! winetricks --unattended "${vc_libraries[@]}" &>> ./install_log.log; then if ! winetricks --unattended "${vc_libraries[@]}" &>>./install_log.log; then
echo -e "$ERROR Winetricks terminated with an error. Please, refer to ${YELLOW}install_log.log${RESET} for more info." echo -e "$ERROR Winetricks terminated with an error. Please, refer to ${YELLOW}install_log.log${RESET} for more info."
echo -e "$ERROR If you can't solve the issue yourself, please, open an issue on the GitHub." echo -e "$ERROR If you can't solve the issue yourself, please, open an issue on the GitHub."
exit 1 exit 1
@ -224,7 +227,7 @@ download_photoshop() {
if [[ "$CHECKSUM" != "$local_checksum" ]]; then if [[ "$CHECKSUM" != "$local_checksum" ]]; then
echo -e "$LOG Checksums don't match!" echo -e "$LOG Checksums don't match!"
echo -e "$LOG Deleting corrupted archive." echo -e "$LOG Deleting corrupted archive."
rm -v "${archive_name:?}" &>> ./install_log.log rm -v "${archive_name:?}" &>>./install_log.log
fi fi
return 0 return 0
@ -302,7 +305,7 @@ install_photoshop() {
local filename="Photoshop.tar.xz" local filename="Photoshop.tar.xz"
echo -e "$LOG Extracting Photoshop." echo -e "$LOG Extracting Photoshop."
if ! tar xvf "$filename" &>> ./install_log.log; then if ! tar xvf "$filename" &>>./install_log.log; then
echo -e "$ERORR An error occurred while unpacking the archive." echo -e "$ERORR An error occurred while unpacking the archive."
exit 1 exit 1
# TODO: # TODO:
@ -343,7 +346,7 @@ install_photoshop() {
fi fi
echo -e "$LOG Extracting Photoshop." echo -e "$LOG Extracting Photoshop."
if ! tar xvf "$LOCAL_ARCHIVE" &>> ./install_log.log; then if ! tar xvf "$LOCAL_ARCHIVE" &>>./install_log.log; then
echo -e "$ERROR An error occurred while unpacking the archive." echo -e "$ERROR An error occurred while unpacking the archive."
exit 1 exit 1
# TODO: # TODO:
@ -366,11 +369,11 @@ install_photoshop() {
install_icon() { install_icon() {
# Papirus Icon Theme already has a Photoshop icon in it. # Papirus Icon Theme already has a Photoshop icon in it.
# The script will check if you have Papirus installed and use its icon. If Papirus is not installed, the script will download the icon from the Internet and use it. # The script will check if you have Papirus installed and use its icon. If Papirus is not installed, the script will download the icon from the Internet and use it.
if find /usr/share/icons -name "Papirus*" &> /dev/null; then if find /usr/share/icons -name "Papirus*" &>/dev/null; then
ICON="photoshop" ICON="photoshop"
else else
if [ -d "$XDG_DATA_HOME/icons" ]; then if [ -d "$XDG_DATA_HOME/icons" ]; then
if find "$XDG_DATA_HOME/icons" -name "Papirus*" &> /dev/null; then if find "$XDG_DATA_HOME/icons" -name "Papirus*" &>/dev/null; then
ICON="photoshop" ICON="photoshop"
fi fi
else else
@ -380,7 +383,7 @@ install_icon() {
if [ -z "$ICON" ]; then if [ -z "$ICON" ]; then
local icon_url="https://cdn3d.iconscout.com/3d/premium/thumb/adobe-photoshop-file-3d-icon-download-in-png-blend-fbx-gltf-formats--logo-format-graphic-design-pack-development-icons-9831950.png" local icon_url="https://cdn3d.iconscout.com/3d/premium/thumb/adobe-photoshop-file-3d-icon-download-in-png-blend-fbx-gltf-formats--logo-format-graphic-design-pack-development-icons-9831950.png"
if ! curl "$icon_url" -o "icon.webp" &>> ./install_log.log; then if ! curl "$icon_url" -o "icon.webp" &>>./install_log.log; then
echo -e "$ERROR Failed to download icon. Please refer ${YELLOW}install_log.log${RESET} for info." echo -e "$ERROR Failed to download icon. Please refer ${YELLOW}install_log.log${RESET} for info."
exit 1 exit 1
fi fi
@ -403,15 +406,15 @@ install_desktop_entry() {
echo -e "$LOG Genarating application menu item." echo -e "$LOG Genarating application menu item."
echo "[Desktop Entry]" > "$path" echo "[Desktop Entry]" >"$path"
echo "Name=Adobe Photoshop CC 2021" >> "$path" echo "Name=Adobe Photoshop CC 2021" >>"$path"
echo "Exec=bash -c "$HOME/.local/bin/photoshop/photoshop.sh %F"" >> "$path" echo "Exec=bash -c "$HOME/.local/bin/photoshop/photoshop.sh %F"" >>"$path"
echo "Type=Application" >> "$path" echo "Type=Application" >>"$path"
echo "Comment=The industry-standard photo editing software (Wine" >> "$path" echo "Comment=The industry-standard photo editing software (Wine" >>"$path"
echo "Categories=Graphics" >> "$path" echo "Categories=Graphics" >>"$path"
echo "Icon=$ICON" >> "$path" echo "Icon=$ICON" >>"$path"
echo "MimeType=image/psd;image/x-psd;image/png;image/jpg;image/jpeg;image/webp;image/heif;image/raw" >> "$path" echo "MimeType=image/psd;image/x-psd;image/png;image/jpg;image/jpeg;image/webp;image/heif;image/raw" >>"$path"
echo "StartupWMClass=photoshop.exe" >> "$path" echo "StartupWMClass=photoshop.exe" >>"$path"
} }
install_launcher() { install_launcher() {
@ -423,14 +426,14 @@ install_launcher() {
echo "#!/usr/bin/env bash" echo "#!/usr/bin/env bash"
echo "" echo ""
echo "export WINEPREFIX=\"$WINEPREFIX\"" echo "export WINEPREFIX=\"$WINEPREFIX\""
echo "LOG_FILE=\"\$XDG_CACHE_HOME/photoshop.log\"" echo "LOG_FILE=\"$XDG_CACHE_HOME/photoshop.log\""
echo "DXVK_LOG_PATH=\"\$WINEPREFIX/dxvk_cache\"" echo "DXVK_LOG_PATH=\"\$WINEPREFIX/dxvk_cache\""
echo "DXVK_STATE_CACHE_PATH=\"\$WINEPREFIX/dxvk_cache\"" echo "DXVK_STATE_CACHE_PATH=\"\$WINEPREFIX/dxvk_cache\""
echo "PHOTOSHOP=\"\$WINEPREFIX/drive_c/Program Files/Adobe Photoshop 2021/photoshop.exe\"" echo "PHOTOSHOP=\"\$WINEPREFIX/drive_c/Program Files/Adobe Photoshop 2021/photoshop.exe\""
echo "" echo ""
echo "echo -e \"All logs are saved in \$LOG_FILE\"" echo "echo -e \"All logs are saved in \$LOG_FILE\""
echo "wine64 \"\$PHOTOSHOP\" \"\$@\" &> \"\$LOG_FILE\" " echo "wine64 \"\$PHOTOSHOP\" \"\$@\" &> \"\$LOG_FILE\" "
} > "$LAUNCHER" } >"$LAUNCHER"
chmod +x "$LAUNCHER" chmod +x "$LAUNCHER"
} }
@ -477,6 +480,7 @@ while getopts "a:i:h" flag; do
\?) \?)
echo "Invalid option: -$OPTARG Use -h for help." echo "Invalid option: -$OPTARG Use -h for help."
exit 1 exit 1
;;
esac esac
done done