3 # Copyright (C) 2012 Brian Aker
6 # Redistribution and use in source and binary forms, with or without
7 # modification, are permitted provided that the following conditions are
10 # * Redistributions of source code must retain the above copyright
11 # notice, this list of conditions and the following disclaimer.
13 # * Redistributions in binary form must reproduce the above
14 # copyright notice, this list of conditions and the following disclaimer
15 # in the documentation and/or other materials provided with the
18 # * The names of its contributors may not be used to endorse or
19 # promote products derived from this software without specific prior
22 # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
23 # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
24 # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
25 # A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
26 # OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
27 # SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
28 # LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
29 # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
30 # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
31 # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
32 # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
35 # Environment Variables that will influence the build:
46 command_not_found_handle
()
48 warn
"$@: command not found"
54 while caller
$frame; do
65 echo "$BASH_SOURCE:$BASH_LINENO: $@" >&2
70 echo "$BASH_SOURCE:$BASH_LINENO: $@" >&2
76 echo "$BASH_SOURCE:$BASH_LINENO: $@"
77 #echo "$BASH_SOURCE:$BASH_LINENO: $@" >&1
82 local param_name
=\$
"$1"
83 local param_value
=`eval "expr \"$param_name\" "`
85 if [ -n "$param_value" ]; then
86 echo "$bash_source:$bash_lineno: assert($param_name) had value of "$param_value"" >&2
93 local param_name
=\$
"$1"
94 local param_value
=`eval "expr \"$param_name\" "`
96 if [ -z "$param_value" ]; then
97 echo "$bash_source:$bash_lineno: assert($param_name)" >&2
102 function assert_file
()
104 if [ ! -f "$1" ]; then
105 echo "$BASH_SOURCE:$BASH_LINENO: assert($1) does not exist: $2" >&2
110 function assert_no_file
()
113 echo "$BASH_SOURCE:$BASH_LINENO: assert($1) file exists: $2" >&2
118 function assert_no_directory
()
121 echo "$BASH_SOURCE:$BASH_LINENO: assert($1) directory exists: $2" >&2
126 function assert_exec_file
()
128 if [ ! -f "$1" ]; then
129 echo "$BASH_SOURCE:$BASH_LINENO: assert($1) does not exist: $2" >&2
133 if [ ! -x "$1" ]; then
134 echo "$BASH_SOURCE:$BASH_LINENO: assert($1) exists but is not executable: $2" >&2
139 function command_exists
()
141 type "$1" &> /dev
/null
;
144 function rebuild_host_os
()
146 HOST_OS
="${UNAME_MACHINE_ARCH}-${VENDOR}-${VENDOR_DISTRIBUTION}-${VENDOR_RELEASE}-${UNAME_KERNEL}-${UNAME_KERNEL_RELEASE}"
149 echo "HOST_OS=$HOST_OS"
154 # Valid values are: darwin,fedora,rhel,ubuntu
155 function set_VENDOR_DISTRIBUTION
()
157 local dist
=`echo "$1" | tr '[A-Z]' '[a-z]'`
160 VENDOR_DISTRIBUTION
='darwin'
163 VENDOR_DISTRIBUTION
='fedora'
166 VENDOR_DISTRIBUTION
='rhel'
169 VENDOR_DISTRIBUTION
='ubuntu'
172 VENDOR_DISTRIBUTION
='opensuse'
175 die
"attempt to set an invalid VENDOR_DISTRIBUTION=$dist"
180 function set_VENDOR_RELEASE
()
182 local release
=`echo "$1" | tr '[A-Z]' '[a-z]'`
183 case "$VENDOR_DISTRIBUTION" in
185 VENDOR_RELEASE
='mountain'
188 VENDOR_RELEASE
="$release"
191 VENDOR_RELEASE
="$release"
194 VENDOR_RELEASE
="$release"
197 VENDOR_RELEASE
="$release"
200 die
"attempt to set VENDOR_RELEASE without setting VENDOR_DISTRIBUTION"
203 die
"attempt to set with an invalid VENDOR_DISTRIBUTION=$VENDOR_DISTRIBUTION"
209 # Valid values are: apple, redhat, centos, canonical
210 function set_VENDOR
()
212 local vendor
=`echo "$1" | tr '[A-Z]' '[a-z]'`
231 die
"An attempt was made to set an invalid VENDOR=$_vendor"
235 set_VENDOR_DISTRIBUTION
$2
236 set_VENDOR_RELEASE
$3
239 function determine_target_platform
()
241 UNAME_MACHINE_ARCH
=`(uname -m) 2>/dev/null` || UNAME_MACHINE_ARCH
=unknown
242 UNAME_KERNEL
=`(uname -s) 2>/dev/null` || UNAME_SYSTEM
=unknown
243 UNAME_KERNEL_RELEASE
=`(uname -r) 2>/dev/null` || UNAME_KERNEL_RELEASE
=unknown
245 if [[ $
(uname
) == 'Darwin' ]]; then
246 set_VENDOR
'apple' 'darwin' 'mountain'
247 elif [[ -f '/etc/fedora-release' ]]; then
248 local fedora_version
=`cat /etc/fedora-release | awk ' { print $3 } '`
249 set_VENDOR
'redhat' 'fedora' $fedora_version
250 if [[ "x$VENDOR_RELEASE" == 'x17' ]]; then
251 AUTORECONF_REBUILD_HOST
=true
253 elif [[ -f '/etc/centos-release' ]]; then
254 local centos_version
=`cat /etc/centos-release | awk ' { print $7 } '`
255 set_VENDOR
'centos' 'rhel' $centos_version
256 elif [[ -f '/etc/SuSE-release' ]]; then
257 local suse_distribution
=`head -1 /etc/SuSE-release | awk ' { print $1 } '`
258 local suse_version
=`head -1 /etc/SuSE-release | awk ' { print $2 } '`
259 set_VENDOR
'suse' $suse_distribution $suse_version
260 elif [[ -f '/etc/redhat-release' ]]; then
261 local rhel_version
=`cat /etc/redhat-release | awk ' { print $7 } '`
262 set_VENDOR
'redhat' 'rhel' $rhel_version
263 elif [[ -f '/etc/lsb-release' ]]; then
264 local debian_DISTRIB_ID
=`cat /etc/lsb-release | grep DISTRIB_ID | awk -F= ' { print $2 } '`
265 local debian_version
=`cat /etc/lsb-release | grep DISTRIB_CODENAME | awk -F= ' { print $2 } '`
266 set_VENDOR
'canonical' $debian_DISTRIB_ID $debian_version
267 if [[ "x$VENDOR_RELEASE" == 'xprecise' ]]; then
268 AUTORECONF_REBUILD_HOST
=true
275 function run_configure
()
277 # We will run autoreconf if we are required
278 run_autoreconf_if_required
280 # We always begin at the root of our build
282 die
"Programmer error, we entered run_configure with a stacked directory"
285 if ! command_exists
"$CONFIGURE"; then
286 die
"$CONFIGURE does not exist"
290 if [[ -n "$BUILD_DIR" ]]; then
293 safe_pushd
$BUILD_DIR
296 # Arguments for configure
297 local BUILD_CONFIGURE_ARG
=
299 # Set ENV DEBUG in order to enable debugging
301 BUILD_CONFIGURE_ARG
='--enable-debug'
304 # Set ENV ASSERT in order to enable assert
305 if [[ -n "$ASSERT" ]]; then
307 ASSERT_ARG
='--enable-assert'
308 BUILD_CONFIGURE_ARG
="$ASSERT_ARG $BUILD_CONFIGURE_ARG"
311 if [[ -n "$CONFIGURE_ARG" ]]; then
312 BUILD_CONFIGURE_ARG
= "$BUILD_CONFIGURE_ARG $CONFIGURE_ARG"
316 # If we are executing on OSX use CLANG, otherwise only use it if we find it in the ENV
319 CC
=clang CXX
=clang
++ $top_srcdir/configure
$BUILD_CONFIGURE_ARG || die
"Cannot execute CC=clang CXX=clang++ configure $BUILD_CONFIGURE_ARG $PREFIX_ARG"
323 command_exists
'gcc44' || die
"Could not locate gcc44"
324 CC
=gcc44 CXX
=gcc44
$top_srcdir/configure
$BUILD_CONFIGURE_ARG $PREFIX_ARG || die
"Cannot execute CC=gcc44 CXX=gcc44 configure $BUILD_CONFIGURE_ARG $PREFIX_ARG"
328 $CONFIGURE $BUILD_CONFIGURE_ARG $PREFIX_ARG
333 if [ $ret -ne 0 ]; then
334 die
"Could not execute $CONFIGURE $BUILD_CONFIGURE_ARG $PREFIX_ARG"
337 if [ ! -f 'Makefile' ]; then
338 die
"Programmer error, configure was run but no Makefile existed after $CONFIGURE was run"
342 function setup_gdb_command
() {
343 GDB_TMPFILE
=$
(mktemp
/tmp
/gdb.XXXXXXXXXX
)
344 echo 'set logging overwrite on' > $GDB_TMPFILE
345 echo 'set logging on' >> $GDB_TMPFILE
346 echo 'set environment LIBTEST_IN_GDB=1' >> $GDB_TMPFILE
347 echo 'run' >> $GDB_TMPFILE
348 echo 'thread apply all bt' >> $GDB_TMPFILE
349 echo 'quit' >> $GDB_TMPFILE
350 GDB_COMMAND
="gdb -f -batch -x $GDB_TMPFILE"
353 function setup_valgrind_command
() {
354 VALGRIND_PROGRAM
=`type -p valgrind`
355 if [[ -n "$VALGRIND_PROGRAM" ]]; then
356 VALGRIND_COMMAND
="$VALGRIND_PROGRAM --error-exitcode=1 --leak-check=yes --show-reachable=yes --track-fds=yes --malloc-fill=A5 --free-fill=DE"
360 function save_BUILD
()
362 if [[ -n "$OLD_CONFIGURE" ]]; then
363 die
"OLD_CONFIGURE($OLD_CONFIGURE) was set on push, programmer error!"
366 if [[ -n "$OLD_CONFIGURE_ARG" ]]; then
367 die
"OLD_CONFIGURE_ARG($OLD_CONFIGURE_ARG) was set on push, programmer error!"
370 if [[ -n "$OLD_MAKE" ]]; then
371 die
"OLD_MAKE($OLD_MAKE) was set on push, programmer error!"
374 if [[ -n "$OLD_TESTS_ENVIRONMENT" ]]; then
375 die
"OLD_TESTS_ENVIRONMENT($OLD_TESTS_ENVIRONMENT) was set on push, programmer error!"
378 if [[ -n "$CONFIGURE" ]]; then
379 OLD_CONFIGURE
=$CONFIGURE
382 if [[ -n "$CONFIGURE_ARG" ]]; then
383 OLD_CONFIGURE_ARG
=$CONFIGURE_ARG
386 if [[ -n "$MAKE" ]]; then
390 if [[ -n "$TESTS_ENVIRONMENT" ]]; then
391 OLD_TESTS_ENVIRONMENT
=$TESTS_ENVIRONMENT
395 function restore_BUILD
()
397 if [[ -n "$OLD_CONFIGURE" ]]; then
398 CONFIGURE
=$OLD_CONFIGURE
401 if [[ -n "$OLD_CONFIGURE_ARG" ]]; then
402 CONFIGURE_ARG
=$OLD_CONFIGURE_ARG
405 if [[ -n "$OLD_MAKE" ]]; then
409 if [[ -n "$OLD_TESTS_ENVIRONMENT" ]]; then
410 TESTS_ENVIRONMENT
=$OLD_TESTS_ENVIRONMENT
416 OLD_TESTS_ENVIRONMENT
=
417 echo "reset happened"
420 function push_PREFIX_ARG
()
422 if [[ -n "$OLD_PREFIX_ARG" ]]; then
423 die
"OLD_PREFIX_ARG was set on push, programmer error!"
426 if [[ -n "$PREFIX_ARG" ]]; then
427 OLD_PREFIX_ARG
=$PREFIX_ARG
431 if [[ -n "$1" ]]; then
432 PREFIX_ARG
="--prefix=$1"
436 function pop_PREFIX_ARG
()
438 if [[ -n "$OLD_PREFIX_ARG" ]]; then
439 PREFIX_ARG
=$OLD_PREFIX_ARG
446 function push_TESTS_ENVIRONMENT
()
448 if [[ -n "$OLD_TESTS_ENVIRONMENT" ]]; then
449 die
"OLD_TESTS_ENVIRONMENT was set on push, programmer error!"
452 if [[ -n "$TESTS_ENVIRONMENT" ]]; then
453 OLD_TESTS_ENVIRONMENT
=$TESTS_ENVIRONMENT
458 function pop_TESTS_ENVIRONMENT
()
461 if [[ -n "$OLD_TESTS_ENVIRONMENT" ]]; then
462 TESTS_ENVIRONMENT
=$OLD_TESTS_ENVIRONMENT
463 OLD_TESTS_ENVIRONMENT
=
467 function safe_pushd
()
469 pushd $1 &> /dev
/null
;
471 if [ -n "$BUILD_DIR" ]; then
473 echo "BUILD_DIR=$BUILD_DIR"
478 function safe_popd
()
480 local directory_to_delete
=`pwd`
482 if [ $?
-eq 0 ]; then
483 if [[ "$top_srcdir" == "$directory_to_delete" ]]; then
484 die
"We almost deleted top_srcdir($top_srcdir), programmer error"
487 rm -r -f "$directory_to_delete"
491 function make_valgrind
()
493 if [[ "$VENDOR_DISTRIBUTION" == 'darwin' ]]; then
498 # If the env VALGRIND_COMMAND is set then we assume it is valid
499 local valgrind_was_set
=false
500 if [[ -z "$VALGRIND_COMMAND" ]]; then
501 setup_valgrind_command
502 if [[ -n "$VALGRIND_COMMAND" ]]; then
503 valgrind_was_set
=true
506 valgrind_was_set
=true
509 # If valgrind_was_set is set to no we bail
510 if ! $valgrind_was_set; then
511 echo 'valgrind was not present'
515 # If we are required to run configure, do so now
516 run_configure_if_required
518 push_TESTS_ENVIRONMENT
520 # If we don't have a configure, then most likely we will be missing libtool
521 assert_file
'configure'
522 if [[ -f 'libtool' ]]; then
523 TESTS_ENVIRONMENT
="./libtool --mode=execute $VALGRIND_COMMAND"
525 TESTS_ENVIRONMENT
="$VALGRIND_COMMAND"
528 make_target
'check' ||
return 1
530 pop_TESTS_ENVIRONMENT
533 function make_install_system
()
535 local INSTALL_LOCATION
=$
(mktemp
-d /tmp
/XXXXXXXXXX
)
536 push_PREFIX_ARG
$INSTALL_LOCATION
538 if [ ! -d $INSTALL_LOCATION ] ; then
539 die
"ASSERT temp directory not found '$INSTALL_LOCATION'"
542 run_configure
#install_buid_dir
544 push_TESTS_ENVIRONMENT
546 make_target
'install'
548 make_target
'installcheck'
550 make_target
'uninstall'
552 pop_TESTS_ENVIRONMENT
555 rm -r -f $INSTALL_LOCATION
558 if [ -f 'Makefile' ]; then
559 die
"ASSERT Makefile should not exist"
565 function make_darwin_malloc
()
567 run_configure_if_required
569 old_MallocGuardEdges
=$MallocGuardEdges
571 old_MallocErrorAbort
=$MallocErrorAbort
573 old_MallocScribble
=$MallocScribble
578 MallocGuardEdges
=$old_MallocGuardEdges
579 MallocErrorAbort
=$old_MallocErrorAbort
580 MallocScribble
=$old_MallocScribble
583 function snapshot_check
()
585 if [ ! -f "$BOOTSTRAP_SNAPSHOT_CHECK" ]; then
589 if [ -n "$BOOTSTRAP_SNAPSHOT_CHECK" ]; then
590 assert_file
"$BOOTSTRAP_SNAPSHOT_CHECK" 'snapshot check failed'
594 # This will reset our environment, and make sure built files are available.
595 function make_for_snapshot
()
597 # Make sure it is clean
598 make_maintainer_clean
602 make_target
'distclean'
604 # We should have a configure, but no Makefile at the end of this exercise
605 assert_no_file
'Makefile'
606 assert_exec_file
'configure'
611 function check_mingw
()
613 command_exists
'mingw64-configure'
615 if [ "$ret" -ne 0 ]; then
619 command_exists
'mingw64-make'
621 if [ "$ret" -ne 0 ]; then
628 function make_skeleton_mingw
()
633 if [ $ret -eq 0 ]; then
634 assert_file
'Makefile'
636 make_target
'all' 'warn'
638 if [ $ret -ne 0 ]; then
641 if [[ -n "$DISPLAY" ]]; then
642 if command_exists
'wine'; then
643 TESTS_ENVIRONMENT
='wine'
645 elif command_exists
'wineconsole'; then
646 TESTS_ENVIRONMENT
='wineconsole --backend=curses'
649 if [[ -n "$TESTS_ENVIRONMENT" ]]; then
650 make_target
'check' 'warn' || warn
"$MAKE check failed"
655 if $jenkins_build_environment; then
656 make_target
'clean' 'warn'
663 function make_for_mingw
()
666 if ! check_mingw
; then
667 die
'mingw64 tools were not found'
670 # Make sure it is clean
671 if [ -f Makefile
-o -f configure
]; then
672 make_maintainer_clean
679 CONFIGURE
='mingw64-configure'
681 CONFIGURE_ARGS
='--enable-static'
691 # If we are locally testing, we should make sure the environment is setup correctly
692 function check_for_jenkins
()
694 if ! $jenkins_build_environment; then
695 echo "Not inside of jenkins"
697 if [ -f 'configure' ]; then
698 make_maintainer_clean
701 if $BOOTSTRAP_SNAPSHOT; then
707 function make_universe
()
714 if [ check_mingw
-eq 0 ]; then
722 function make_for_continuus_integration
()
724 # Setup the environment if we are local
727 # No matter then evironment, we should not have a Makefile at this point
728 assert_no_file
'Makefile'
730 # Platforms which require bootstrap should have some setup done before we hit this stage.
731 # If we are building locally, skip this step, unless we are just testing locally.
732 if $BOOTSTRAP_SNAPSHOT; then
735 # If we didn't require a snapshot, then we should not have a configure
736 assert_no_file
'configure'
741 assert_no_file
'Makefile' 'Programmer error, Makefile existed where build state should have been clean'
747 assert_exec_file
'configure'
748 assert_file
'Makefile'
752 # make rpm includes "make distcheck"
753 if [[ -f rpm.am
]]; then
755 elif [[ -d rpm
]]; then
761 assert_exec_file
'configure'
762 assert_file
'Makefile'
769 assert_exec_file
'configure'
770 assert_file
'Makefile'
776 assert_exec_file
'configure'
777 assert_file
'Makefile'
781 assert_exec_file
'configure'
782 assert_file
'Makefile'
791 make_maintainer_clean
796 # The point to this test is to test bootstrap.sh itself
797 function self_test
()
799 # We start off with a clean env
800 make_maintainer_clean
802 eval "./bootstrap.sh jenkins" || die
"failed 'jenkins'"
803 eval "./bootstrap.sh all" || die
"failed 'all'"
804 eval "./bootstrap.sh gdb" || die
"failed 'gdb'"
805 eval "./bootstrap.sh maintainer-clean" || die
"failed 'maintainer-clean'"
808 function make_install_html
()
810 run_configure_if_required
811 assert_file
'configure'
813 make_target
'install-html'
818 if command_exists
'gdb'; then
819 run_configure_if_required
821 push_TESTS_ENVIRONMENT
823 # Set ENV GDB_COMMAND
824 if [[ -z "$GDB_COMMAND" ]]; then
828 # If we don't have a configure, then most likely we will be missing libtool
829 assert_file
'configure'
830 if [[ -f 'libtool' ]]; then
831 TESTS_ENVIRONMENT
="./libtool --mode=execute $GDB_COMMAND"
833 TESTS_ENVIRONMENT
="$GDB_COMMAND"
838 if [ -f 'gdb.txt' ]; then
842 pop_TESTS_ENVIRONMENT
844 if [ -f '.gdb_history' ]; then
848 if $jenkins_build_environment; then
852 echo 'gdb was not present'
857 # $1 target to compile
858 # $2 to die, or not to die, based on contents
859 function make_target
()
862 die
"Programmer error, no target provided for make"
865 if [ ! -f 'Makefile' ]; then
866 die
"Programmer error, make was called before configure"
870 if [ -n "$TESTS_ENVIRONMENT" ]; then
872 echo "TESTS_ENVIRONMENT=$TESTS_ENVIRONMENT"
876 if [ -z "$MAKE" ]; then
877 die
"MAKE was not set"
880 # $2 represents error or warn
884 if [ $ret -ne 0 ]; then
886 warn
"Cannot execute $MAKE $1: $ret"
888 die
"Cannot execute $MAKE $1: $ret"
895 function make_distcheck
()
897 make_target
'distcheck'
902 if command_exists
'rpmbuild'; then
903 if [ -f 'rpm.am' -o -d 'rpm' ]; then
904 run_configure_if_required
907 if $jenkins_build_environment; then
915 function make_maintainer_clean
()
917 run_configure_if_required
918 make_target
'maintainer-clean' 'no_error'
920 # Lets make sure we really cleaned up the environment
921 assert_no_file
'Makefile'
922 assert_no_file
'configure'
923 assert_no_directory
'autom4te.cache'
926 function make_check
()
931 function make_jenkins_default
()
937 function make_default
()
939 run_configure_if_required
943 function run_configure_if_required
()
945 run_autoreconf_if_required
947 if [ ! -f 'Makefile' ]; then
951 assert_file
'Makefile' 'configure did not produce a Makefile'
954 function run_autoreconf_if_required
()
956 if [ ! -x 'configure' ]; then
960 assert_exec_file
'configure'
963 function run_autoreconf
()
965 if [[ -z "$AUTORECONF" ]]; then
966 die
"Programmer error, tried to call run_autoreconf () but AUTORECONF was not set"
969 if test $use_libtool = 1; then
970 assert
$BOOTSTRAP_LIBTOOLIZE
971 run
$BOOTSTRAP_LIBTOOLIZE '--copy' '--install' '--force' || die
"Cannot execute $BOOTSTRAP_LIBTOOLIZE"
974 run
$AUTORECONF || die
"Cannot execute $AUTORECONF"
976 eval 'bash -n configure' || die
"autoreconf generated a malformed configure"
992 function parse_command_line_options
()
994 local SHORTOPTS
=':apcmt:dvh'
998 while getopts "$SHORTOPTS" opt
; do
1001 AUTORECONF_OPTION
=true
1002 MAKE_TARGET
='autoreconf'
1005 PRINT_SETUP_OPTION
=true
1008 CONFIGURE_OPTION
=true
1009 MAKE_TARGET
='configure'
1011 m
) # maintainer-clean
1013 MAKE_TARGET
='clean_op'
1017 TARGET_OPTION_ARG
="$OPTARG"
1018 MAKE_TARGET
="$OPTARG"
1025 echo "bootstrap.sh [options] optional_target ..."
1033 echo "Option -$OPTARG requires an argument." >&2
1037 echo "$0: error - unrecognized option $1" 1>&2
1045 if [ -n "$1" ]; then
1050 function determine_vcs
()
1052 if [[ -d '.git' ]]; then
1054 elif [[ -d '.bzr' ]]; then
1056 elif [[ -d '.svn' ]]; then
1058 elif [[ -d '.hg' ]]; then
1062 if [[ -n "$VCS_CHECKOUT" ]]; then
1067 function require_libtoolise
()
1070 grep '^[ ]*A[CM]_PROG_LIBTOOL' configure.ac
>/dev
/null \
1072 grep '^[ ]*LT_INIT' configure.ac
>/dev
/null \
1076 function autoreconf_setup
()
1078 # Set ENV MAKE in order to override "make"
1079 if [[ -z "$MAKE" ]]; then
1080 if command_exists
'gmake'; then
1081 MAKE
=`type -p gmake`
1083 if command_exists
'make'; then
1088 if [ "$VCS_CHECKOUT" ]; then
1090 MAKE
="$MAKE --warn-undefined-variables"
1099 if [[ -z "$GNU_BUILD_FLAGS" ]]; then
1100 GNU_BUILD_FLAGS
="--install --force"
1104 GNU_BUILD_FLAGS
="$GNU_BUILD_FLAGS --verbose"
1107 if [ -z "$ACLOCAL_PATH" ]; then
1108 ACLOCAL_PATH
="/usr/local/share/aclocal $ACLOCAL_PATH"
1111 if [[ -z "$WARNINGS" ]]; then
1112 if [[ -n "$VCS_CHECKOUT" ]]; then
1113 WARNINGS
="all,error"
1119 if test $use_libtool = 1; then
1120 if [[ -n "$LIBTOOLIZE" ]]; then
1121 BOOTSTRAP_LIBTOOLIZE
=`type -p $LIBTOOLIZE`
1123 if [[ -z "$BOOTSTRAP_LIBTOOLIZE" ]]; then
1124 echo "Couldn't find user supplied libtoolize, it is required"
1127 # If we are using OSX, we first check to see glibtoolize is available
1128 if [[ "$VENDOR_DISTRIBUTION" == "darwin" ]]; then
1129 BOOTSTRAP_LIBTOOLIZE
=`type -p glibtoolize`
1131 if [[ -z "$BOOTSTRAP_LIBTOOLIZE" ]]; then
1132 echo "Couldn't find glibtoolize, it is required on OSX"
1135 BOOTSTRAP_LIBTOOLIZE
=`type -p libtoolize`
1137 if [[ -z "$BOOTSTRAP_LIBTOOLIZE" ]]; then
1138 echo "Couldn't find libtoolize, it is required"
1143 LIBTOOLIZE_OPTIONS
="--verbose $BOOTSTRAP_LIBTOOLIZE_OPTIONS"
1146 LIBTOOLIZE_OPTIONS
="--debug $BOOTSTRAP_LIBTOOLIZE_OPTIONS"
1151 # Test the ENV AUTOMAKE if it exists
1152 if [[ -n "$AUTOMAKE" ]]; then
1153 run
$AUTOMAKE '--help' &> /dev
/null || die
"Failed to run AUTOMAKE:$AUTOMAKE"
1156 # Test the ENV AUTOCONF if it exists
1157 if [[ -n "$AUTOCONF" ]]; then
1158 run
$AUTOCONF '--help' &> /dev
/null || die
"Failed to run AUTOCONF:$AUTOCONF"
1161 # Test the ENV AUTOHEADER if it exists
1162 if [[ -n "$AUTOHEADER" ]]; then
1163 run
$AUTOHEADER '--help' &> /dev
/null || die
"Failed to run AUTOHEADER:$AUTOHEADER"
1166 # Test the ENV AUTOM4TE if it exists
1167 if [[ -n "$AUTOM4TE" ]]; then
1168 run
$AUTOM4TE '--help' &> /dev
/null || die
"Failed to run AUTOM4TE:$AUTOM4TE"
1171 # Test the ENV AUTOHEADER if it exists, if not we add one and add --install
1172 if [[ -z "$ACLOCAL" ]]; then
1173 ACLOCAL
="aclocal --install"
1175 run
$ACLOCAL '--help' &> /dev
/null || die
"Failed to run ACLOCAL:$ACLOCAL"
1177 if [[ -z "$AUTORECONF" ]]; then
1178 AUTORECONF
=`type -p autoreconf`
1180 if [[ -z "$AUTORECONF" ]]; then
1181 die
"Couldn't find autoreconf"
1184 if [[ -n "$GNU_BUILD_FLAGS" ]]; then
1185 AUTORECONF
="$AUTORECONF $GNU_BUILD_FLAGS"
1189 run
$AUTORECONF '--help' &> /dev
/null || die
"Failed to run AUTORECONF:$AUTORECONF"
1192 function print_setup
()
1194 saved_debug_status
=$DEBUG
1199 echo '----------------------------------------------'
1200 echo 'BOOTSTRAP ENV'
1201 echo "AUTORECONF=$AUTORECONF"
1202 echo "HOST_OS=$HOST_OS"
1205 if $AUTORECONF_OPTION; then
1209 if $CLEAN_OPTION; then
1213 if $CONFIGURE_OPTION; then
1217 if $DEBUG_OPTION; then
1221 if $PRINT_SETUP_OPTION; then
1225 if $TARGET_OPTION; then
1226 echo "--target=$TARGET_OPTION_ARG"
1229 if $VERBOSE_OPTION; then
1233 if [[ -n "$MAKE" ]]; then
1237 if [[ -n "$MAKE_TARGET" ]]; then
1238 echo "MAKE_TARGET=$MAKE_TARGET"
1241 if [[ -n "$PREFIX" ]]; then
1242 echo "PREFIX=$PREFIX"
1245 if [[ -n "$TESTS_ENVIRONMENT" ]]; then
1246 echo "TESTS_ENVIRONMENT=$TESTS_ENVIRONMENT"
1249 if [[ -n "$VCS_CHECKOUT" ]]; then
1250 echo "VCS_CHECKOUT=$VCS_CHECKOUT"
1261 if [[ -n "$WARNINGS" ]]; then
1262 echo "WARNINGS=$WARNINGS"
1264 echo '----------------------------------------------'
1266 if $saved_debug_status; then
1271 function make_clean_option
()
1273 run_configure_if_required
1275 make_maintainer_clean
1277 if [[ "$VCS_CHECKOUT" == 'git' ]]; then
1278 run
"$VCS_CHECKOUT" status
--ignored
1279 elif [[ -n "$VCS_CHECKOUT" ]]; then
1280 run
"$VCS_CHECKOUT" status
1284 function make_for_autoreconf
()
1286 if [ -f 'Makefile' ]; then
1287 make_maintainer_clean
1292 assert_no_file
'Makefile'
1295 function check_make_target
()
1345 die
"Unknown MAKE_TARGET option: $1"
1350 function bootstrap
()
1352 determine_target_platform
1356 # Set up whatever we need to do to use autoreconf later
1360 if [ -z "$MAKE_TARGET" ]; then
1361 MAKE_TARGET
="make_default"
1364 if $PRINT_SETUP_OPTION -o $DEBUG; then
1369 # Exit if all we were looking for were the currently used options
1370 if $PRINT_SETUP_OPTION; then
1375 # Use OLD_TESTS_ENVIRONMENT for tracking the state of the variable
1376 local OLD_TESTS_ENVIRONMENT
=
1378 # Set ENV PREFIX in order to set --prefix for ./configure
1379 if [[ -n "$PREFIX" ]]; then
1380 push_PREFIX_ARG
$PREFIX
1383 # We should always have a target by this point
1386 local MAKE_TARGET_ARRAY
=($MAKE_TARGET)
1388 for target
in "${MAKE_TARGET_ARRAY[@]}"
1390 # If we are running inside of Jenkins, we want to only run some of the possible tests
1391 if $jenkins_build_environment; then
1392 check_make_target
$target
1422 if ! check_mingw
; then
1423 die
"mingw was not found"
1429 if ! make_for_mingw
; then
1430 die
"Failed to build mingw: $?"
1446 make_for_continuus_integration
1449 run_configure_if_required
1450 make_target
"$target"
1458 # Variables we export
1459 declare -x VCS_CHECKOUT
=
1461 # Variables we control globally
1465 # Options for getopt
1466 local AUTORECONF_OPTION
=false
1467 local CLEAN_OPTION
=false
1468 local CONFIGURE_OPTION
=false
1469 local DEBUG_OPTION
=false
1470 local PRINT_SETUP_OPTION
=false
1471 local TARGET_OPTION
=false
1472 local TARGET_OPTION_ARG
=
1473 local VERBOSE_OPTION
=false
1475 local OLD_CONFIGURE
=
1476 local OLD_CONFIGURE_ARG
=
1478 local OLD_TESTS_ENVIRONMENT
=
1480 # If we call autoreconf on the platform or not
1481 local AUTORECONF_REBUILD_HOST
=false
1482 local AUTORECONF_REBUILD
=false
1484 local -r top_srcdir
=`pwd`
1487 if [ -z "$CONFIGURE" ]; then
1488 CONFIGURE
="$top_srcdir/configure"
1492 # Variables for determine_target_platform () and rebuild_host_os ()
1493 # UNAME_MACHINE_ARCH= uname -m
1494 # VENDOR= apple, redhat, centos, canonical
1496 # RHEL{rhel,Tikanga,Santiago}
1497 # Ubuntu{ubuntu,Lucid,Maverick,Natty,Oneiric,Precise,Quantal}
1498 # Fedora{fedora,Verne,Beefy}
1499 # OSX{osx,lion,snow,mountain}
1500 # VENDOR_DISTRIBUTION= darwin,fedora,rhel,ubuntu
1501 # UNAME_KERNEL= Linux, Darwin,...
1502 # UNAME_KERNEL_RELEASE= Linux, Darwin,...
1503 local UNAME_MACHINE_ARCH
=unknown
1504 local VENDOR
=unknown
1505 local VENDOR_RELEASE
=unknown
1506 local VENDOR_DISTRIBUTION
=unknown
1507 local UNAME_KERNEL
=unknown
1508 local UNAME_KERNEL_RELEASE
=unknown
1511 rebuild_host_os no_output
1513 parse_command_line_options $@
1515 # If we are running under Jenkins we predetermine what tests we will run against
1516 # This MAKE_TARGET can be overridden by parse_command_line_options based MAKE_TARGET changes.
1517 # We don't want Jenkins overriding other variables, so we NULL them.
1518 if [ -z "$MAKE_TARGET" ]; then
1519 if $jenkins_build_environment; then
1520 MAKE_TARGET
='jenkins'
1532 function set_branch
()
1534 if [ -z "$BRANCH" ]; then
1535 if [ -z "$CI_PROJECT_TEAM" ]; then
1536 die
"Variable CI_PROJECT_TEAM has not been set"
1538 if [ -z "$PROJECT" ]; then
1539 die
"Variable PROJECT has not been set"
1541 if [ -z "$BUILD_TAG" ]; then
1542 die
"Variable BUILD_TAG has not been set"
1545 BRANCH
="lp:~$CI_PROJECT_TEAM/$PROJECT/$BUILD_TAG"
1549 if [ -z "$BRANCH" ]; then
1550 die
"Missing values required to build BRANCH variable."
1556 if [ -z "$VCS_CHECKOUT" ]; then
1557 die
"Merges require VCS_CHECKOUT."
1562 if [[ "$VCS_CHECKOUT" == 'bzr' ]]; then
1563 if test -n "$BRANCH_TO_MERGE"; then
1564 bzr merge
$BRANCH_TO_MERGE
1565 bzr commit
--message="Merge $BRANCH_TO_MERGE Build: $BUILD_TAG" --unchanged
1569 elif [[ -n "$VCS_CHECKOUT" ]]; then
1570 die
"Merge attempt occured, current VCS setup does not support this"
1574 function enable_debug
()
1577 local caller_loc
=`caller`
1579 echo "$caller_loc Enabling debug: $1"
1581 echo "$caller_loc Enabling debug"
1591 Usage: $program_name [OPTION]..
1593 Bootstrap this package from the checked-out sources, and optionally walk through CI run.
1600 function disable_debug
()
1606 # Script begins here
1610 env_debug_enabled
=false
1611 if [[ -n "$JENKINS_HOME" ]]; then
1612 declare -r jenkins_build_environment
=true
1614 declare -r jenkins_build_environment
=false
1624 export GNU_BUILD_FLAGS
1626 export LIBTOOLIZE_OPTIONS
1628 export TESTS_ENVIRONMENT
1634 export MallocGuardEdges
1635 export MallocErrorAbort
1636 export MallocScribble
1640 # We check for DEBUG twice, once before we source the config file, and once afterward
1641 env_debug_enabled
=false
1642 if [[ -n "$DEBUG" ]]; then
1643 env_debug_enabled
=true
1648 # Variables which only can be set by .bootstrap
1649 BOOTSTRAP_SNAPSHOT
=false
1650 BOOTSTRAP_SNAPSHOT_CHECK
=
1652 if [ -f '.bootstrap' ]; then
1656 if $env_debug_enabled; then
1659 if [[ -n "$DEBUG" ]]; then
1660 enable_debug
"Enabling DEBUG from '.bootstrap'"
1665 # We do this in order to protect the case where DEBUG
1666 if ! $env_debug_enabled; then