From ccc30fd28cb3e65195a6cea06ca00f95e16ac9f8 Mon Sep 17 00:00:00 2001 From: Mike Buland Date: Mon, 28 Dec 2009 22:25:06 +0000 Subject: Added build.sh, it can build build when no libbu++ is present by downloading what it needs, and it'll build a static version of build no problem. Semi-static, it won't build any plugins or link against a shared libbu++, system stuff may still be dynamic. It can also clean up behind itself. --- build.sh | 68 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 68 insertions(+) create mode 100755 build.sh diff --git a/build.sh b/build.sh new file mode 100755 index 0000000..dd7e45b --- /dev/null +++ b/build.sh @@ -0,0 +1,68 @@ +#!/bin/bash + +BUSRC="stack.cpp fstring.cpp fbasicstring.cpp hash.cpp list.cpp trace.cpp stream.cpp formatter.cpp util.cpp sharedcore.cpp exceptionbase.cpp heap.cpp archivebase.cpp archive.cpp queue.cpp archival.cpp sio.cpp stdstream.cpp process.cpp plugger.cpp optparser.cpp signals.cpp array.cpp membuf.cpp" +BUHDR="stack.h fstring.h fbasicstring.h hash.h list.h trace.h stream.h formatter.h util.h sharedcore.h exceptionbase.h heap.h archivebase.h archive.h queue.h archival.h sio.h stdstream.h process.h osx_compatibility.h win32_compatibility.h linux_compatibility.h plugger.h singleton.h optparser.h signals.h array.h membuf.h" + +function bld() +{ + OUTFILE="$1" + if [ ! -e "$OUTFILE" ]; then + return 1 + fi + shift + for INFILE in $*; do + if [ "$INFILE" -nt "$OUTFILE" ]; then + return 1 + fi + done + return 0 +} + +function cmd() +{ + printf "%8s $2\n" $1 + shift 2 + $* || exit +} + +function gpp() +{ + bld "$1" "$2" || cmd CXX "$1" g++ -ggdb -W -Wall -Iminibu -Iminibu/bu -c -o "$1" "$2" +} + +if [ ! -z "$1" ]; then + if [ "$1" == "clean" -o "$1" == "-c" ]; then + echo "Cleaning up, deleting all object code and downloaded source code..." + echo + rm -Rf minibu src/*.o + exit + else + echo "The only option supported is \"clean\", otherwise run $0" + echo "with no parameters to compile build." + echo + exit + fi +fi + +mkdir -p minibu/src minibu/bu +for F in $BUSRC; do + bld minibu/src/$F || cmd WGET minibu/src/$F wget -q http://svn.xagasoft.com/libbu++/trunk/src/$F -O minibu/src/$F +done +for F in $BUHDR; do + bld minibu/bu/$F || cmd WGET minibu/bu/$F wget -q http://svn.xagasoft.com/libbu++/trunk/src/$F -O minibu/bu/$F +done + +bld src/build.tab.c src/build.y || cmd BISON src/build.tab.c bison -bsrc/build src/build.y +bld src/build.yy.c src/build.l || cmd FLEX src/build.yy.c flex src/build.l + +for F in $BUSRC; do + OUTPUT=${F%.*}.o + bld minibu/src/$OUTPUT || gpp minibu/src/$OUTPUT minibu/src/$F +done + +for F in src/*.c src/*.cpp; do + OUTPUT=${F%.*}.o + gpp "$OUTPUT" "$F" +done +bld build src/*.o minibu/src/*.o || cmd LINK build g++ -o build src/*.o minibu/src/*.o -ldl +bld build~ build || cmd CP build~ cp build build~ -- cgit v1.2.3