mirror of
https://github.com/hermensbas/azerothcore_installer.git
synced 2026-01-13 00:28:33 +00:00
73 lines
2.9 KiB
Bash
Executable File
73 lines
2.9 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
#./script.sh # normal mode
|
|
#./script.sh debug # debug mode (GDB, timestamped crash logs)
|
|
|
|
##########################################################################################
|
|
# Toggle debug mode
|
|
##########################################################################################
|
|
DEBUG_MODE=0
|
|
if [[ "$1" == "debug" ]]; then
|
|
DEBUG_MODE=1
|
|
fi
|
|
|
|
##########################################################################################
|
|
# Paths for logs and crash dumps
|
|
##########################################################################################
|
|
export LOGS_PATH="/tmp/ac/logs"
|
|
export CRASHES_PATH="/tmp/ac/crashes"
|
|
|
|
# Ensure directories exist
|
|
mkdir -p "$LOGS_PATH" "$CRASHES_PATH"
|
|
|
|
##########################################################################################
|
|
# Helper: start tmux session and run command
|
|
##########################################################################################
|
|
start_tmux_session() {
|
|
local session_name=$1
|
|
local command=$2
|
|
local log_file=$3
|
|
local debug=$4
|
|
|
|
# Create session if it doesn't exist
|
|
if tmux has-session -t "$session_name" 2>/dev/null; then
|
|
echo "Tmux session '$session_name' already exists, attaching command..."
|
|
else
|
|
if tmux new-session -d -s "$session_name"; then
|
|
echo "Created tmux session: $session_name"
|
|
else
|
|
echo "Error creating tmux session: $session_name"
|
|
return 1
|
|
fi
|
|
fi
|
|
|
|
# Export environment variables inside tmux
|
|
tmux send-keys -t "$session_name" "export LOGS_PATH=$LOGS_PATH; export CRASHES_PATH=$CRASHES_PATH" C-m
|
|
|
|
if [[ "$debug" -eq 1 ]]; then
|
|
# Timestamped GDB log
|
|
local gdb_log="$CRASHES_PATH/${session_name}_gdb_$(date +%Y%m%d_%H%M%S).log"
|
|
tmux send-keys -t "$session_name" "gdb -ex 'set logging file $gdb_log' -ex 'set logging enabled on' -ex 'run' -ex 'bt full' -ex 'quit' --args $command" C-m
|
|
echo "Debug mode enabled for $session_name, logging to $gdb_log"
|
|
else
|
|
# Normal mode: append output to log
|
|
tmux send-keys -t "$session_name" "$command | tee -a $log_file" C-m
|
|
echo "Executed '$command' inside $session_name, logging to $log_file"
|
|
fi
|
|
echo
|
|
}
|
|
|
|
##########################################################################################
|
|
# Start servers
|
|
##########################################################################################
|
|
# Authserver (no debug)
|
|
start_tmux_session "$AUTHSERVER_SESSION" "${SERVER_ROOT}/acore.sh run-authserver" "$LOGS_PATH/authserver.log" 0
|
|
|
|
# Worldserver (toggle debug)
|
|
start_tmux_session "$WORLDSERVER_SESSION" "${SERVER_ROOT}/acore.sh run-worldserver" "$LOGS_PATH/worldserver.log" $DEBUG_MODE
|
|
|
|
##########################################################################################
|
|
# Launch interactive menu if needed
|
|
##########################################################################################
|
|
source "${ROOT_DIR}/script/menu.sh"
|