launcher improvements

+ adds support menu for issue report, documentation, discord
+ Use the GPU choice made earlier to set the correct PyTorch index-url to install XTTS
+ better error handling for linux
This commit is contained in:
deffcolony
2024-01-03 20:35:16 +01:00
parent e537d72579
commit 308b9e3724
4 changed files with 522 additions and 131 deletions

View File

@@ -159,6 +159,7 @@ echo 4. Update
echo 5. Backup
echo 6. Switch branch
echo 7. Toolbox
echo 8. Support
echo 0. Exit
REM Get the current Git branch
@@ -166,7 +167,7 @@ for /f %%i in ('git branch --show-current') do set current_branch=%%i
echo ======== VERSION STATUS =========
echo SillyTavern branch: %cyan_fg_strong%%current_branch%%reset%
echo SillyTavern: %update_status%
echo Launcher: V1.0.2
echo Launcher: V1.0.4
echo =================================
set "choice="
@@ -190,6 +191,8 @@ if "%choice%"=="1" (
call :switchbrance_menu
) else if "%choice%"=="7" (
call :toolbox
) else if "%choice%"=="8" (
call :support
) else if "%choice%"=="0" (
exit
) else (
@@ -1199,3 +1202,45 @@ if /i "%confirmation%"=="Y" (
pause
goto :home
)
REM Support menu - Frontend
:support
title SillyTavern [SUPPORT]
cls
echo %blue_fg_strong%/ Home / Support%reset%
echo -------------------------------------
echo What would you like to do?
echo 1. I want to report a issue
echo 2. Documentation
echo 3. Discord
echo 0. Back to Home
set /p support_choice=Choose Your Destiny:
REM Support menu - Backend
if "%support_choice%"=="1" (
call :issue_report
) else if "%support_choice%"=="2" (
call :documentation
) else if "%support_choice%"=="3" (
call :discord
) else if "%support_choice%"=="0" (
goto :home
) else (
color 6
echo WARNING: Invalid number. Please insert a valid number.
pause
goto :support
)
:issue_report
start "" "https://github.com/SillyTavern/SillyTavern-Launcher/issues/new/choose"
goto :support
:documentation
start "" "https://docs.sillytavern.app/"
goto :support
:discord
start "" "https://discord.gg/sillytavern"
goto :support

View File

@@ -297,14 +297,59 @@ install_nodejs_npm() {
fi
}
# Function to install SillyTavern + Extras
install_st_extras() {
echo -e "\033]0;SillyTavern [INSTALL-ST-EXTRAS]\007"
clear
echo -e "${blue_fg_strong}/ Installer / SillyTavern + Extras${reset}"
echo "---------------------------------------------------------------"
# Ask the user about the GPU
echo -e "What is your GPU?"
echo -e "1. NVIDIA"
echo -e "2. AMD"
echo -e "3. None (CPU-only mode)"
# Get GPU information
gpu_info=""
while IFS= read -r line; do
gpu_info+=" $line"
done < <(lspci | grep VGA | cut -d ':' -f3)
echo ""
echo -e "${blue_bg}╔════ GPU INFO ═════════════════════════════════════════════════════════════╗${reset}"
boxDrawingText "" 75 $blue_bg
boxDrawingText "* ${gpu_info:1}" 75 $blue_bg
boxDrawingText "" 75 $blue_bg
echo -e "${blue_bg}╚═══════════════════════════════════════════════════════════════════════════╝${reset}"
echo ""
# Prompt for GPU choice
read -p "Enter the number corresponding to your GPU: " gpu_choice
# GPU menu - Backend
# Set the GPU choice in an environment variable for choice callback
export GPU_CHOICE=$gpu_choice
# Check the user's response
if [ "$gpu_choice" == "1" ]; then
log_message "INFO" "GPU choice set to NVIDIA"
install_st_extras_pre
elif [ "$gpu_choice" == "2" ]; then
log_message "INFO" "GPU choice set to AMD"
install_st_extras_pre
elif [ "$gpu_choice" == "3" ]; then
log_message "INFO" "Using CPU-only mode"
install_st_extras_pre
else
log_message "ERROR" "${red_fg_strong}Invalid number. Please enter a valid number.${reset}"
read -p "Press Enter to continue..."
install_st_extras
fi
}
# Function to install_st_extras_pre
install_st_extras_pre() {
log_message "INFO" "Installing SillyTavern + Extras..."
echo -e "${cyan_fg_strong}This may take a while. Please be patient.${reset}"
@@ -313,7 +358,6 @@ install_st_extras() {
log_message "INFO" "${green_fg_strong}SillyTavern installed successfully.${reset}"
log_message "INFO" "Installing Extras..."
log_message "INFO" "Cloning SillyTavern-extras repository..."
git clone https://github.com/SillyTavern/SillyTavern-extras.git
@@ -342,6 +386,16 @@ install_st_extras() {
log_message "INFO" "Activating Conda environment extras..."
conda activate extras
# Check if extras activation was successful
if [ $? -eq 0 ]; then
log_message "INFO" "Conda environment extras activated successfully."
else
log_message "ERROR" "${red_fg_strong}Failed to activate Conda environment: extras${reset}"
log_message "INFO" "Press Enter to try again otherwise close the installer and restart."
read -p "Press Enter to try again..."
install_st_extras_pre
fi
log_message "INFO" "Installing Python and Git in the Conda environment..."
conda install python=3.11 git -y
@@ -354,6 +408,15 @@ install_st_extras() {
# Check the user's response
if [[ "$install_xtts_requirements" == "Y" || "$install_xtts_requirements" == "y" ]]; then
install_xtts
else
log_message "INFO" "XTTS installation skipped."
install_st_extras_post
fi
}
# Function to install_xtts
install_xtts() {
log_message "INFO" "Installing XTTS..."
# Activate the Miniconda installation
@@ -368,23 +431,20 @@ install_st_extras() {
log_message "INFO" "Activating Conda environment xtts..."
source activate xtts
# Check if activation was successful
# Check if xtts activation was successful
if [ $? -eq 0 ]; then
log_message "INFO" "Conda environment xtts activated successfully."
else
log_message "ERROR" "Failed to activate Conda environment xtts."
log_message "ERROR" "${red_fg_strong}Failed to activate Conda environment: xtts${reset}"
log_message "INFO" "Press Enter to try again otherwise close the installer and restart."
read -p "Press Enter to try again..."
install_xtts
fi
# Install Python 3.10 in the xtts environment
log_message "INFO" "Installing Python in the Conda environment..."
conda install python=3.10 -y
# Install pip3 requirements
log_message "INFO" "Installing pip3 requirements for xtts..."
pip3 install xtts-api-server
pip3 install pydub
pip3 install torch torchvision torchaudio --index-url https://download.pytorch.org/whl/cu118
# Create folders for xtts
log_message "INFO" "Creating xtts folders..."
mkdir "$PWD/xtts"
@@ -401,10 +461,29 @@ install_st_extras() {
log_message "INFO" "Removing the xtts-api-server directory..."
rm -rf "$PWD/xtts-api-server"
else
log_message "INFO" "XTTS installation skipped."
fi
# Install pip3 requirements
log_message "INFO" "Installing pip3 requirements for xtts..."
pip3 install xtts-api-server
pip3 install pydub
pip3 install stream2sentence
# Use the GPU choice made earlier to set the correct PyTorch index-url
if [ "$GPU_CHOICE" == "1" ]; then
log_message "INFO" "Installing NVIDIA version of PyTorch"
pip3 install torch torchvision torchaudio --index-url https://download.pytorch.org/whl/cu118
install_st_extras_post
elif [ "$GPU_CHOICE" == "2" ]; then
log_message "INFO" "Installing AMD version of PyTorch"
pip3 install torch torchvision torchaudio --index-url https://download.pytorch.org/whl/rocm5.6
install_st_extras_post
elif [ "$GPU_CHOICE" == "3" ]; then
log_message "INFO" "Installing CPU-only version of PyTorch"
pip3 install torch torchvision torchaudio
install_st_extras_post
fi
}
install_st_extras_post() {
# Activate the extras environment
log_message "INFO" "Activating Conda environment extras..."
conda activate extras
@@ -412,46 +491,26 @@ install_st_extras() {
# Navigate to the SillyTavern-extras directory
cd "$PWD/SillyTavern-extras"
# Ask the user about the GPU
echo -e "What is your GPU?"
echo -e "1. NVIDIA"
echo -e "2. AMD"
echo -e "3. None (CPU-only mode)"
# Get GPU information
gpu_info=""
while IFS= read -r line; do
gpu_info+=" $line"
done < <(lspci | grep VGA | cut -d ':' -f3)
echo ""
echo -e "${blue_bg}╔════ GPU INFO ═════════════════════════════════╗${reset}"
echo -e "${blue_bg}║ ║${reset}"
echo -e "${blue_bg}║* ${gpu_info:1}${reset}"
echo -e "${blue_bg}║ ║${reset}"
echo -e "${blue_bg}╚═══════════════════════════════════════════════╝${reset}"
echo ""
# Prompt for GPU choice
read -p "Enter the number corresponding to your GPU: " gpu_choice
# Check the user's response
if [ "$gpu_choice" == "1" ]; then
# Install pip3 requirements
log_message "INFO" "Installing modules from requirements.txt in extras..."
# Use the GPU choice made earlier to install requirements for extras
if [ "$GPU_CHOICE" == "1" ]; then
log_message "INFO" "Installing modules for NVIDIA from requirements.txt in extras"
pip3 install -r requirements.txt
conda install -c conda-forge faiss-gpu -y
elif [ "$gpu_choice" == "2" ]; then
log_message "INFO" "Installing modules from requirements-rocm.txt in extras..."
install_st_extras_post
elif [ "$GPU_CHOICE" == "2" ]; then
log_message "INFO" "Installing modules for AMD from requirements-rocm.txt in extras"
pip3 install -r requirements-rocm.txt
elif [ "$gpu_choice" == "3" ]; then
log_message "INFO" "Installing modules from requirements-silicon.txt in extras..."
install_st_extras_post
elif [ "$GPU_CHOICE" == "3" ]; then
log_message "INFO" "Installing modules for CPU from requirements-silicon.txt in extras"
pip3 install -r requirements-silicon.txt
else
log_message "ERROR" "Invalid GPU choice. Please enter a valid number."
exit 1
install_st_extras_post
fi
# Install Python 3.11 and Git in the extras environment
log_message "INFO" "Installing Python and Git in the Conda environment..."
conda install python=3.11 git -y
log_message "INFO" "Installing pip3 requirements-rvc in extras environment..."
pip3 install -r requirements-rvc.txt
pip3 install tensorboardX
@@ -493,8 +552,6 @@ install_st_extras() {
installer
}
# Function to install SillyTavern
install_sillytavern() {
echo -e "\033]0;SillyTavern [INSTALL-ST]\007"
@@ -546,8 +603,54 @@ install_extras() {
clear
echo -e "${blue_fg_strong}/ Installer / Extras${reset}"
echo "---------------------------------------------------------------"
log_message "INFO" "Installing Extras..."
# Ask the user about the GPU
echo -e "What is your GPU?"
echo -e "1. NVIDIA"
echo -e "2. AMD"
echo -e "3. None (CPU-only mode)"
# Get GPU information
gpu_info=""
while IFS= read -r line; do
gpu_info+=" $line"
done < <(lspci | grep VGA | cut -d ':' -f3)
echo ""
echo -e "${blue_bg}╔════ GPU INFO ═════════════════════════════════════════════════════════════╗${reset}"
boxDrawingText "" 75 $blue_bg
boxDrawingText "* ${gpu_info:1}" 75 $blue_bg
boxDrawingText "" 75 $blue_bg
echo -e "${blue_bg}╚═══════════════════════════════════════════════════════════════════════════╝${reset}"
echo ""
# Prompt for GPU choice
read -p "Enter the number corresponding to your GPU: " gpu_choice
# GPU menu - Backend
# Set the GPU choice in an environment variable for choice callback
export GPU_CHOICE=$gpu_choice
# Check the user's response
if [ "$gpu_choice" == "1" ]; then
log_message "INFO" "GPU choice set to NVIDIA"
install_extras_pre
elif [ "$gpu_choice" == "2" ]; then
log_message "INFO" "GPU choice set to AMD"
install_extras_pre
elif [ "$gpu_choice" == "3" ]; then
log_message "INFO" "Using CPU-only mode"
install_extras_pre
else
log_message "ERROR" "${red_fg_strong}Invalid number. Please enter a valid number.${reset}"
read -p "Press Enter to continue..."
install_extras
fi
}
# Function to install_extras_pre
install_extras_pre() {
log_message "INFO" "Installing Extras..."
log_message "INFO" "Cloning SillyTavern-extras repository..."
git clone https://github.com/SillyTavern/SillyTavern-extras.git
@@ -576,6 +679,16 @@ install_extras() {
log_message "INFO" "Activating Conda environment extras..."
conda activate extras
# Check if extras activation was successful
if [ $? -eq 0 ]; then
log_message "INFO" "Conda environment extras activated successfully."
else
log_message "ERROR" "${red_fg_strong}Failed to activate Conda environment: extras${reset}"
log_message "INFO" "Press Enter to try again otherwise close the installer and restart."
read -p "Press Enter to try again..."
install_extras_pre
fi
log_message "INFO" "Installing Python and Git in the Conda environment..."
conda install python=3.11 git -y
@@ -588,6 +701,15 @@ install_extras() {
# Check the user's response
if [[ "$install_xtts_requirements" == "Y" || "$install_xtts_requirements" == "y" ]]; then
install_xtts
else
log_message "INFO" "XTTS installation skipped."
install_extras_post
fi
}
# Function to install_xtts
install_xtts() {
log_message "INFO" "Installing XTTS..."
# Activate the Miniconda installation
@@ -600,25 +722,22 @@ install_extras() {
# Activate the xtts environment
log_message "INFO" "Activating Conda environment xtts..."
source activate xtts
conda activate xtts
# Check if activation was successful
if [ $? -eq 0 ]; then
log_message "INFO" "Conda environment xtts activated successfully."
else
log_message "ERROR" "Failed to activate Conda environment xtts."
log_message "ERROR" "${red_fg_strong}Failed to activate Conda environment: xtts${reset}"
log_message "INFO" "Press Enter to try again otherwise close the installer and restart."
read -p "Press Enter to try again..."
install_xtts
fi
# Install Python 3.10 in the xtts environment
log_message "INFO" "Installing Python in the Conda environment..."
conda install python=3.10 -y
# Install pip3 requirements
log_message "INFO" "Installing pip3 requirements for xtts..."
pip3 install xtts-api-server
pip3 install pydub
pip3 install torch torchvision torchaudio --index-url https://download.pytorch.org/whl/cu118
# Create folders for xtts
log_message "INFO" "Creating xtts folders..."
mkdir "$PWD/xtts"
@@ -635,10 +754,29 @@ install_extras() {
log_message "INFO" "Removing the xtts-api-server directory..."
rm -rf "$PWD/xtts-api-server"
else
log_message "INFO" "XTTS installation skipped."
fi
# Install pip3 requirements
log_message "INFO" "Installing pip3 requirements for xtts..."
pip3 install xtts-api-server
pip3 install pydub
pip3 install stream2sentence
# Use the GPU choice made earlier to set the correct PyTorch index-url
if [ "$GPU_CHOICE" == "1" ]; then
log_message "INFO" "Installing NVIDIA version of PyTorch"
pip3 install torch torchvision torchaudio --index-url https://download.pytorch.org/whl/cu118
install_extras_post
elif [ "$GPU_CHOICE" == "2" ]; then
log_message "INFO" "Installing AMD version of PyTorch"
pip3 install torch torchvision torchaudio --index-url https://download.pytorch.org/whl/rocm5.6
install_extras_post
elif [ "$GPU_CHOICE" == "3" ]; then
log_message "INFO" "Installing CPU-only version of PyTorch"
pip3 install torch torchvision torchaudio
install_extras_post
fi
}
install_extras_post() {
# Activate the extras environment
log_message "INFO" "Activating Conda environment extras..."
conda activate extras
@@ -646,60 +784,37 @@ install_extras() {
# Navigate to the SillyTavern-extras directory
cd "$PWD/SillyTavern-extras"
# Ask the user about the GPU
echo -e "What is your GPU?"
echo -e "1. NVIDIA"
echo -e "2. AMD"
echo -e "3. None (CPU-only mode)"
# Get GPU information
gpu_info=""
while IFS= read -r line; do
gpu_info+=" $line"
done < <(lspci | grep VGA | cut -d ':' -f3)
echo ""
echo -e "${blue_bg}╔════ GPU INFO ═════════════════════════════════════════════════════════════╗${reset}"
boxDrawingText "" 75 $blue_bg
boxDrawingText "* ${gpu_info:1}" 75 $blue_bg
boxDrawingText "" 75 $blue_bg
echo -e "${blue_bg}╚═══════════════════════════════════════════════════════════════════════════╝${reset}"
echo ""
# Prompt for GPU choice
read -p "Enter the number corresponding to your GPU: " gpu_choice
# Check the user's response
if [ "$gpu_choice" == "1" ]; then
# Install pip3 requirements
log_message "INFO" "Installing modules from requirements.txt in extras..."
# Use the GPU choice made earlier to install requirements for extras
if [ "$GPU_CHOICE" == "1" ]; then
log_message "INFO" "Installing modules for NVIDIA from requirements.txt in extras"
pip3 install -r requirements.txt
conda install -c conda-forge faiss-gpu -y
elif [ "$gpu_choice" == "2" ]; then
log_message "INFO" "Installing modules from requirements-rocm.txt in extras..."
install_extras_post
elif [ "$GPU_CHOICE" == "2" ]; then
log_message "INFO" "Installing modules for AMD from requirements-rocm.txt in extras"
pip3 install -r requirements-rocm.txt
elif [ "$gpu_choice" == "3" ]; then
log_message "INFO" "Installing modules from requirements-silicon.txt in extras..."
install_extras_post
elif [ "$GPU_CHOICE" == "3" ]; then
log_message "INFO" "Installing modules for CPU from requirements-silicon.txt in extras"
pip3 install -r requirements-silicon.txt
else
log_message "ERROR" "Invalid GPU choice. Please enter a valid number."
exit 1
install_extras_post
fi
# Install Python 3.11 and Git in the extras environment
log_message "INFO" "Installing Python and Git in the Conda environment..."
conda install python=3.11 git -y
log_message "INFO" "Installing pip3 requirements-rvc in extras environment..."
pip3 install -r requirements-rvc.txt
pip3 install tensorboardX
# Cleanup the Downloaded file
rm -rf /tmp/$miniconda_installer
log_message "INFO" "${green_fg_strong}Extras has been successfully installed.${reset}"
log_message "INFO" "${green_fg_strong}SillyTavern + Extras successfully installed.${reset}"
installer
}
# Function for the installer menu
installer() {
echo -e "\033]0;SillyTavern [INSTALLER]\007"
@@ -710,7 +825,8 @@ installer() {
echo "1. Install SillyTavern + Extras"
echo "2. Install SillyTavern"
echo "3. Install Extras"
echo "4. Exit"
echo "4. Support"
echo "0. Exit"
read -p "Choose Your Destiny (default is 1): " choice
@@ -719,20 +835,87 @@ installer() {
choice=1
fi
# Installer - Backend
if [ "$choice" = "1" ]; then
install_st_extras
elif [ "$choice" = "2" ]; then
install_sillytavern
elif [ "$choice" = "3" ]; then
install_extras
elif [ "$choice" = "4" ]; then
exit
# Installer Menu - Backend
case $choice in
1) install_st_extras ;;
2) install_sillytavern ;;
3) install_extras ;;
4) support ;;
0) exit ;;
*) echo -e "${yellow_fg_strong}WARNING: Invalid number. Please insert a valid number.${reset}"
read -p "Press Enter to continue..."
installer ;;
esac
}
# Functions for Support Menu - Backend
issue_report() {
if [ "$EUID" -eq 0 ]; then
log_message "ERROR" "${red_fg_strong}Cannot run xdg-open as root. Please run the script without root permission.${reset}"
else
echo -e "${yellow_fg_strong}WARNING: Invalid number. Please insert a valid number.${reset}"
read -p "Press Enter to continue..."
installer
if [ "$(uname -s)" == "Darwin" ]; then
open https://github.com/SillyTavern/SillyTavern-Launcher/issues/new/choose
else
xdg-open https://github.com/SillyTavern/SillyTavern-Launcher/issues/new/choose
fi
fi
read -p "Press Enter to continue..."
support
}
documentation() {
if [ "$EUID" -eq 0 ]; then
log_message "ERROR" "${red_fg_strong}Cannot run xdg-open as root. Please run the script without root permission.${reset}"
else
if [ "$(uname -s)" == "Darwin" ]; then
open https://docs.sillytavern.app/
else
xdg-open https://docs.sillytavern.app/
fi
fi
read -p "Press Enter to continue..."
support
}
discord() {
if [ "$EUID" -eq 0 ]; then
log_message "ERROR" "${red_fg_strong}Cannot run xdg-open as root. Please run the script without root permission.${reset}"
else
if [ "$(uname -s)" == "Darwin" ]; then
open https://discord.gg/sillytavern
else
xdg-open https://discord.gg/sillytavern
fi
fi
read -p "Press Enter to continue..."
support
}
# Support Menu - Frontend
support() {
echo -e "\033]0;SillyTavern [SUPPORT]\007"
clear
echo -e "${blue_fg_strong}/ Home / Support${reset}"
echo "-------------------------------------"
echo "What would you like to do?"
echo "1. I want to report an issue"
echo "2. Documentation"
echo "3. Discord"
echo "0. Back to installer"
read -p "Choose Your Destiny: " support_choice
# Support Menu - Backend
case $support_choice in
1) issue_report ;;
2) documentation ;;
3) discord ;;
0) installer ;;
*) echo -e "${yellow_fg_strong}WARNING: Invalid number. Please insert a valid number.${reset}"
read -p "Press Enter to continue..."
support ;;
esac
}
# Check if the script is running on macOS
@@ -792,4 +975,4 @@ elif command -v zypper &>/dev/null; then
else
log_message "ERROR" "${red_fg_strong}Unsupported package manager. Cannot detect Linux distribution.${reset}"
exit 1
fi
fi

View File

@@ -126,7 +126,7 @@ if exist "%LOCALAPPDATA%\Microsoft\WindowsApps\python3.exe" (
)
REM Installer - Frontend
REM Installer menu - Frontend
:installer
title SillyTavern [INSTALLER]
cls
@@ -136,7 +136,8 @@ echo What would you like to do?
echo 1. Install SillyTavern + Extras
echo 2. Install SillyTavern
echo 3. Install Extras
echo 4. Exit
echo 4. Support
echo 0. Exit
set "choice="
set /p "choice=Choose Your Destiny (default is 1): "
@@ -144,7 +145,7 @@ set /p "choice=Choose Your Destiny (default is 1): "
REM Default to choice 1 if no input is provided
if not defined choice set "choice=1"
REM Installer - Backend
REM Installer menu - Backend
if "%choice%"=="1" (
call :install_st_extras
) else if "%choice%"=="2" (
@@ -152,6 +153,8 @@ if "%choice%"=="1" (
) else if "%choice%"=="3" (
call :install_extras
) else if "%choice%"=="4" (
call :support
) else if "%choice%"=="0" (
exit
) else (
color 6
@@ -167,6 +170,7 @@ cls
echo %blue_fg_strong%/ Installer / SillyTavern + Extras%reset%
echo ---------------------------------------------------------------
REM GPU menu - Frontend
:what_gpu
echo What is your GPU?
echo 1. NVIDIA
@@ -191,6 +195,7 @@ echo.
endlocal
set /p gpu_choice=Enter number corresponding to your GPU:
REM GPU menu - Backend
REM Set the GPU choice in an environment variable for choise callback
set "GPU_CHOICE=%gpu_choice%"
@@ -206,7 +211,7 @@ if "%gpu_choice%"=="1" (
echo %blue_bg%[%time%]%reset% %blue_fg_strong%[INFO]%reset% Using CPU-only mode
goto :install_st_extras_pre
) else (
echo %red_bg%[%time%]%reset% %red_fg_strong%[ERROR]%reset% Invalid GPU choice. Please enter a valid number.
echo %red_bg%[%time%]%reset% %red_fg_strong%[ERROR]%reset% Invalid number. Please enter a valid number.
pause
goto what_gpu
)
@@ -447,6 +452,7 @@ cls
echo %blue_fg_strong%/ Installer / Extras%reset%
echo ---------------------------------------------------------------
REM GPU menu - Frontend
:what_gpu
echo What is your GPU?
echo 1. NVIDIA
@@ -471,6 +477,7 @@ echo.
endlocal
set /p gpu_choice=Enter number corresponding to your GPU:
REM GPU menu - Backend
REM Set the GPU choice in an environment variable for choise callback
set "GPU_CHOICE=%gpu_choice%"
@@ -486,7 +493,7 @@ if "%gpu_choice%"=="1" (
echo %blue_bg%[%time%]%reset% %blue_fg_strong%[INFO]%reset% Using CPU-only mode
goto :install_extras_pre
) else (
echo %red_bg%[%time%]%reset% %red_fg_strong%[ERROR]%reset% Invalid GPU choice. Please enter a valid number.
echo %red_bg%[%time%]%reset% %red_fg_strong%[ERROR]%reset% Invalid number. Please enter a valid number.
pause
goto what_gpu
)
@@ -667,3 +674,45 @@ if /i "%start_launcher%"=="Y" (
exit
)
goto :installer
REM Support menu - Frontend
:support
title SillyTavern [SUPPORT]
cls
echo %blue_fg_strong%/ Installer / Support%reset%
echo -------------------------------------
echo What would you like to do?
echo 1. I want to report a issue
echo 2. Documentation
echo 3. Discord
echo 0. Back to Installer
set /p support_choice=Choose Your Destiny:
REM Support menu - Backend
if "%support_choice%"=="1" (
call :issue_report
) else if "%support_choice%"=="2" (
call :documentation
) else if "%support_choice%"=="3" (
call :discord
) else if "%support_choice%"=="0" (
goto :installer
) else (
color 6
echo WARNING: Invalid number. Please insert a valid number.
pause
goto :support
)
:issue_report
start "" "https://github.com/SillyTavern/SillyTavern-Launcher/issues/new/choose"
goto :support
:documentation
start "" "https://docs.sillytavern.app/"
goto :support
:discord
start "" "https://discord.gg/sillytavern"
goto :support

View File

@@ -153,17 +153,19 @@ home() {
echo "-------------------------------------"
echo "What would you like to do?"
echo "1. Start SillyTavern"
echo "2. Start SillyTavern + Extras"
echo "3. Update"
echo "4. Backup"
echo "5. Switch branch"
echo "6. Toolbox"
echo "2. Start Extras"
echo "3. Start SillyTavern + Extras "
echo "4. Update"
echo "5. Backup"
echo "6. Switch branch"
echo "7. Toolbox"
echo "8. Support"
echo "0. Exit"
echo "======== VERSION STATUS ========"
echo -e "SillyTavern branch: ${cyan_fg_strong}$current_branch${reset}"
echo -e "Sillytavern: $update_status"
echo -e "Launcher: V1.0.2"
echo -e "Launcher: V1.0.4"
echo "================================"
read -p "Choose Your Destiny: " home_choice
@@ -176,11 +178,13 @@ home() {
# Home Menu - Backend
case $home_choice in
1) start_st ;;
2) start_st_extras ;;
3) update ;;
4) backup_menu ;;
5) switch_branch_menu ;;
6) toolbox ;;
2) start_extras ;;
3) start_st_extras ;;
4) update ;;
5) backup_menu ;;
6) switch_branch_menu ;;
7) toolbox ;;
8) support ;;
0) exit ;;
*) echo -e "${yellow_fg_strong}WARNING: Invalid number. Please insert a valid number.${reset}"
read -p "Press Enter to continue..."
@@ -245,6 +249,46 @@ start_st() {
home
}
# Function to start SillyTavern with Extras
start_extras() {
check_nodejs
if [ "$LAUNCH_NEW_WIN" = "0" ]; then
local main_pid=$!
log_message "INFO" "Extras launched under pid $main_pid"
{
#has to be after the first one, so we are 1 directory up
cd "$(dirname "$0")./SillyTavern-extras" || {
log_message "ERROR" "SillyTavern-extras directory not found. Please make sure you have installed SillyTavern-extras."
kill $main_pid
exit 1
}
log_message "INFO" "Wordking dir: $(pwd)"
./start.sh
} &
local extras_pid=$!
log_message "INFO" "Extras launched under pid $extras_pid"
wait $main_pid
kill $extras_pid
else
log_message "INFO" "Extras launched in a new window."
# Find a suitable terminal
local detected_terminal
detected_terminal=$(find_terminal)
log_message "INFO" "Found terminal: $detected_terminal"
# Enable read p command for troubleshooting
# read -p "Press Enter to continue..."
# Start SillyTavern in the detected terminal
if [ "$(uname)" == "Darwin" ]; then
log_message "INFO" "Detected macOS. Opening new Terminal window."
open -a Terminal "$(dirname "$0")/SillyTavern-extras/start.sh"
else
exec "$detected_terminal" -e "cd $(dirname "$0")./SillyTavern-extras && ./start.sh" &
fi
fi
home
}
# Function to start SillyTavern with Extras
start_st_extras() {
check_nodejs
@@ -789,6 +833,76 @@ toolbox() {
esac
}
# Functions for Support Menu - Backend
issue_report() {
if [ "$EUID" -eq 0 ]; then
log_message "ERROR" "${red_fg_strong}Cannot run xdg-open as root. Please run the script without root permission.${reset}"
else
if [ "$(uname -s)" == "Darwin" ]; then
open https://github.com/SillyTavern/SillyTavern-Launcher/issues/new/choose
else
xdg-open https://github.com/SillyTavern/SillyTavern-Launcher/issues/new/choose
fi
fi
read -p "Press Enter to continue..."
support
}
documentation() {
if [ "$EUID" -eq 0 ]; then
log_message "ERROR" "${red_fg_strong}Cannot run xdg-open as root. Please run the script without root permission.${reset}"
else
if [ "$(uname -s)" == "Darwin" ]; then
open https://docs.sillytavern.app/
else
xdg-open https://docs.sillytavern.app/
fi
fi
read -p "Press Enter to continue..."
support
}
discord() {
if [ "$EUID" -eq 0 ]; then
log_message "ERROR" "${red_fg_strong}Cannot run xdg-open as root. Please run the script without root permission.${reset}"
else
if [ "$(uname -s)" == "Darwin" ]; then
open https://discord.gg/sillytavern
else
xdg-open https://discord.gg/sillytavern
fi
fi
read -p "Press Enter to continue..."
support
}
# Support Menu - Frontend
support() {
echo -e "\033]0;SillyTavern [SUPPORT]\007"
clear
echo -e "${blue_fg_strong}/ Home / Support${reset}"
echo "-------------------------------------"
echo "What would you like to do?"
echo "1. I want to report an issue"
echo "2. Documentation"
echo "3. Discord"
echo "0. Back to installer"
read -p "Choose Your Destiny: " support_choice
# Support Menu - Backend
case $support_choice in
1) issue_report ;;
2) documentation ;;
3) discord ;;
0) installer ;;
*) echo -e "${yellow_fg_strong}WARNING: Invalid number. Please insert a valid number.${reset}"
read -p "Press Enter to continue..."
support ;;
esac
}
# Check if the script is running on macOS
if [ "$(uname)" == "Darwin" ]; then
IS_MACOS="1"