forked from nalc/nalc-server
Rewrite install script
This commit is contained in:
parent
193d900a7b
commit
e86048fce9
|
@ -1,2 +1,4 @@
|
|||
nalc_lib
|
||||
default
|
||||
cherry_tree?
|
||||
moretrees?
|
||||
|
|
|
@ -12,7 +12,7 @@
|
|||
minetest.unregister_item("default:axe_wood")
|
||||
minetest.unregister_item("default:pick_wood")
|
||||
|
||||
-- Suppression du groupe oddly_breakable_by_hand pour les nodes en bois du mod default
|
||||
-- Suppression du groupe oddly_breakable_by_hand pour les nodes en bois
|
||||
local wood_nodes = {}
|
||||
wood_nodes["default"] = {
|
||||
"tree", "pine_tree", "jungletree", "acacia_tree", "aspen_tree",
|
||||
|
@ -20,6 +20,25 @@ wood_nodes["default"] = {
|
|||
"wood", "pine_wood", "junglewood", "acacia_wood", "aspen_wood",
|
||||
}
|
||||
|
||||
if minetest.get_modpath("cherry_tree") then
|
||||
wood_nodes["cherry_tree"] = {"cherry_tree", "cherry_plank"}
|
||||
end
|
||||
|
||||
if minetest.get_modpath("moretrees") and moretrees then
|
||||
wood_nodes["moretrees"] = {}
|
||||
local treelist = moretrees.treelist
|
||||
local j = 1
|
||||
for i in ipairs(treelist) do
|
||||
if treelist[i][1] ~= "poplar_small" then
|
||||
wood_nodes["moretrees"][j] = treelist[i][1].."_trunk"
|
||||
wood_nodes["moretrees"][j+1] = treelist[i][1].."_planks"
|
||||
j = j+2
|
||||
end
|
||||
end
|
||||
-- rubber_tree_trunk_empty
|
||||
wood_nodes["moretrees"][#wood_nodes["moretrees"]+1] = "rubber_tree_trunk_empty"
|
||||
end
|
||||
|
||||
for mod, nodes in pairs(wood_nodes) do
|
||||
for _,name in ipairs(nodes) do
|
||||
nalc.not_hand_breakable(mod..":"..name)
|
||||
|
|
142
install.sh
142
install.sh
|
@ -73,16 +73,17 @@ install_minetest() {
|
|||
echo "Attention ! Cela va supprimer définitivement toutes les données."
|
||||
read -p "Êtes-vous certains de vouloir continuer ? (y or n) : " continue
|
||||
if [[ $continue == "y" ]]; then
|
||||
echo "rm -rf minetest"
|
||||
rm -rf minetest
|
||||
echo "Répertoire minetest supprimé."
|
||||
else
|
||||
echo "Installation annulée. Fin"
|
||||
exit 0
|
||||
fi
|
||||
elif [[ $continue == "y" ]]; then
|
||||
echo "cd minetest"
|
||||
echo "git pull"
|
||||
echo "cd .."
|
||||
cd minetest
|
||||
git pull
|
||||
verif
|
||||
cd ..
|
||||
elif [[ $continue == "cancel" ]]; then
|
||||
echo "Installation annulée. Fin"
|
||||
exit 0
|
||||
|
@ -90,23 +91,140 @@ install_minetest() {
|
|||
fi
|
||||
|
||||
if [[ ! -d minetest ]]; then
|
||||
echo "git clone $URL/minetest.git"
|
||||
git clone $URL/minetest.git
|
||||
verif
|
||||
fi
|
||||
|
||||
echo "Minetest va être recompilé..."
|
||||
sleep 3
|
||||
echo "cd minetest"
|
||||
echo "cmake ."
|
||||
echo "make -j$makeopt"
|
||||
cd minetest
|
||||
cmake . -DRUN_IN_PLACE=true -DGETTEXT=true
|
||||
make -j$makeopt
|
||||
echo "Installation de Minetest terminé."
|
||||
echo "cd .."
|
||||
cd ..
|
||||
}
|
||||
|
||||
install_minetest_game() {
|
||||
if [[ -d minetest/games/minetest_game ]]; then
|
||||
if [[ -d minetest_game ]]; then
|
||||
echo "Installation précédente du jeux Minetest détecté."
|
||||
read -p "Mettre à jour ? (y,n,clean,cancel)" continue
|
||||
read -p "Mettre à jour ? (y,n,clean,cancel) " continue
|
||||
if [[ $continue == "y" ]]; then
|
||||
cd minetest_game
|
||||
git pull
|
||||
verif
|
||||
cd ..
|
||||
echo "Mise à jour du jeux Minetest depuis dépôt distant terminé."
|
||||
elif [[ $continue == "clean" ]]; then
|
||||
echo "/!\ Cette action va effacer les données du répertoire minetest_game"
|
||||
read -p "Êtes-vous sûr de vouloir continuer ? (y or n) " continue
|
||||
if [[ $continue == "y" ]]; then
|
||||
rm -rf minetest_game
|
||||
echo "Jeux Minetest supprimé."
|
||||
else
|
||||
echo "Mise à jour annulée. Terminé."
|
||||
exit 0
|
||||
fi
|
||||
elif [[ $continue == "cancel" ]]; then
|
||||
echo "Mise à jour annulée. Terminé."
|
||||
exit 0
|
||||
fi
|
||||
fi
|
||||
|
||||
if [[ ! -d minetest_game ]]; then
|
||||
git clone $URL/minetest_game.git
|
||||
verif
|
||||
echo "Clonage de minetest_game terminé."
|
||||
fi
|
||||
|
||||
if [[ ! -a minetest/games/minetest_game ]]; then
|
||||
ln -s $(pwd)/minetest_game minetest/games/minetest_game
|
||||
echo "Lien symbolique minetest/games/minetest_game vers $(pwd)/minetest_game créé."
|
||||
fi
|
||||
|
||||
echo "Installation/Mise à jour du jeux Minetest terminé."
|
||||
}
|
||||
|
||||
install_world() {
|
||||
if [[ -d minetest/worlds/nalc ]]; then
|
||||
echo "Une map est déjà présente. Que souhaitez-vous faire ?"
|
||||
read -p "Choisissez parmi la liste ([1]Nouveau, [2]Utiliser) : " continuer
|
||||
if [[ $continuer == 1 ]]; then
|
||||
if [[ -d minetest/worlds/nalc_old ]]; then
|
||||
rm -rf minetest/worlds/nalc_old
|
||||
fi
|
||||
|
||||
mv minetest/worlds/nalc minetest/worlds/nalc_old
|
||||
fi
|
||||
fi
|
||||
|
||||
if [[ ! -d minetest/worlds/nalc ]]; then
|
||||
mkdir -p minetest/worlds/nalc
|
||||
ln -s $(pwd)/world.mt minetest/worlds/nalc/world.mt
|
||||
fi
|
||||
}
|
||||
|
||||
install_mods() {
|
||||
if [[ -d nalc-server-mods ]]; then
|
||||
echo "Le dossier de mods est déjà présent. Que souhaitez-vous faire ?"
|
||||
read -p "Choisissez parmi la liste, ([1]update, [2]clean, [3]cancel, [4]Ne rien faire) : " continue
|
||||
if [[ $continue == 1 ]]; then
|
||||
cd nalc-server-mods
|
||||
git pull
|
||||
verif
|
||||
git submodule update --remote --recursive
|
||||
verif
|
||||
cd ..
|
||||
elif [[ $continue == 2 ]]; then
|
||||
rm -rf nalc-server-mods
|
||||
elif [[ $continue == 3 ]]; then
|
||||
echo "Mise à jour des mods annulé. Terminé."
|
||||
exit 0
|
||||
fi
|
||||
fi
|
||||
|
||||
if [[ ! -d nalc-server-mods ]]; then
|
||||
git clone $URL/nalc-server-mods.git
|
||||
verif
|
||||
cd nalc-server-mods
|
||||
git submodule update --init --recursive
|
||||
cd ..
|
||||
fi
|
||||
|
||||
# Recréation des liens symboliques et du fichier world.mt (dans tous les cas)
|
||||
rm minetest/mods/*
|
||||
|
||||
if [[ -a world.mt ]]; then
|
||||
rm world.mt
|
||||
fi
|
||||
|
||||
cp worldmt.conf world.mt
|
||||
|
||||
if [[ -d custom/mods ]]; then
|
||||
ls custom/mods | while read -r mod; do
|
||||
if [[ -d custom/mods/$mod ]]; then
|
||||
rm nalc-server-mods/$mod
|
||||
ln -s $(pwd)/custom/mods/$mod nalc-server-mods/$mod
|
||||
fi
|
||||
done
|
||||
fi
|
||||
|
||||
ls nalc-server-mods | while read -r mod; do
|
||||
if [[ -d nalc-server-mods/$mod ]]; then
|
||||
ln -s $(pwd)/nalc-server-mods/$mod minetest/mods/$mod
|
||||
|
||||
if [[ -a nalc-server-mods/$mod/modpack.txt ]]; then
|
||||
ls nalc-server-mods/$mod | while read -r submod; do
|
||||
if [[ -d nalc-server-mods/$mod/$submod ]]; then
|
||||
echo "load_mod_$submod = true" >> world.mt
|
||||
fi
|
||||
done
|
||||
else
|
||||
echo "load_mod_$mod = true" >> world.mt
|
||||
fi
|
||||
fi
|
||||
done
|
||||
|
||||
echo "Liens des mods créés dans minetest/mods/"
|
||||
}
|
||||
|
||||
init() {
|
||||
|
@ -123,7 +241,7 @@ init() {
|
|||
install_minetest
|
||||
install_minetest_game
|
||||
install_mods
|
||||
post_configuration
|
||||
install_world
|
||||
|
||||
echo "L'installation est terminé. Bravo !"
|
||||
else
|
||||
|
|
Loading…
Reference in New Issue
Block a user