X-Git-Url: https://harrygodden.com/git/?a=blobdiff_plain;f=build.sh;h=328e432a9bf367015e515dff195d6099ced08971;hb=7838efe822ca9336a69936004dd6d9bed70910fb;hp=e078ea626139a4a35881b860da40cc2a83d316b2;hpb=684ee6fcb34db7c58a7e845d33a19d8fb0cccfd3;p=fishladder.git diff --git a/build.sh b/build.sh index e078ea6..328e432 100755 --- a/build.sh +++ b/build.sh @@ -3,11 +3,20 @@ src="fishladder.c" target="fishladder" lib="-I. -L./lib -L./" -libs="-lGL -lglfw -lX11 -lXxf86vm -lXrandr -lm -lpthread -lXi -ldl -l:steam/libsteam_api.so" -flags="-fsanitize=address -ggdb3 -Wno-unused-function" +libs="-lGL -lglfw -lX11 -lXxf86vm -lXrandr -lm -lpthread -lXi -ldl" # -l:steam/libsteam_api.so" +flags="-fsanitize=address -ggdb3 -Wno-unused-function -DNO_STEAM" + +if [[ "$OSTYPE" != "linux-gnu"* ]]; then + echo "Operating system is not GNU/Linux, windows will be assumed." + target="fishladder.exe" + libs="-lglfw3 -lopengl32 -lm -mwindows" + flags="-ggdb3 -Wno-unused-function -DNO_STEAM" +fi run_after=false do_build=true +compile_tools=false +compile_models=false while (( "$#" )); do case $1 in @@ -23,6 +32,14 @@ while (( "$#" )); do do_build=false echo "no-build" ;; + -t|--tools) + compile_tools=true + echo "build-tools" + ;; + -m|--models) + compile_models=true + echo "build-models" + ;; *) echo "Unkown param: $1" exit 1 @@ -31,6 +48,23 @@ while (( "$#" )); do shift done +# Tools +if [ "$compile_tools" = true ]; then + echo "Building tools" + mkdir tools -p + gcc -Wall -Wstrict-aliasing=3 $lib $flags mdlcomp.c gl/glad.c -o tools/mdlcomp $libs -Wl,-rpath=./ $defines + gcc -Wall -Wstrict-aliasing=3 $lib $flags fontcomp.c gl/glad.c -o tools/fontcomp $libs -Wl,-rpath=./ $defines +fi + +# Resources +if [ "$compile_models" = true ]; then + echo "Recompiling models" + for f in models/*.obj; + do echo "Compiling $f.."; + ./tools/mdlcomp $f $f.h + done +fi + # Main build if [ "$do_build" = true ]; then gcc -Wall -Wstrict-aliasing=3 $lib $flags $src gl/glad.c -o $target $libs -Wl,-rpath=./ $defines @@ -43,18 +77,43 @@ if [ "$do_build" = true ]; then echo "Build succeeded" fi -# Directories to initialize -mkdir build.linux/cfg -p -mkdir build.linux/textures -p +if [[ "$OSTYPE" == "linux-gnu"* ]]; then + # Directories to initialize + mkdir build.linux/cfg -p + mkdir build.linux/textures -p + mkdir build.linux/sound -p + mkdir build.linux/maps -p -cp $target ./build.linux/$target -cp ./steam/libsteam_api.so ./build.linux/libsteam_api.so -cp -r ./textures/ ./build.linux/ + cp $target ./build.linux/$target + cp ./steam/libsteam_api.so ./build.linux/libsteam_api.so + cp -r ./textures/ ./build.linux/ + cp -r ./sound/ ./build.linux/ + cp -r ./maps/ ./build.linux/ -if [ "$run_after" = true ]; then - echo "Playing" + if [ "$run_after" = true ]; then + echo "Playing" - cd ./build.linux/ - ./$target - cd ./../ + cd ./build.linux/ + ./$target + cd ./../ + fi +else + mkdir build.win32/cfg -p + mkdir build.win32/textures -p + mkdir build.win32/sound -p + mkdir build.win32/maps -p + + cp $target ./build.win32/$target + cp -r ./textures/ ./build.win32/ + cp -r ./sound/ ./build.win32/ + cp -r ./maps/ ./build.win32/ + cp ./lib/glfw3.dll ./build.win32/glfw3.dll + + if [ "$run_after" = true ]; then + echo "Playing" + + cd ./build.win32/ + ./$target + cd ./../ + fi fi