Mon, 19 May 2025 13:58:19 +0200
make charts identifiable with a query - fixes #608
| 0 | 1 | #!/bin/sh |
| 2 | ||
| 3 | ||
| 4 | # some utility functions | |
| 5 | isplatform() | |
| 6 | { | |
| 7 | for p in $PLATFORM | |
| 8 | do | |
| 9 | if [ "$p" = "$1" ]; then | |
| 10 | return 0 | |
| 11 | fi | |
| 12 | done | |
| 13 | return 1 | |
| 14 | } | |
| 15 | notisplatform() | |
| 16 | { | |
| 17 | for p in $PLATFORM | |
| 18 | do | |
| 19 | if [ "$p" = "$1" ]; then | |
| 20 | return 1 | |
| 21 | fi | |
| 22 | done | |
| 23 | return 0 | |
| 24 | } | |
| 25 | istoolchain() | |
| 26 | { | |
| 27 | for t in $TOOLCHAIN | |
| 28 | do | |
| 29 | if [ "$t" = "$1" ]; then | |
| 30 | return 0 | |
| 31 | fi | |
| 32 | done | |
| 33 | return 1 | |
| 34 | } | |
| 35 | notistoolchain() | |
| 36 | { | |
| 37 | for t in $TOOLCHAIN | |
| 38 | do | |
| 39 | if [ "$t" = "$1" ]; then | |
| 40 | return 1 | |
| 41 | fi | |
| 42 | done | |
| 43 | return 0 | |
| 44 | } | |
| 45 | ||
| 46 | # clean abort | |
| 47 | abort_configure() | |
| 48 | { | |
| 49 | rm -Rf "$TEMP_DIR" | |
| 50 | exit 1 | |
| 51 | } | |
| 52 | ||
| 53 | # Test for availability of pkg-config | |
| 54 | PKG_CONFIG=`command -v pkg-config` | |
| 55 | : ${PKG_CONFIG:="false"} | |
| 56 | ||
| 57 | # Simple uname based platform detection | |
| 58 | # $PLATFORM is used for platform dependent dependency selection | |
| 59 | OS=`uname -s` | |
| 60 | OS_VERSION=`uname -r` | |
| 61 | printf "detect platform... " | |
| 62 | if [ "$OS" = "SunOS" ]; then | |
| 63 | PLATFORM="solaris sunos unix svr4" | |
| 64 | elif [ "$OS" = "Linux" ]; then | |
| 65 | PLATFORM="linux unix" | |
| 66 | elif [ "$OS" = "FreeBSD" ]; then | |
| 67 | PLATFORM="freebsd bsd unix" | |
| 68 | elif [ "$OS" = "OpenBSD" ]; then | |
| 69 | PLATFORM="openbsd bsd unix" | |
| 70 | elif [ "$OS" = "NetBSD" ]; then | |
| 71 | PLATFORM="netbsd bsd unix" | |
| 72 | elif [ "$OS" = "Darwin" ]; then | |
| 73 | PLATFORM="macos osx bsd unix" | |
| 74 | elif echo "$OS" | grep -i "MINGW" > /dev/null; then | |
| 75 | PLATFORM="windows mingw" | |
| 76 | fi | |
| 77 | : ${PLATFORM:="unix"} | |
| 78 | ||
| 79 | PLATFORM_NAME=`echo "$PLATFORM" | cut -f1 -d' ' -` | |
| 80 | echo "$PLATFORM_NAME" | |
| 81 | ||
| 82 | ||
| 83 | # help text | |
| 84 | printhelp() | |
| 85 | { | |
| 86 | echo "Usage: $0 [OPTIONS]..." | |
| 87 | cat << __EOF__ | |
| 88 | Installation directories: | |
| 89 | --prefix=PREFIX path prefix for architecture-independent files | |
| 90 | [$prefix] | |
| 91 | --exec-prefix=EPREFIX path prefix for architecture-dependent files | |
| 92 | [PREFIX] | |
| 93 | ||
| 94 | --bindir=DIR user executables [EPREFIX/bin] | |
| 95 | --sbindir=DIR system admin executables [EPREFIX/sbin] | |
| 96 | --libexecdir=DIR program executables [EPREFIX/libexec] | |
| 97 | --sysconfdir=DIR system configuration files [PREFIX/etc] | |
| 98 | --sharedstatedir=DIR modifiable architecture-independent data [PREFIX/com] | |
| 99 | --localstatedir=DIR modifiable single-machine data [PREFIX/var] | |
| 100 | --runstatedir=DIR run-time variable data [LOCALSTATEDIR/run] | |
| 101 | --libdir=DIR object code libraries [EPREFIX/lib] | |
| 102 | --includedir=DIR C header files [PREFIX/include] | |
| 103 | --datarootdir=DIR read-only arch.-independent data root [PREFIX/share] | |
| 104 | --datadir=DIR read-only architecture-independent data [DATAROOTDIR] | |
| 105 | --infodir=DIR info documentation [DATAROOTDIR/info] | |
| 106 | --mandir=DIR man documentation [DATAROOTDIR/man] | |
| 107 | --localedir=DIR locale-dependent data [DATAROOTDIR/locale] | |
| 108 | ||
| 109 | Build Types: | |
| 45 | 110 | --debug add extra compile flags for debug builds |
| 111 | --release add extra compile flags for release builds | |
| 0 | 112 | |
|
34
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
113 | Optional Features: |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
114 | --enable-static statically link libstdc++ |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
115 | |
| 0 | 116 | __EOF__ |
| 117 | } | |
| 118 | ||
| 119 | # create temporary directory | |
| 120 | TEMP_DIR=".tmp-`uname -n`" | |
| 121 | rm -Rf "$TEMP_DIR" | |
| 122 | if mkdir -p "$TEMP_DIR"; then | |
| 123 | : | |
| 124 | else | |
| 125 | echo "Cannot create tmp dir $TEMP_DIR" | |
| 126 | echo "Abort" | |
| 127 | exit 1 | |
| 128 | fi | |
| 129 | touch "$TEMP_DIR/options" | |
| 130 | touch "$TEMP_DIR/features" | |
| 131 | ||
| 132 | # define standard variables | |
| 133 | # also define standard prefix (this is where we will search for config.site) | |
| 134 | prefix=/usr | |
| 135 | exec_prefix= | |
| 136 | bindir= | |
| 137 | sbindir= | |
| 138 | libdir= | |
| 139 | libexecdir= | |
| 140 | datarootdir= | |
| 141 | datadir= | |
| 142 | sysconfdir= | |
| 143 | sharedstatedir= | |
| 144 | localstatedir= | |
| 145 | runstatedir= | |
| 146 | includedir= | |
| 147 | infodir= | |
| 148 | localedir= | |
| 149 | mandir= | |
| 150 | ||
| 151 | # custom variables | |
| 152 | ||
| 153 | # features | |
| 154 | ||
| 155 | # | |
| 156 | # parse arguments | |
| 157 | # | |
| 158 | BUILD_TYPE="default" | |
| 159 | for ARG in "$@" | |
| 160 | do | |
| 161 | case "$ARG" in | |
| 162 | "--prefix="*) prefix=${ARG#--prefix=} ;; | |
| 163 | "--exec-prefix="*) exec_prefix=${ARG#--exec-prefix=} ;; | |
| 164 | "--bindir="*) bindir=${ARG#----bindir=} ;; | |
| 165 | "--sbindir="*) sbindir=${ARG#--sbindir=} ;; | |
| 166 | "--libdir="*) libdir=${ARG#--libdir=} ;; | |
| 167 | "--libexecdir="*) libexecdir=${ARG#--libexecdir=} ;; | |
| 168 | "--datarootdir="*) datarootdir=${ARG#--datarootdir=} ;; | |
| 169 | "--datadir="*) datadir=${ARG#--datadir=} ;; | |
| 170 | "--sysconfdir="*) sysconfdir=${ARG#--sysconfdir=} ;; | |
| 171 | "--sharedstatedir="*) sharedstatedir=${ARG#--sharedstatedir=} ;; | |
| 172 | "--localstatedir="*) localstatedir=${ARG#--localstatedir=} ;; | |
| 173 | "--includedir="*) includedir=${ARG#--includedir=} ;; | |
| 174 | "--infodir="*) infodir=${ARG#--infodir=} ;; | |
| 175 | "--mandir"*) mandir=${ARG#--mandir} ;; | |
| 176 | "--localedir"*) localedir=${ARG#--localedir} ;; | |
| 177 | "--help"*) printhelp; abort_configure ;; | |
| 178 | "--debug") BUILD_TYPE="debug" ;; | |
| 179 | "--release") BUILD_TYPE="release" ;; | |
|
34
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
180 | "--enable-static") FEATURE_STATIC=on ;; |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
181 | "--disable-static") unset FEATURE_STATIC ;; |
| 0 | 182 | "-"*) echo "unknown option: $ARG"; abort_configure ;; |
| 183 | esac | |
| 184 | done | |
| 185 | ||
| 186 | ||
| 187 | ||
| 188 | # set defaults for dir variables | |
| 189 | : ${exec_prefix:="$prefix"} | |
| 190 | : ${bindir:='${exec_prefix}/bin'} | |
| 191 | : ${sbindir:='${exec_prefix}/sbin'} | |
| 192 | : ${libdir:='${exec_prefix}/lib'} | |
| 193 | : ${libexecdir:='${exec_prefix}/libexec'} | |
| 194 | : ${datarootdir:='${prefix}/share'} | |
| 195 | : ${datadir:='${datarootdir}'} | |
| 196 | : ${sysconfdir:='${prefix}/etc'} | |
| 197 | : ${sharedstatedir:='${prefix}/com'} | |
| 198 | : ${localstatedir:='${prefix}/var'} | |
| 199 | : ${runstatedir:='${localstatedir}/run'} | |
| 200 | : ${includedir:='${prefix}/include'} | |
| 201 | : ${infodir:='${datarootdir}/info'} | |
| 202 | : ${mandir:='${datarootdir}/man'} | |
| 203 | : ${localedir:='${datarootdir}/locale'} | |
| 204 | ||
| 45 | 205 | # remember the above values and compare them later |
| 206 | orig_bindir="$bindir" | |
| 207 | orig_sbindir="$sbindir" | |
| 208 | orig_libdir="$libdir" | |
| 209 | orig_libexecdir="$libexecdir" | |
| 210 | orig_datarootdir="$datarootdir" | |
| 211 | orig_datadir="$datadir" | |
| 212 | orig_sysconfdir="$sysconfdir" | |
| 213 | orig_sharedstatedir="$sharedstatedir" | |
| 214 | orig_localstatedir="$localstatedir" | |
| 215 | orig_runstatedir="$runstatedir" | |
| 216 | orig_includedir="$includedir" | |
| 217 | orig_infodir="$infodir" | |
| 218 | orig_mandir="$mandir" | |
| 219 | orig_localedir="$localedir" | |
| 220 | ||
| 0 | 221 | # check if a config.site exists and load it |
| 222 | if [ -n "$CONFIG_SITE" ]; then | |
| 223 | # CONFIG_SITE may contain space separated file names | |
| 224 | for cs in $CONFIG_SITE; do | |
| 225 | printf "loading defaults from $cs... " | |
| 226 | . "$cs" | |
| 227 | echo ok | |
| 228 | done | |
| 229 | elif [ -f "$prefix/share/config.site" ]; then | |
| 230 | printf "loading site defaults... " | |
| 231 | . "$prefix/share/config.site" | |
| 232 | echo ok | |
| 233 | elif [ -f "$prefix/etc/config.site" ]; then | |
| 234 | printf "loading site defaults... " | |
| 235 | . "$prefix/etc/config.site" | |
| 236 | echo ok | |
| 237 | fi | |
| 238 | ||
| 239 | ||
| 240 | # generate vars.mk | |
| 241 | cat > "$TEMP_DIR/vars.mk" << __EOF__ | |
| 242 | prefix=$prefix | |
| 243 | exec_prefix=$exec_prefix | |
| 244 | bindir=$bindir | |
| 245 | sbindir=$sbindir | |
| 246 | libdir=$libdir | |
| 247 | libexecdir=$libexecdir | |
| 248 | datarootdir=$datarootdir | |
| 249 | datadir=$datadir | |
| 250 | sysconfdir=$sysconfdir | |
| 251 | sharedstatedir=$sharedstatedir | |
| 252 | localstatedir=$localstatedir | |
| 253 | runstatedir=$runstatedir | |
| 254 | includedir=$includedir | |
| 255 | infodir=$infodir | |
| 256 | mandir=$mandir | |
| 257 | localedir=$localedir | |
| 258 | __EOF__ | |
| 259 | ||
| 260 | # toolchain detection utilities | |
| 261 | . make/toolchain.sh | |
| 262 | ||
| 263 | # | |
| 264 | # DEPENDENCIES | |
| 265 | # | |
| 266 | ||
| 267 | # check languages | |
| 268 | lang_c= | |
| 269 | lang_cpp= | |
| 270 | if detect_cpp_compiler ; then | |
| 271 | lang_cpp=1 | |
| 272 | fi | |
| 273 | ||
| 274 | # create buffer for make variables required by dependencies | |
| 275 | echo > "$TEMP_DIR/make.mk" | |
| 276 | ||
| 277 | test_pkg_config() | |
| 278 | { | |
| 279 | if "$PKG_CONFIG" --exists "$1" ; then : | |
| 280 | else return 1 ; fi | |
| 281 | if [ -z "$2" ] || "$PKG_CONFIG" --atleast-version="$2" "$1" ; then : | |
| 282 | else return 1 ; fi | |
| 283 | if [ -z "$3" ] || "$PKG_CONFIG" --exact-version="$3" "$1" ; then : | |
| 284 | else return 1 ; fi | |
| 285 | if [ -z "$4" ] || "$PKG_CONFIG" --max-version="$4" "$1" ; then : | |
| 286 | else return 1 ; fi | |
| 287 | return 0 | |
| 288 | } | |
| 289 | ||
| 290 | print_check_msg() | |
| 291 | { | |
| 292 | if [ -z "$1" ]; then | |
| 293 | shift | |
| 294 | printf "$@" | |
| 295 | fi | |
| 296 | } | |
| 297 | ||
|
34
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
298 | dependency_error_static() |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
299 | { |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
300 | print_check_msg "$dep_checked_static" "checking for static... " |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
301 | # dependency static toolchain="gcc" |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
302 | while true |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
303 | do |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
304 | if notistoolchain "gcc"; then |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
305 | break |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
306 | fi |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
307 | TEMP_LDFLAGS="$TEMP_LDFLAGS -static" |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
308 | print_check_msg "$dep_checked_static" "yes\n" |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
309 | dep_checked_static=1 |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
310 | return 1 |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
311 | done |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
312 | |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
313 | # dependency static toolchain="clang" |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
314 | while true |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
315 | do |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
316 | if notistoolchain "clang"; then |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
317 | break |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
318 | fi |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
319 | TEMP_LDFLAGS="$TEMP_LDFLAGS -static" |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
320 | print_check_msg "$dep_checked_static" "yes\n" |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
321 | dep_checked_static=1 |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
322 | return 1 |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
323 | done |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
324 | |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
325 | print_check_msg "$dep_checked_static" "no\n" |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
326 | dep_checked_static=1 |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
327 | return 0 |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
328 | } |
| 0 | 329 | |
| 330 | # start collecting dependency information | |
| 331 | echo > "$TEMP_DIR/flags.mk" | |
| 332 | ||
| 333 | DEPENDENCIES_FAILED= | |
| 334 | ERROR=0 | |
| 335 | # unnamed dependencies | |
| 336 | TEMP_CFLAGS="$CFLAGS" | |
| 337 | TEMP_CXXFLAGS="$CXXFLAGS" | |
| 338 | TEMP_LDFLAGS="$LDFLAGS" | |
| 339 | while true | |
| 340 | do | |
| 341 | while true | |
| 342 | do | |
| 343 | if [ -z "$lang_cpp" ] ; then | |
| 344 | ERROR=1 | |
| 345 | break | |
| 346 | fi | |
| 347 | ||
|
10
bf159cf9f4b6
improve heatmap::add() by using C++23 ranges-v3
Mike Becker <universe@uap-core.de>
parents:
5
diff
changeset
|
348 | TEMP_CXXFLAGS="$TEMP_CXXFLAGS -std=c++23" |
| 0 | 349 | break |
| 350 | done | |
| 351 | break | |
| 352 | done | |
| 353 | ||
| 45 | 354 | # build type |
| 355 | if [ "$BUILD_TYPE" = "debug" ]; then | |
| 356 | TEMP_CFLAGS="\${DEBUG_CFLAGS} $TEMP_CFLAGS" | |
| 357 | TEMP_CXXFLAGS="\${DEBUG_CXXFLAGS} $TEMP_CXXFLAGS" | |
| 358 | fi | |
| 359 | if [ "$BUILD_TYPE" = "release" ]; then | |
| 360 | TEMP_CFLAGS="\${RELEASE_CFLAGS} $TEMP_CFLAGS" | |
| 361 | TEMP_CXXFLAGS="\${RELEASE_CXXFLAGS} $TEMP_CXXFLAGS" | |
| 362 | fi | |
| 363 | ||
| 0 | 364 | # add general dependency flags to flags.mk |
| 365 | echo "# general flags" >> "$TEMP_DIR/flags.mk" | |
| 366 | if [ -n "${TEMP_CFLAGS}" ] && [ -n "$lang_c" ]; then | |
| 367 | echo "CFLAGS += $TEMP_CFLAGS" >> "$TEMP_DIR/flags.mk" | |
| 368 | fi | |
| 369 | if [ -n "${TEMP_CXXFLAGS}" ] && [ -n "$lang_cpp" ]; then | |
| 370 | echo "CXXFLAGS += $TEMP_CXXFLAGS" >> "$TEMP_DIR/flags.mk" | |
| 371 | fi | |
| 372 | if [ -n "${TEMP_LDFLAGS}" ]; then | |
| 373 | echo "LDFLAGS += $TEMP_LDFLAGS" >> "$TEMP_DIR/flags.mk" | |
| 374 | fi | |
| 375 | ||
| 376 | # | |
| 377 | # OPTION VALUES | |
| 378 | # | |
| 379 | ||
| 380 | # | |
| 381 | # TARGETS | |
| 382 | # | |
| 383 | ||
| 384 | echo >> "$TEMP_DIR/flags.mk" | |
|
34
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
385 | echo "configuring global target" |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
386 | echo "# flags for unnamed target" >> "$TEMP_DIR/flags.mk" |
| 0 | 387 | TEMP_CFLAGS= |
| 388 | TEMP_CXXFLAGS= | |
| 389 | TEMP_LDFLAGS= | |
| 390 | ||
| 391 | ||
| 392 | # Features | |
|
34
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
393 | if [ -n "$FEATURE_STATIC" ]; then |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
394 | # check dependency |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
395 | if dependency_error_static ; then |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
396 | # "auto" features can fail and are just disabled in this case |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
397 | if [ "$FEATURE_STATIC" = "auto" ]; then |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
398 | DISABLE_FEATURE_STATIC=1 |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
399 | else |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
400 | DEPENDENCIES_FAILED="$DEPENDENCIES_FAILED static " |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
401 | ERROR=1 |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
402 | fi |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
403 | fi |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
404 | if [ -n "$DISABLE_FEATURE_STATIC" ]; then |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
405 | unset FEATURE_STATIC |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
406 | fi |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
407 | fi |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
408 | if [ -n "$FEATURE_STATIC" ]; then |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
409 | : |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
410 | else |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
411 | : |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
412 | fi |
| 0 | 413 | |
| 414 | ||
| 415 | if [ -n "${TEMP_CFLAGS}" ] && [ -n "$lang_c" ]; then | |
| 416 | echo "CFLAGS += $TEMP_CFLAGS" >> "$TEMP_DIR/flags.mk" | |
| 417 | fi | |
| 418 | if [ -n "${TEMP_CXXFLAGS}" ] && [ -n "$lang_cpp" ]; then | |
| 419 | echo "CXXFLAGS += $TEMP_CXXFLAGS" >> "$TEMP_DIR/flags.mk" | |
| 420 | fi | |
| 421 | if [ -n "${TEMP_LDFLAGS}" ]; then | |
| 422 | echo "LDFLAGS += $TEMP_LDFLAGS" >> "$TEMP_DIR/flags.mk" | |
| 423 | fi | |
| 424 | ||
| 425 | ||
| 426 | # final result | |
| 427 | if [ $ERROR -ne 0 ]; then | |
| 428 | echo | |
| 429 | echo "Error: Unresolved dependencies" | |
| 430 | echo "$DEPENDENCIES_FAILED" | |
| 431 | abort_configure | |
| 432 | fi | |
| 433 | ||
| 434 | echo "configure finished" | |
| 435 | echo | |
| 45 | 436 | echo "Toolchain" |
| 437 | echo " name: $TOOLCHAIN_NAME" | |
| 438 | if [ -n "$TOOLCHAIN_CC" ]; then | |
| 439 | echo " cc: $TOOLCHAIN_CC" | |
| 440 | fi | |
| 441 | if [ -n "$TOOLCHAIN_CXX" ]; then | |
| 442 | echo " cxx: $TOOLCHAIN_CXX" | |
| 443 | fi | |
| 444 | if [ -n "$TOOLCHAIN_WSIZE" ]; then | |
| 445 | echo " word size: $TOOLCHAIN_WSIZE bit" | |
| 446 | fi | |
| 447 | if [ -n "$TOOLCHAIN_CSTD" ]; then | |
| 448 | echo " default C std: $TOOLCHAIN_CSTD" | |
| 449 | fi | |
| 450 | echo | |
| 0 | 451 | echo "Build Config:" |
| 45 | 452 | echo " prefix: $prefix" |
| 453 | echo " exec_prefix: $exec_prefix" | |
| 454 | if [ "$orig_bindir" != "$bindir" ]; then | |
| 455 | echo " bindir: $bindir" | |
| 456 | fi | |
| 457 | if [ "$orig_sbindir" != "$sbindir" ]; then | |
| 458 | echo " sbindir: $sbindir" | |
| 459 | fi | |
| 460 | if [ "$orig_libdir" != "$libdir" ]; then | |
| 461 | echo " libdir: $libdir" | |
| 462 | fi | |
| 463 | if [ "$orig_libexecdir" != "$libexecdir" ]; then | |
| 464 | echo " libexecdir: $libexecdir" | |
| 465 | fi | |
| 466 | if [ "$orig_datarootdir" != "$datarootdir" ]; then | |
| 467 | echo " datarootdir: $datarootdir" | |
| 468 | fi | |
| 469 | if [ "$orig_datadir" != "$datadir" ]; then | |
| 470 | echo " datadir: $datadir" | |
| 471 | fi | |
| 472 | if [ "$orig_sysconfdir" != "$sysconfdir" ]; then | |
| 473 | echo " sysconfdir: $sysconfdir" | |
| 474 | fi | |
| 475 | if [ "$orig_sharedstatedir" != "$sharedstatedir" ]; then | |
| 476 | echo " sharedstatedir: $sharedstatedir" | |
| 477 | fi | |
| 478 | if [ "$orig_localstatedir" != "$localstatedir" ]; then | |
| 479 | echo " localstatedir: $localstatedir" | |
| 480 | fi | |
| 481 | if [ "$orig_runstatedir" != "$runstatedir" ]; then | |
| 482 | echo " runstatedir: $runstatedir" | |
| 483 | fi | |
| 484 | if [ "$orig_includedir" != "$includedir" ]; then | |
| 485 | echo " includedir: $includedir" | |
| 486 | fi | |
| 487 | if [ "$orig_infodir" != "$infodir" ]; then | |
| 488 | echo " infodir: $infodir" | |
| 489 | fi | |
| 490 | if [ "$orig_mandir" != "$mandir" ]; then | |
| 491 | echo " mandir: $mandir" | |
| 492 | fi | |
| 493 | if [ "$orig_localedir" != "$localedir" ]; then | |
| 494 | echo " localedir: $localedir" | |
| 495 | fi | |
| 496 | echo | |
|
34
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
497 | echo "Features:" |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
498 | if [ -n "$FEATURE_STATIC" ]; then |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
499 | echo " static: on" |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
500 | else |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
501 | echo " static: off" |
|
cc9d74d5eb46
add configure option for static linking
Mike Becker <universe@uap-core.de>
parents:
10
diff
changeset
|
502 | fi |
| 0 | 503 | echo |
| 504 | ||
| 505 | # generate the config.mk file | |
| 45 | 506 | pwd=`pwd` |
| 0 | 507 | cat > "$TEMP_DIR/config.mk" << __EOF__ |
| 508 | # | |
| 45 | 509 | # config.mk generated by: |
| 510 | # pwd: $pwd | |
| 511 | # $0 $@ | |
| 0 | 512 | # |
| 513 | ||
| 514 | __EOF__ | |
| 515 | write_toolchain_defaults "$TEMP_DIR/toolchain.mk" | |
| 45 | 516 | cat "$TEMP_DIR/config.mk" "$TEMP_DIR/vars.mk" "$TEMP_DIR/toolchain.mk" "$TEMP_DIR/flags.mk" "$TEMP_DIR/make.mk" > config.mk |
| 0 | 517 | rm -Rf "$TEMP_DIR" |