X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=bootstrap.sh;h=0bf6c3d3739e558d97ab24d8a4568c8291359814;hb=75ac80cb255e4def7ee685ce9c46db7c2f6625aa;hp=cdaeee6138e989e66e4c155cc56987546bfaeb09;hpb=05aafad32a76aa43b95f0e1141027d0ebfc1b07e;p=builder.git diff --git a/bootstrap.sh b/bootstrap.sh index cdaeee6..0bf6c3d 100755 --- a/bootstrap.sh +++ b/bootstrap.sh @@ -3,10 +3,16 @@ set -e -REQUIRED="core datafile fs strings io" +REQUIRED="core datafile" CFLAGS="-Iinclude `pkg-config --cflags sigc++-2.0`" LIBS="`pkg-config --libs sigc++-2.0` -lpthread" -if [ -e /usr/lib/libdl.so ]; then +MACHINE="`uname -m`" +if [ "$MACHINE" = "x86_64" ]; then + MULTIARCH="x86_64-linux-gnu" +else + MULTIARCH="i386-linux-gnu" +fi +if [ -e /usr/lib/libdl.so -o -e /usr/lib/$MULTIARCH/libdl.so ]; then LIBS="$LIBS -ldl" fi if [ -z "$LIBPATH" -o "${LIBPATH%%/*}" ]; then @@ -18,20 +24,29 @@ mkdir -p include/msp sources=source/*.cpp +missing="" for i in $REQUIRED; do path=`ls -1d $LIBPATH/*$i* 2>/dev/null | head -n1` - if [ -z "$path" ]; then - echo msp$i missing - exit 1 - fi - if [ $i = "core" ]; then - ln -sf $path/source/* include/msp/ + if [ -z "$path" -o ! -d "$path/source" ]; then + missing="$missing msp$i" else - ln -sf $path/source include/msp/$i + if [ $i = "core" ]; then + ln -sf $path/source/* include/msp/ + else + ln -sf $path/source include/msp/$i + fi + sources="$sources `find $path/source -name '*.cpp'`" fi - sources="$sources `find $path/source -name '*.cpp'`" done +if [ ! -z "$missing" ]; then + echo "The following libraries were not found:$missing" + echo "I looked for them in $LIBPATH" + echo "If they are somewhere else, please adjust the LIBPATH environment variable." + exit 1 +fi + echo "Compiling builder-stage1. This may take several minutes." g++ $sources -o builder-stage1 $CFLAGS $LIBS -echo "Done." +echo "Using builder-stage1 to compile builder." +./builder-stage1