#!/bin/sh
#
# ngIRCd -- The Next Generation IRC Daemon
-# Copyright (c)2001-2013 Alexander Barton (alex@barton.de) and Contributors
+# Copyright (c)2001-2016 Alexander Barton (alex@barton.de) and Contributors
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# suitable for inclusion in doc/Platforms.txt -- please send reports
# to the ngIRCd mailing list: <ngircd-ml@ngircd.barton.de>.
-NAME=`basename "$0"`
+NAME=$(basename "$0")
VERBOSE=
+CLEAN=1
PLATFORM=
COMPILER="unknown"
VERSION="unknown"
-DATE=`date "+%y-%m-%d"`
+DATE=$(date "+%y-%m-%d")
COMMENT=
R_CONFIGURE=
R_MAKE=
R_CHECK=
+R_CHECK_Y="?"
R_RUN=
+SRC_D=$(dirname "$0")
+MY_D="$PWD"
+
[ -n "$MAKE" ] || MAKE="make"
export MAKE CC
"-v")
VERBOSE=1
;;
+ "-x")
+ CLEAN=
+ ;;
*)
- echo "Usage: $NAME [-v]"
+ echo "Usage: $NAME [-v] [-x]"
+ echo
+ echo " -v Verbose output"
+ echo " -x Don't regenerate build system, even when possible"
+ echo
exit 2
esac
shift
done
+for cmd in telnet expect; do
+ command -v "$cmd" >/dev/null 2>&1 \
+ || echo "$NAME: WARNING: $cmd(1) not found, \"make check\" won't run all tests!"
+done
+
echo "$NAME: Checking ngIRCd base source directory ..."
-grep "ngIRCd" ./ChangeLog >/dev/null 2>&1
+grep "ngIRCd" "$SRC_D/ChangeLog" >/dev/null 2>&1
if [ $? -ne 0 ]; then
- grep "ngIRCd" ../ChangeLog >/dev/null 2>&1
+ grep "ngIRCd" "$SRC_D/../ChangeLog" >/dev/null 2>&1
if [ $? -ne 0 ]; then
echo "$NAME: ngIRCd base source directory not found!?"
exit 1
fi
- cd ..
+ SRC_D="$SRC_D/.."
fi
+echo "$NAME: - source directory: $SRC_D"
+echo "$NAME: - working directory: $MY_D"
-echo "$NAME: Checking for \"./configure\" script ..."
-if [ ! -e ./configure ]; then
- echo "$NAME: Running \"./autogen.sh\" ..."
- [ -n "$VERBOSE" ] && ./autogen.sh || ./autogen.sh >/dev/null
+echo "$NAME: Checking for GIT tree ..."
+if [ -d "$SRC_D/.git" ]; then
+ echo "$NAME: Checking for \"git\" command ..."
+ git version >/dev/null 2>&1
+ if [ $? -eq 0 ] && [ -n "$CLEAN" ]; then
+ echo "$NAME: Running \"git clean\" ..."
+ cd "$SRC_D" || exit 1
+ if [ -n "$VERBOSE" ]; then
+ git clean -dxf
+ else
+ git clean -dxf >/dev/null
+ fi
+ cd "$MY_D" || exit 1
+ fi
fi
-if [ -r ./configure ]; then
- echo "$NAME: Running \"./configure\" script ..."
- [ -n "$VERBOSE" ] && ./configure || ./configure >/dev/null
- if [ $? -eq 0 -a -r ./Makefile ]; then
+echo "$NAME: Checking for \"$SRC_D/configure\" script ..."
+if [ ! -r "$SRC_D/configure" ]; then
+ echo "$NAME: Running \"$SRC_D/autogen.sh\" ..."
+ cd "$SRC_D" || exit 1
+ if [ -n "$VERBOSE" ]; then
+ ./autogen.sh
+ else
+ ./autogen.sh >/dev/null
+ fi
+ if [ $? -ne 0 ]; then
+ echo "$NAME: \"$SRC_D/autogen.sh\" script failed, aborting!"
+ exit 1
+ fi
+ cd "$MY_D" || exit 1
+fi
+
+if [ -r "$SRC_D/configure" ]; then
+ echo "$NAME: Running \"$SRC_D/configure\" script ..."
+ if [ -n "$VERBOSE" ]; then
+ "$SRC_D/configure" -C
+ else
+ "$SRC_D/configure" -C >/dev/null
+ fi
+ if [ $? -eq 0 ] && [ -r ./Makefile ]; then
R_CONFIGURE=1
+ rm -f "src/ngircd/ngircd"
echo "$NAME: Running \"$MAKE\" ..."
- [ -n "$VERBOSE" ] && "$MAKE" || "$MAKE" >/dev/null
- if [ $? -eq 0 -a -x src/ngircd/ngircd ]; then
+ if [ -n "$VERBOSE" ]; then
+ "$MAKE"
+ else
+ "$MAKE" >/dev/null
+ fi
+ if [ $? -eq 0 ] && [ -x src/ngircd/ngircd ]; then
R_MAKE=1
echo "$NAME: Running \"$MAKE check\" ..."
- [ -n "$VERBOSE" ] && "$MAKE" check || "$MAKE" check >/dev/null
+ if [ -n "$VERBOSE" ]; then
+ "$MAKE" check
+ else
+ "$MAKE" check >/dev/null
+ fi
if [ $? -eq 0 ]; then
R_CHECK=1
R_RUN=$R_CHECK
+ [ -r ./src/testsuite/tests-skipped.lst ] \
+ && R_CHECK_Y="y" || R_CHECK_Y="Y"
else
./src/ngircd/ngircd --help 2>/dev/null \
| grep "^ngIRCd" >/dev/null
# Get target platform information
if [ -r "src/config.h" ]; then
- CPU=`grep "HOST_CPU" "src/config.h" | cut -d'"' -f2`
- OS=`grep "HOST_OS" "src/config.h" | cut -d'"' -f2`
- VENDOR=`grep "HOST_VENDOR" "src/config.h" | cut -d'"' -f2`
+ CPU=$(grep "HOST_CPU" "src/config.h" | cut -d'"' -f2)
+ OS=$(grep "HOST_OS" "src/config.h" | cut -d'"' -f2)
+ VENDOR=$(grep "HOST_VENDOR" "src/config.h" | cut -d'"' -f2)
PLATFORM="$CPU/$VENDOR/$OS"
fi
if [ -z "$PLATFORM" ]; then
- PLATFORM="`uname 2>/dev/null` `uname -r 2>/dev/null`, `uname -m 2>/dev/null`"
+ PLATFORM="$(uname 2>/dev/null) $(uname -r 2>/dev/null), $(uname -m 2>/dev/null)"
fi
# Get compiler information
CC=$(grep "^CC = " Makefile | cut -d' ' -f3)
$CC --version 2>&1 | grep -i "GCC" >/dev/null
if [ $? -eq 0 ]; then
+ # GCC, or compiler that mimics GCC
$CC --version 2>&1 | grep -i "Open64" >/dev/null
if [ $? -eq 0 ]; then
COMPILER="Open64"
COMPILER="gcc $COMPILER"
fi
else
- $CC --version 2>&1 | grep -i "LLVM" >/dev/null
+ # Non-GCC compiler
+ $CC --version 2>&1 | grep -i "clang" >/dev/null
if [ $? -eq 0 ]; then
COMPILER=$($CC --version 2>/dev/null | head -1 \
- | cut -d'(' -f1 | sed -e 's/version //g' \
- | sed -e 's/Apple /A-/g')
+ | cut -d'(' -f1 | cut -d'-' -f1 \
+ | sed -e 's/version //g' | sed -e 's/Apple /A-/g' \
+ | sed -e 's/Debian //g' | sed -e 's/LLVM /clang /g')
+ fi
+ $CC -version 2>&1 | grep -i "tcc" >/dev/null
+ if [ $? -eq 0 ]; then
+ COMPILER=$($CC -version 2>/dev/null | head -1 \
+ | cut -d'(' -f1 | sed -e 's/version //g')
fi
if [ "$COMPILER" = "unknown" ]; then
- v="`$CC --version 2>/dev/null | head -1`"
+ v="$($CC --version 2>/dev/null | head -1)"
+ [ -z "$v" ] && v="$($CC -version 2>/dev/null | head -1)"
[ -n "$v" ] && COMPILER="$v"
fi
fi
fi
# Get ngIRCd version information
-eval $(grep "^VERSION = " Makefile | sed -e 's/ //g')
+eval "$(grep "^VERSION = " Makefile | sed -e 's/ //g')"
case "$VERSION" in
- *-*-*)
- VERSION=`echo "$VERSION" | cut -d'-' -f3 | cut -b2-`
+ *~*-*)
+ VERSION=$(echo "$VERSION" | cut -b1-10)
;;
esac
[ -n "$VERSION" ] || VERSION="unknown"
# Get IO interface information
if [ "$OS" = "linux-gnu" ]; then
- COMMENT="(1)"
+ COMMENT="1"
else
grep "^#define HAVE_SYS_DEVPOLL_H 1" src/config.h >/dev/null 2>&1
- [ $? -eq 0 ] && COMMENT="(4)"
+ [ $? -eq 0 ] && COMMENT="4"
grep "^#define HAVE_EPOLL_CREATE 1" src/config.h >/dev/null 2>&1
- [ $? -eq 0 ] && COMMENT="(5)"
+ [ $? -eq 0 ] && COMMENT="5"
grep "^#define HAVE_KQUEUE 1" src/config.h >/dev/null 2>&1
- [ $? -eq 0 ] && COMMENT="(3)"
+ [ $? -eq 0 ] && COMMENT="3"
fi
[ -n "$R_CONFIGURE" ] && C="Y" || C="N"
[ -n "$R_MAKE" ] && M="Y" || M="N"
-[ -n "$R_CHECK" ] && T="Y" || T="N"
-[ -n "$R_RUN" ] && R="Y" || R="N"
+[ -n "$R_CHECK" ] && T="$R_CHECK_Y" || T="N"
+if [ -n "$R_RUN" ]; then
+ # Mark "runs" with "Y" only when the test suite succeeded:
+ [ "$T" = "N" ] && R="?" || R="Y"
+else
+ R="N"
+fi
[ -n "$COMMENT" ] && COMMENT=" $COMMENT"
echo
-echo " the executable works (\"runs\") as expected --+"
-echo " tests run successfully (\"make check\") --+ |"
-echo " ngIRCd compiles (\"make\") --+ | |"
-echo " ./configure works --+ | | |"
-echo " | | | |"
-echo "Platform Compiler ngIRCd Date Tester C M T R See"
-echo "--------------------------- ------------ ---------- -------- ------ - - - - ---"
-type printf >/dev/null 2>&1
+echo " the executable works (\"runs\") as expected --+"
+echo " tests run successfully (\"make check\") --+ |"
+echo " ngIRCd compiles (\"make\") --+ | |"
+echo " ./configure works --+ | | |"
+echo " | | | |"
+echo "Platform Compiler ngIRCd Date Tester C M T R *"
+echo "--------------------------- ------------ ---------- -------- -------- - - - - -"
+command -v printf >/dev/null 2>&1
if [ $? -eq 0 ]; then
- printf "%-27s %-12s %-10s %s %-6s %s %s %s %s%s" \
- "$PLATFORM" "$COMPILER" "$VERSION" "$DATE" "$USER" \
+ printf "%-27s %-12s %-10s %s %-8s %s %s %s %s%s\n" \
+ "$PLATFORM" "$COMPILER" "$VERSION" "$DATE" "$LOGNAME" \
"$C" "$M" "$T" "$R" "$COMMENT"
else
- echo "$PLATFORM $COMPILER $VERSION $DATE $USER" \
+ echo "$PLATFORM $COMPILER $VERSION $DATE $LOGNAME" \
"$C" "$M" "$T" "$R" "$COMMENT"
fi
-echo; echo
+echo
+
+double_check() {
+ echo "Please double check that the ngIRCd daemon starts up, runs and handles IRC"
+ echo "connections successfully!"
+}
+
+if [ "$R_CHECK_Y" = "y" ]; then
+ echo "WARNING: Some tests have been skipped!"
+ double_check
+ echo
+fi
+if [ "$R" = "?" ]; then
+ echo "WARNING: The resulting binary passed simple tests, but the test suite failed!"
+ double_check
+ echo
+fi