Enhance chipper script: add run directory management and role-based execution; update options for multiplayer warnings
This commit is contained in:
parent
6b7dd9f96a
commit
0d5bc6a5bf
4
.gitignore
vendored
4
.gitignore
vendored
@ -35,4 +35,6 @@ loom-cache/
|
|||||||
*.bak
|
*.bak
|
||||||
|
|
||||||
__pycache__/
|
__pycache__/
|
||||||
*.pyc
|
*.pyc
|
||||||
|
|
||||||
|
run-*/
|
||||||
18
build.gradle
18
build.gradle
@ -25,3 +25,21 @@ java {
|
|||||||
languageVersion = JavaLanguageVersion.of(17)
|
languageVersion = JavaLanguageVersion.of(17)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
loom {
|
||||||
|
runs {
|
||||||
|
server {
|
||||||
|
server()
|
||||||
|
runDir "run-server"
|
||||||
|
}
|
||||||
|
client1 {
|
||||||
|
client()
|
||||||
|
runDir "run-1"
|
||||||
|
}
|
||||||
|
client2 {
|
||||||
|
client()
|
||||||
|
runDir "run-2"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|||||||
261
chipper
261
chipper
@ -1,119 +1,226 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
# Do NOT use `set -e` with Gradle
|
|
||||||
set -u
|
set -u
|
||||||
|
|
||||||
RUN_DIR="run"
|
|
||||||
OPTIONS_SRC="./config/options.txt"
|
|
||||||
OPTIONS_DST="$RUN_DIR/options.txt"
|
|
||||||
|
|
||||||
GRADLE="./gradlew"
|
GRADLE="./gradlew"
|
||||||
GRADLE_FLAGS=(
|
GRADLE_BASE_FLAGS=(
|
||||||
"--console=plain"
|
"--console=plain"
|
||||||
"--configuration-cache"
|
"--no-daemon"
|
||||||
|
"-Dfabric.development=true"
|
||||||
|
"-Dminecraft.api.env=dev"
|
||||||
|
"-Dminecraft.session.disable=true"
|
||||||
)
|
)
|
||||||
|
|
||||||
# ---------- helpers ----------
|
OPTIONS_SRC="./config/options.txt"
|
||||||
|
|
||||||
|
ROLE=""
|
||||||
|
ROLE_INDEX=""
|
||||||
|
PASSTHROUGH=()
|
||||||
|
|
||||||
|
# ---------- utils ----------
|
||||||
|
|
||||||
|
rand() { shuf -i 0-$(($1 - 1)) -n 1; }
|
||||||
|
|
||||||
|
parse_args() {
|
||||||
|
local cleaned=()
|
||||||
|
for ((i=0; i<${#ARGS[@]}; i++)); do
|
||||||
|
case "${ARGS[$i]}" in
|
||||||
|
-s|--server)
|
||||||
|
ROLE="server"
|
||||||
|
;;
|
||||||
|
-p1|--player1)
|
||||||
|
ROLE="client"
|
||||||
|
ROLE_INDEX=1
|
||||||
|
;;
|
||||||
|
-p2|--player2)
|
||||||
|
ROLE="client"
|
||||||
|
ROLE_INDEX=2
|
||||||
|
;;
|
||||||
|
--)
|
||||||
|
PASSTHROUGH=( "${ARGS[@]:$((i+1))}" )
|
||||||
|
break
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
cleaned+=( "${ARGS[$i]}" )
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
ARGS=( "${cleaned[@]}" )
|
||||||
|
}
|
||||||
|
|
||||||
|
# ---------- run-dir helpers ----------
|
||||||
|
|
||||||
|
prepare_run_dir() {
|
||||||
|
local dir="$1"
|
||||||
|
rm -rf "$dir"
|
||||||
|
mkdir -p "$dir"
|
||||||
|
}
|
||||||
|
|
||||||
inject_options() {
|
inject_options() {
|
||||||
|
local dir="$1"
|
||||||
|
|
||||||
|
# options.txt
|
||||||
if [[ -f "$OPTIONS_SRC" ]]; then
|
if [[ -f "$OPTIONS_SRC" ]]; then
|
||||||
echo "[*] Injecting options.txt..."
|
cp "$OPTIONS_SRC" "$dir/options.txt"
|
||||||
cp "$OPTIONS_SRC" "$OPTIONS_DST"
|
fi
|
||||||
else
|
|
||||||
echo "[!] Warning: $OPTIONS_SRC not found, skipping injection"
|
# servers.dat (client server list)
|
||||||
|
if [[ -f "./config/servers.dat" ]]; then
|
||||||
|
cp "./config/servers.dat" "$dir/servers.dat"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
ensure_run_dir() {
|
ensure_server_files() {
|
||||||
if [[ ! -d "$RUN_DIR" ]]; then
|
local dir="$1"
|
||||||
echo "[*] Creating run directory..."
|
|
||||||
mkdir -p "$RUN_DIR"
|
[[ -f "$dir/eula.txt" ]] || echo "eula=true" > "$dir/eula.txt"
|
||||||
|
|
||||||
|
if [[ ! -f "$dir/server.properties" ]]; then
|
||||||
|
cat > "$dir/server.properties" <<EOF
|
||||||
|
online-mode=false
|
||||||
|
server-port=25565
|
||||||
|
level-name=world
|
||||||
|
enable-command-block=true
|
||||||
|
EOF
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
# ---------- actions ----------
|
# ---------- squirrel ----------
|
||||||
|
|
||||||
|
header() {
|
||||||
|
local action="$1"
|
||||||
|
|
||||||
|
local squirrels=(
|
||||||
|
' /\_/\
|
||||||
|
( o.o )
|
||||||
|
> ^ <'
|
||||||
|
|
||||||
|
' /\_/\
|
||||||
|
( -.- )
|
||||||
|
o_(")(")'
|
||||||
|
|
||||||
|
' /\_/\
|
||||||
|
( @.@ )
|
||||||
|
> ~ <'
|
||||||
|
)
|
||||||
|
|
||||||
clean() {
|
|
||||||
clear
|
clear
|
||||||
echo "[*] Running gradle clean..."
|
echo "${squirrels[$(rand ${#squirrels[@]})]}"
|
||||||
$GRADLE clean "${GRADLE_FLAGS[@]}"
|
echo
|
||||||
|
case "$action" in
|
||||||
|
run) echo "🐿️ running chipper" ;;
|
||||||
|
clean) echo "🐿️ cleaning workspace" ;;
|
||||||
|
build) echo "🐿️ building project" ;;
|
||||||
|
tree) echo "🐿️ observing project tree" ;;
|
||||||
|
*) echo "🐿️ thinking..." ;;
|
||||||
|
esac
|
||||||
|
echo
|
||||||
}
|
}
|
||||||
|
|
||||||
build() {
|
# ---------- commands ----------
|
||||||
clear
|
|
||||||
|
|
||||||
ensure_run_dir
|
cmd_run() {
|
||||||
inject_options
|
header run
|
||||||
|
|
||||||
echo "[*] Running client..."
|
case "$ROLE" in
|
||||||
$GRADLE runClient "${GRADLE_FLAGS[@]}"
|
server)
|
||||||
|
run_dir="run-server"
|
||||||
|
prepare_run_dir "$run_dir"
|
||||||
|
inject_options "$run_dir"
|
||||||
|
ensure_server_files "$run_dir"
|
||||||
|
|
||||||
|
echo "🖥️🐿️ starting dedicated server"
|
||||||
|
exec "$GRADLE" runServer "${GRADLE_BASE_FLAGS[@]}" "${PASSTHROUGH[@]}"
|
||||||
|
;;
|
||||||
|
|
||||||
|
client)
|
||||||
|
run_dir="run-$ROLE_INDEX"
|
||||||
|
task="runClient$ROLE_INDEX"
|
||||||
|
prepare_run_dir "$run_dir"
|
||||||
|
inject_options "$run_dir"
|
||||||
|
|
||||||
|
echo "🎮🐿️ starting client $ROLE_INDEX"
|
||||||
|
exec "$GRADLE" "$task" "${GRADLE_BASE_FLAGS[@]}" "${PASSTHROUGH[@]}"
|
||||||
|
;;
|
||||||
|
|
||||||
|
*)
|
||||||
|
echo "❌🐿️ no role selected"
|
||||||
|
echo "👉🐿️ use one of:"
|
||||||
|
echo " --server"
|
||||||
|
echo " --player1"
|
||||||
|
echo " --player2"
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
show_tree() {
|
cmd_clean() {
|
||||||
clear
|
header clean
|
||||||
echo "[*] Project tree (respecting .gitignore):"
|
"$GRADLE" clean "${GRADLE_BASE_FLAGS[@]}" "${PASSTHROUGH[@]}"
|
||||||
|
}
|
||||||
|
|
||||||
|
cmd_build() {
|
||||||
|
header build
|
||||||
|
"$GRADLE" build "${GRADLE_BASE_FLAGS[@]}" "${PASSTHROUGH[@]}"
|
||||||
|
}
|
||||||
|
|
||||||
|
cmd_tree() {
|
||||||
|
header tree
|
||||||
tree --gitignore
|
tree --gitignore
|
||||||
}
|
}
|
||||||
|
|
||||||
ship() {
|
cmd_help() {
|
||||||
clear
|
|
||||||
echo "[*] Building project..."
|
|
||||||
$GRADLE build "${GRADLE_FLAGS[@]}"
|
|
||||||
echo "[+] Build ready to ship."
|
|
||||||
}
|
|
||||||
|
|
||||||
# ---------- help ----------
|
|
||||||
|
|
||||||
help_menu() {
|
|
||||||
cat <<'EOF'
|
cat <<'EOF'
|
||||||
🐿️ S Q U I R R E L B U I L D T O O L 🐿️
|
/\_/\
|
||||||
|
( o.o )
|
||||||
|
> ^ <
|
||||||
|
|
||||||
|
🐿️ C H I P P E R
|
||||||
|
|
||||||
Usage:
|
Usage:
|
||||||
./chipper [option]
|
./chipper run [role] [-- passthrough]
|
||||||
|
|
||||||
Options:
|
Roles:
|
||||||
--clean Run gradle clean
|
-s, --server Start ONLY server
|
||||||
--build Run client (fast path)
|
-p1, --player1 Start ONLY client 1
|
||||||
--tree Show project tree only
|
-p2, --player2 Start ONLY client 2
|
||||||
--ship Build project
|
|
||||||
--help Show this help menu
|
Other commands:
|
||||||
|
clean Gradle clean
|
||||||
|
build Gradle build
|
||||||
|
tree Show project tree
|
||||||
|
help Show this menu
|
||||||
|
|
||||||
|
Examples:
|
||||||
|
./chipper run --server
|
||||||
|
./chipper run --player1
|
||||||
|
./chipper run --player2
|
||||||
|
./chipper run --player1 -- --debug
|
||||||
|
./chipper build
|
||||||
|
./chipper tree
|
||||||
|
|
||||||
Notes:
|
Notes:
|
||||||
- Uses Gradle configuration cache
|
- No legacy player spawning
|
||||||
- Plain console output (no fake progress)
|
- Each role has its own run directory
|
||||||
- Safe to Ctrl+C after EXECUTION starts
|
- options.txt injected per run dir
|
||||||
|
- Everything after `--` is forwarded
|
||||||
The squirrel believes in you.
|
- The squirrel is mandatory
|
||||||
EOF
|
EOF
|
||||||
}
|
}
|
||||||
|
|
||||||
# ---------- argument parsing ----------
|
# ---------- entry ----------
|
||||||
|
|
||||||
if [[ $# -eq 0 ]]; then
|
ARGS=( "$@" )
|
||||||
help_menu
|
parse_args
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
|
|
||||||
case "$1" in
|
case "${ARGS[0]:-help}" in
|
||||||
--clean)
|
run) cmd_run ;;
|
||||||
clean
|
clean) cmd_clean ;;
|
||||||
;;
|
build) cmd_build ;;
|
||||||
--build)
|
tree) cmd_tree ;;
|
||||||
build
|
help|-h) cmd_help ;;
|
||||||
;;
|
|
||||||
--tree)
|
|
||||||
show_tree
|
|
||||||
;;
|
|
||||||
--ship)
|
|
||||||
ship
|
|
||||||
;;
|
|
||||||
--help|-h)
|
|
||||||
help_menu
|
|
||||||
;;
|
|
||||||
*)
|
*)
|
||||||
echo "[!] Unknown option: $1"
|
echo "[!] Unknown command: ${ARGS[0]}"
|
||||||
echo ""
|
cmd_help
|
||||||
help_menu
|
|
||||||
exit 1
|
exit 1
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|||||||
@ -72,8 +72,8 @@ tutorialStep:movement
|
|||||||
mouseWheelSensitivity:1.0
|
mouseWheelSensitivity:1.0
|
||||||
rawMouseInput:true
|
rawMouseInput:true
|
||||||
glDebugVerbosity:1
|
glDebugVerbosity:1
|
||||||
skipMultiplayerWarning:false
|
skipMultiplayerWarning:true
|
||||||
skipRealms32bitWarning:false
|
skipRealms32bitWarning:true
|
||||||
hideMatchedNames:true
|
hideMatchedNames:true
|
||||||
joinedFirstServer:false
|
joinedFirstServer:false
|
||||||
hideBundleTutorial:false
|
hideBundleTutorial:false
|
||||||
|
|||||||
BIN
config/servers.dat
Normal file
BIN
config/servers.dat
Normal file
Binary file not shown.
Loading…
x
Reference in New Issue
Block a user