Sun, 07 Dec 2025 15:45:30 +0100
rename combobox to dropdown
| 156 | 1 | #!/bin/sh |
| 2 | ||
| 573 | 3 | #set( $D = '$' ) |
| 4 | #[[ | |
| 5 | # some utility functions | |
| 6 | isplatform() | |
| 7 | { | |
| 8 | for p in $PLATFORM | |
| 9 | do | |
| 10 | if [ "$p" = "$1" ]; then | |
| 11 | return 0 | |
| 12 | fi | |
| 13 | done | |
| 14 | return 1 | |
| 15 | } | |
| 16 | notisplatform() | |
| 17 | { | |
| 18 | for p in $PLATFORM | |
| 19 | do | |
| 20 | if [ "$p" = "$1" ]; then | |
| 21 | return 1 | |
| 22 | fi | |
| 23 | done | |
| 24 | return 0 | |
| 25 | } | |
| 26 | istoolchain() | |
| 27 | { | |
| 28 | for t in $TOOLCHAIN | |
| 29 | do | |
| 30 | if [ "$t" = "$1" ]; then | |
| 31 | return 0 | |
| 32 | fi | |
| 33 | done | |
| 34 | return 1 | |
| 35 | } | |
| 36 | notistoolchain() | |
| 37 | { | |
| 38 | for t in $TOOLCHAIN | |
| 39 | do | |
| 40 | if [ "$t" = "$1" ]; then | |
| 41 | return 1 | |
| 42 | fi | |
| 43 | done | |
| 44 | return 0 | |
| 45 | } | |
| 46 | ||
| 47 | # clean abort | |
| 48 | abort_configure() | |
| 49 | { | |
| 50 | rm -Rf "$TEMP_DIR" | |
| 51 | exit 1 | |
| 52 | } | |
| 53 | ||
| 54 | # Test for availability of pkg-config | |
| 55 | PKG_CONFIG=`command -v pkg-config` | |
| 56 | : ${PKG_CONFIG:="false"} | |
| 57 | ||
| 58 | # Simple uname based platform detection | |
| 59 | # $PLATFORM is used for platform dependent dependency selection | |
| 60 | OS=`uname -s` | |
| 61 | OS_VERSION=`uname -r` | |
|
607
cfcc3fb12d7d
add support for building shared libraries
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
573
diff
changeset
|
62 | ARCH=`uname -m` |
| 573 | 63 | printf "detect platform... " |
| 64 | if [ "$OS" = "SunOS" ]; then | |
| 65 | PLATFORM="solaris sunos unix svr4" | |
| 66 | elif [ "$OS" = "Linux" ]; then | |
| 67 | PLATFORM="linux unix" | |
| 68 | elif [ "$OS" = "FreeBSD" ]; then | |
| 69 | PLATFORM="freebsd bsd unix" | |
| 70 | elif [ "$OS" = "OpenBSD" ]; then | |
| 71 | PLATFORM="openbsd bsd unix" | |
| 72 | elif [ "$OS" = "NetBSD" ]; then | |
| 73 | PLATFORM="netbsd bsd unix" | |
| 74 | elif [ "$OS" = "Darwin" ]; then | |
| 75 | PLATFORM="macos osx bsd unix" | |
| 76 | elif echo "$OS" | grep -i "MINGW" > /dev/null; then | |
| 77 | PLATFORM="windows mingw" | |
| 78 | fi | |
| 79 | : ${PLATFORM:="unix"} | |
| 80 | ||
| 81 | PLATFORM_NAME=`echo "$PLATFORM" | cut -f1 -d' ' -` | |
| 82 | echo "$PLATFORM_NAME" | |
| 83 | ]]# | |
| 84 | ||
| 85 | # help text | |
| 86 | printhelp() | |
| 87 | { | |
| 88 | echo "Usage: $0 [OPTIONS]..." | |
|
944
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
89 | echo 'Configuration:' |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
90 | #foreach( $cfg in $config ) |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
91 | if true \ |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
92 | #if( $cfg.platform ) |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
93 | && isplatform "${cfg.platform}" \ |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
94 | #end |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
95 | #foreach( $np in $cfg.notList ) |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
96 | && notisplatform "${np}" \ |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
97 | #end |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
98 | ; then |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
99 | : |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
100 | #foreach( $var in $cfg.vars ) |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
101 | #if( $var.overridable ) |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
102 | if test -z "${D}${var.varName}__described__"; then |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
103 | ${var.varName}__described__=1 |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
104 | cat << '__EOF__' |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
105 | ${var.helpText} |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
106 | __EOF__ |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
107 | fi |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
108 | #end |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
109 | #end |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
110 | fi |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
111 | #end |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
112 | cat << '__EOF__' |
| 573 | 113 | |
| 114 | Build Types: | |
| 115 | --debug add extra compile flags for debug builds | |
| 116 | --release add extra compile flags for release builds | |
| 117 | #if( $options.size() > 0 ) | |
| 118 | ||
| 119 | Options: | |
| 120 | #foreach( $opt in $options ) | |
|
944
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
121 | ${opt.helpText} |
| 573 | 122 | #end |
| 123 | #end | |
| 124 | #if( $features.size() > 0 ) | |
| 125 | ||
| 126 | Optional Features: | |
| 127 | #foreach( $feature in $features ) | |
| 128 | ${feature.helpText} | |
| 129 | #end | |
| 130 | #end | |
| 131 | ||
| 132 | __EOF__ | |
|
944
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
133 | abort_configure |
| 573 | 134 | } |
| 135 | ||
| 277 | 136 | # create temporary directory |
| 137 | TEMP_DIR=".tmp-`uname -n`" | |
| 138 | rm -Rf "$TEMP_DIR" | |
| 139 | if mkdir -p "$TEMP_DIR"; then | |
| 140 | : | |
| 141 | else | |
| 142 | echo "Cannot create tmp dir $TEMP_DIR" | |
| 143 | echo "Abort" | |
| 144 | exit 1 | |
| 145 | fi | |
| 146 | touch "$TEMP_DIR/options" | |
| 147 | touch "$TEMP_DIR/features" | |
| 148 | ||
|
944
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
149 | # config variables |
| 573 | 150 | #foreach( $cfg in $config ) |
| 151 | if true \ | |
| 152 | #if( $cfg.platform ) | |
| 153 | && isplatform "${cfg.platform}" \ | |
| 154 | #end | |
| 155 | #foreach( $np in $cfg.notList ) | |
| 156 | && notisplatform "${np}" \ | |
|
158
4bde241c49b1
update build system
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
156
diff
changeset
|
157 | #end |
| 573 | 158 | ; then |
|
944
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
159 | : |
| 573 | 160 | #foreach( $var in $cfg.vars ) |
|
944
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
161 | if test -z "${D}${var.varName}__initialized__"; then |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
162 | ${var.varName}__initialized__=1 |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
163 | #if( $var.exec ) |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
164 | ${var.varName}=`${var.value}` |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
165 | #else |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
166 | ${var.varName}='${var.value}' |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
167 | #end |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
168 | fi |
| 573 | 169 | #end |
| 170 | fi | |
|
158
4bde241c49b1
update build system
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
156
diff
changeset
|
171 | #end |
| 156 | 172 | |
| 277 | 173 | # features |
| 174 | #foreach( $feature in $features ) | |
| 175 | #if( ${feature.auto} ) | |
| 176 | ${feature.varName}=auto | |
|
158
4bde241c49b1
update build system
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
156
diff
changeset
|
177 | #end |
|
4bde241c49b1
update build system
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
156
diff
changeset
|
178 | #end |
|
4bde241c49b1
update build system
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
156
diff
changeset
|
179 | |
| 156 | 180 | # |
| 277 | 181 | # parse arguments |
| 156 | 182 | # |
| 277 | 183 | BUILD_TYPE="default" |
| 184 | for ARG in "$@" | |
| 156 | 185 | do |
|
158
4bde241c49b1
update build system
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
156
diff
changeset
|
186 | case "$ARG" in |
|
944
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
187 | #foreach( $var in $vars ) |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
188 | #if ($var.overridable) |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
189 | "--${var.arg}="*) ${var.varName}=${D}{ARG#--${var.arg}=} ;; |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
190 | #end |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
191 | #end |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
192 | "--help"*) printhelp ;; |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
193 | "--debug") BUILD_TYPE="debug" ;; |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
194 | "--release") BUILD_TYPE="release" ;; |
| 277 | 195 | #foreach( $opt in $options ) |
|
944
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
196 | "--${opt.arg}="*) ${opt.varName}=${D}{ARG#--${opt.arg}=} ;; |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
197 | "--${opt.arg}") echo "option '$ARG' needs a value:"; echo " $ARG=${opt.valuesString}"; abort_configure ;; |
| 156 | 198 | #end |
| 277 | 199 | #foreach( $feature in $features ) |
| 200 | "--enable-${feature.arg}") ${feature.varName}=on ;; | |
| 201 | "--disable-${feature.arg}") unset ${feature.varName} ;; | |
| 202 | #end | |
| 203 | "-"*) echo "unknown option: $ARG"; abort_configure ;; | |
| 204 | esac | |
| 156 | 205 | done |
| 206 | ||
|
944
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
207 | # toolchain detection utilities |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
208 | . make/toolchain.sh |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
209 | |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
210 | # check languages |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
211 | lang_c= |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
212 | lang_cpp= |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
213 | #foreach( $lang in $languages ) |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
214 | if detect_${lang}_compiler ; then |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
215 | lang_${lang}=1 |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
216 | fi |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
217 | #end |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
218 | |
| 277 | 219 | ## Begin unparsed content. ** |
| 220 | #[[ | |
| 221 | ||
| 222 | # set defaults for dir variables | |
| 223 | : ${exec_prefix:="$prefix"} | |
| 224 | : ${bindir:='${exec_prefix}/bin'} | |
| 225 | : ${sbindir:='${exec_prefix}/sbin'} | |
| 226 | : ${libdir:='${exec_prefix}/lib'} | |
| 227 | : ${libexecdir:='${exec_prefix}/libexec'} | |
| 228 | : ${datarootdir:='${prefix}/share'} | |
| 229 | : ${datadir:='${datarootdir}'} | |
| 230 | : ${sharedstatedir:='${prefix}/com'} | |
|
944
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
231 | if [ -z "$sysconfdir" ]; then |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
232 | if [ "$prefix" = '/usr' ]; then |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
233 | sysconfdir='/etc' |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
234 | else |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
235 | sysconfdir='${prefix}/etc' |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
236 | fi |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
237 | fi |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
238 | if [ -z "$localstatedir" ]; then |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
239 | if [ "$prefix" = '/usr' ]; then |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
240 | localstatedir='/var' |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
241 | else |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
242 | localstatedir='${prefix}/var' |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
243 | fi |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
244 | fi |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
245 | if [ -z "$runstatedir" ]; then |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
246 | if [ "$prefix" = '/usr' ]; then |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
247 | runstatedir='/var/run' |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
248 | else |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
249 | runstatedir='${prefix}/var' |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
250 | fi |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
251 | fi |
| 277 | 252 | : ${includedir:='${prefix}/include'} |
| 253 | : ${infodir:='${datarootdir}/info'} | |
| 254 | : ${mandir:='${datarootdir}/man'} | |
| 255 | : ${localedir:='${datarootdir}/locale'} | |
| 256 | ||
|
607
cfcc3fb12d7d
add support for building shared libraries
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
573
diff
changeset
|
257 | |
| 277 | 258 | # check if a config.site exists and load it |
|
944
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
259 | CONFIG_SITE_OK=0 |
| 277 | 260 | if [ -n "$CONFIG_SITE" ]; then |
| 261 | # CONFIG_SITE may contain space separated file names | |
| 262 | for cs in $CONFIG_SITE; do | |
| 263 | printf "loading defaults from $cs... " | |
|
944
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
264 | if [ -f "$cs" ]; then |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
265 | . "$cs" |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
266 | echo ok |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
267 | CONFIG_SITE_OK=1 |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
268 | break |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
269 | else |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
270 | echo "not found" |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
271 | fi |
| 277 | 272 | done |
| 273 | elif [ -f "$prefix/share/config.site" ]; then | |
| 274 | printf "loading site defaults... " | |
| 275 | . "$prefix/share/config.site" | |
| 276 | echo ok | |
|
944
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
277 | CONFIG_SITE_OK=1 |
| 277 | 278 | elif [ -f "$prefix/etc/config.site" ]; then |
| 279 | printf "loading site defaults... " | |
| 280 | . "$prefix/etc/config.site" | |
| 281 | echo ok | |
|
944
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
282 | CONFIG_SITE_OK=1 |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
283 | fi |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
284 | |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
285 | if [ $CONFIG_SITE_OK -eq 0 ]; then |
|
607
cfcc3fb12d7d
add support for building shared libraries
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
573
diff
changeset
|
286 | # try to detect the correct libdir on our own, except it was changed by the user |
|
944
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
287 | if [ "$libdir" = '${exec_prefix}/lib' ] ; then |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
288 | if [ "$TOOLCHAIN_WSIZE" = "64" ] ; then |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
289 | if [ "$OS" = "SunOS" ]; then |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
290 | [ -d "${exec_prefix}/lib/64" ] && libdir='${exec_prefix}/lib/64' |
|
607
cfcc3fb12d7d
add support for building shared libraries
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
573
diff
changeset
|
291 | else |
|
944
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
292 | [ -d "${exec_prefix}/lib64" ] && libdir='${exec_prefix}/lib64' |
|
607
cfcc3fb12d7d
add support for building shared libraries
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
573
diff
changeset
|
293 | fi |
|
944
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
294 | elif [ "$TOOLCHAIN_WSIZE" = "32" ] ; then |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
295 | if [ "$OS" = "SunOS" ]; then |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
296 | [ -d "${exec_prefix}/lib/32" ] && libdir='${exec_prefix}/lib/32' |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
297 | else |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
298 | [ -d "${exec_prefix}/lib32" ] && libdir='${exec_prefix}/lib32' |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
299 | fi |
|
607
cfcc3fb12d7d
add support for building shared libraries
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
573
diff
changeset
|
300 | fi |
|
cfcc3fb12d7d
add support for building shared libraries
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
573
diff
changeset
|
301 | fi |
| 156 | 302 | fi |
| 277 | 303 | ]]# |
| 304 | ## End of unparsed content ** | |
|
158
4bde241c49b1
update build system
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
156
diff
changeset
|
305 | |
| 277 | 306 | # generate vars.mk |
| 307 | cat > "$TEMP_DIR/vars.mk" << __EOF__ | |
| 308 | #foreach( $var in $vars ) | |
| 309 | ${var.varName}=${D}${var.varName} | |
|
158
4bde241c49b1
update build system
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
156
diff
changeset
|
310 | #end |
| 156 | 311 | __EOF__ |
| 312 | ||
| 313 | ||
| 314 | # | |
| 315 | # DEPENDENCIES | |
| 316 | # | |
| 317 | ||
|
944
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
318 | |
| 277 | 319 | |
| 320 | # create buffer for make variables required by dependencies | |
| 321 | echo > "$TEMP_DIR/make.mk" | |
| 322 | ||
| 323 | test_pkg_config() | |
| 156 | 324 | { |
| 277 | 325 | if "$PKG_CONFIG" --exists "$1" ; then : |
| 326 | else return 1 ; fi | |
| 327 | if [ -z "$2" ] || "$PKG_CONFIG" --atleast-version="$2" "$1" ; then : | |
| 328 | else return 1 ; fi | |
| 329 | if [ -z "$3" ] || "$PKG_CONFIG" --exact-version="$3" "$1" ; then : | |
| 330 | else return 1 ; fi | |
| 331 | if [ -z "$4" ] || "$PKG_CONFIG" --max-version="$4" "$1" ; then : | |
| 332 | else return 1 ; fi | |
| 333 | return 0 | |
| 334 | } | |
| 335 | ||
| 336 | print_check_msg() | |
| 337 | { | |
| 338 | if [ -z "$1" ]; then | |
| 339 | shift | |
| 340 | printf "$@" | |
| 341 | fi | |
| 342 | } | |
| 343 | ||
| 344 | #foreach( $dependency in $namedDependencies ) | |
| 345 | dependency_error_${dependency.id}() | |
| 346 | { | |
| 347 | print_check_msg "${D}dep_checked_${dependency.id}" "checking for ${dependency.name}... " | |
| 348 | #foreach( $sub in $dependency.subdependencies ) | |
| 349 | # dependency $sub.fullName | |
| 156 | 350 | while true |
| 351 | do | |
| 277 | 352 | #if( $sub.platform ) |
| 353 | if notisplatform "${sub.platform}"; then | |
| 354 | break | |
| 355 | fi | |
| 356 | #end | |
| 357 | #if( $sub.toolchain ) | |
| 358 | if notistoolchain "${sub.toolchain}"; then | |
| 359 | break | |
| 360 | fi | |
| 361 | #end | |
| 362 | #foreach( $np in $sub.notList ) | |
| 363 | if isplatform "${np}" || istoolchain "${np}"; then | |
| 156 | 364 | break |
| 365 | fi | |
| 277 | 366 | #end |
| 367 | #foreach( $lang in $sub.lang ) | |
| 368 | if [ -z "$lang_${lang}" ] ; then | |
|
158
4bde241c49b1
update build system
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
156
diff
changeset
|
369 | break |
|
4bde241c49b1
update build system
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
156
diff
changeset
|
370 | fi |
| 277 | 371 | #end |
| 156 | 372 | #if( $sub.pkgconfig.size() > 0 ) |
|
158
4bde241c49b1
update build system
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
156
diff
changeset
|
373 | if [ -z "$PKG_CONFIG" ]; then |
| 277 | 374 | break |
| 375 | fi | |
| 376 | #end | |
| 377 | #foreach( $test in $sub.tests ) | |
|
944
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
378 | if $test > /dev/null 2>&1 ; then |
| 277 | 379 | : |
| 380 | else | |
| 381 | break | |
| 156 | 382 | fi |
| 383 | #end | |
| 384 | #foreach( $pkg in $sub.pkgconfig ) | |
| 277 | 385 | if test_pkg_config "$pkg.name" "$pkg.atleast" "$pkg.exact" "$pkg.max" ; then |
| 386 | TEMP_CFLAGS="$TEMP_CFLAGS `"$PKG_CONFIG" --cflags $pkg.name`" | |
| 387 | TEMP_LDFLAGS="$TEMP_LDFLAGS `"$PKG_CONFIG" --libs $pkg.name`" | |
| 388 | else | |
| 156 | 389 | break |
| 390 | fi | |
| 391 | #end | |
| 392 | #foreach( $flags in $sub.flags ) | |
| 393 | #if( $flags.exec ) | |
| 277 | 394 | if tmp_flags=`$flags.value` ; then |
| 395 | TEMP_$flags.varName="$TEMP_$flags.varName $tmp_flags" | |
| 156 | 396 | else |
| 397 | break | |
| 398 | fi | |
| 399 | #else | |
| 277 | 400 | TEMP_$flags.varName="$TEMP_$flags.varName $flags.value" |
| 156 | 401 | #end |
| 402 | #end | |
| 277 | 403 | #if ( $sub.make.length() > 0 ) |
| 404 | cat >> $TEMP_DIR/make.mk << __EOF__ | |
| 405 | # Dependency: $dependency.name | |
|
158
4bde241c49b1
update build system
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
156
diff
changeset
|
406 | $sub.make |
|
4bde241c49b1
update build system
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
156
diff
changeset
|
407 | __EOF__ |
|
4bde241c49b1
update build system
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
156
diff
changeset
|
408 | #end |
| 277 | 409 | print_check_msg "${D}dep_checked_${dependency.id}" "yes\n" |
| 410 | dep_checked_${dependency.id}=1 | |
| 411 | return 1 | |
| 156 | 412 | done |
| 277 | 413 | |
| 414 | #end | |
| 415 | print_check_msg "${D}dep_checked_${dependency.id}" "no\n" | |
| 416 | dep_checked_${dependency.id}=1 | |
| 417 | return 0 | |
| 156 | 418 | } |
| 419 | #end | |
| 420 | ||
| 277 | 421 | # start collecting dependency information |
| 422 | echo > "$TEMP_DIR/flags.mk" | |
| 423 | ||
| 156 | 424 | DEPENDENCIES_FAILED= |
| 425 | ERROR=0 | |
| 426 | #if( $dependencies.size() > 0 ) | |
| 277 | 427 | # unnamed dependencies |
| 573 | 428 | TEMP_CFLAGS="$CFLAGS" |
| 429 | TEMP_CXXFLAGS="$CXXFLAGS" | |
| 430 | TEMP_LDFLAGS="$LDFLAGS" | |
| 156 | 431 | #foreach( $dependency in $dependencies ) |
| 432 | while true | |
| 433 | do | |
| 277 | 434 | #if( $dependency.platform ) |
| 435 | if notisplatform "${dependency.platform}"; then | |
| 436 | break | |
| 437 | fi | |
| 438 | #end | |
| 439 | #if( $dependency.toolchain ) | |
| 440 | if notistoolchain "${dependency.toolchain}"; then | |
| 156 | 441 | break |
| 442 | fi | |
| 443 | #end | |
| 277 | 444 | #foreach( $np in $dependency.notList ) |
| 445 | if isplatform "${np}" || istoolchain "${np}"; then | |
|
158
4bde241c49b1
update build system
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
156
diff
changeset
|
446 | break |
|
4bde241c49b1
update build system
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
156
diff
changeset
|
447 | fi |
| 277 | 448 | #end |
| 156 | 449 | while true |
| 450 | do | |
| 277 | 451 | #foreach( $lang in $dependency.lang ) |
| 452 | if [ -z "$lang_${lang}" ] ; then | |
| 453 | ERROR=1 | |
| 454 | break | |
| 455 | fi | |
| 456 | #end | |
| 156 | 457 | #if( $dependency.pkgconfig.size() > 0 ) |
|
158
4bde241c49b1
update build system
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
156
diff
changeset
|
458 | if [ -z "$PKG_CONFIG" ]; then |
| 156 | 459 | ERROR=1 |
| 460 | break | |
| 461 | fi | |
| 462 | #end | |
| 463 | #foreach( $pkg in $dependency.pkgconfig ) | |
| 277 | 464 | print_check_msg "${D}dep_pkgconfig_checked_${pkg.id}" "checking for pkg-config package $pkg.name... " |
| 465 | if test_pkg_config "$pkg.name" "$pkg.atleast" "$pkg.exact" "$pkg.max" ; then | |
| 466 | print_check_msg "${D}dep_pkgconfig_checked_${pkg.id}" "yes\n" | |
| 467 | dep_pkgconfig_checked_${pkg.id}=1 | |
| 468 | TEMP_CFLAGS="$TEMP_CFLAGS `"$PKG_CONFIG" --cflags $pkg.name`" | |
| 469 | TEMP_LDFLAGS="$TEMP_LDFLAGS `"$PKG_CONFIG" --libs $pkg.name`" | |
| 470 | else | |
| 471 | print_check_msg "${D}dep_pkgconfig_checked_${pkg.id}" "no\n" | |
| 472 | dep_pkgconfig_checked_${pkg.id}=1 | |
| 156 | 473 | ERROR=1 |
| 474 | break | |
| 475 | fi | |
| 476 | #end | |
| 277 | 477 | |
| 156 | 478 | #foreach( $flags in $dependency.flags ) |
| 479 | #if( $flags.exec ) | |
| 277 | 480 | if tmp_flags=`$flags.value` ; then |
| 481 | TEMP_$flags.varName="$TEMP_$flags.varName $tmp_flags" | |
| 156 | 482 | else |
| 483 | ERROR=1 | |
| 484 | break | |
| 485 | fi | |
| 486 | #else | |
| 277 | 487 | TEMP_$flags.varName="$TEMP_$flags.varName $flags.value" |
|
158
4bde241c49b1
update build system
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
156
diff
changeset
|
488 | #end |
| 156 | 489 | #end |
| 277 | 490 | #if ( $dependency.make.length() > 0 ) |
| 491 | cat >> "$TEMP_DIR/make.mk" << __EOF__ | |
|
158
4bde241c49b1
update build system
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
156
diff
changeset
|
492 | $dependency.make |
|
4bde241c49b1
update build system
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
156
diff
changeset
|
493 | __EOF__ |
| 156 | 494 | #end |
| 495 | break | |
| 496 | done | |
| 497 | break | |
| 498 | done | |
| 499 | #end | |
| 500 | ||
| 573 | 501 | # build type |
| 502 | if [ "$BUILD_TYPE" = "debug" ]; then | |
|
607
cfcc3fb12d7d
add support for building shared libraries
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
573
diff
changeset
|
503 | TEMP_CFLAGS="\${DEBUG_CFLAGS} $TEMP_CFLAGS" |
|
cfcc3fb12d7d
add support for building shared libraries
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
573
diff
changeset
|
504 | TEMP_CXXFLAGS="\${DEBUG_CXXFLAGS} $TEMP_CXXFLAGS" |
| 573 | 505 | fi |
| 506 | if [ "$BUILD_TYPE" = "release" ]; then | |
|
607
cfcc3fb12d7d
add support for building shared libraries
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
573
diff
changeset
|
507 | TEMP_CFLAGS="\${RELEASE_CFLAGS} $TEMP_CFLAGS" |
|
cfcc3fb12d7d
add support for building shared libraries
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
573
diff
changeset
|
508 | TEMP_CXXFLAGS="\${RELEASE_CXXFLAGS} $TEMP_CXXFLAGS" |
| 573 | 509 | fi |
| 510 | ||
| 277 | 511 | # add general dependency flags to flags.mk |
| 512 | echo "# general flags" >> "$TEMP_DIR/flags.mk" | |
| 513 | if [ -n "${TEMP_CFLAGS}" ] && [ -n "$lang_c" ]; then | |
| 514 | echo "CFLAGS += $TEMP_CFLAGS" >> "$TEMP_DIR/flags.mk" | |
| 156 | 515 | fi |
| 277 | 516 | if [ -n "${TEMP_CXXFLAGS}" ] && [ -n "$lang_cpp" ]; then |
| 517 | echo "CXXFLAGS += $TEMP_CXXFLAGS" >> "$TEMP_DIR/flags.mk" | |
| 156 | 518 | fi |
| 277 | 519 | if [ -n "${TEMP_LDFLAGS}" ]; then |
| 520 | echo "LDFLAGS += $TEMP_LDFLAGS" >> "$TEMP_DIR/flags.mk" | |
| 156 | 521 | fi |
| 522 | #end | |
| 523 | ||
| 524 | # | |
| 525 | # OPTION VALUES | |
| 526 | # | |
| 527 | #foreach( $opt in $options ) | |
| 528 | #foreach( $val in $opt.values ) | |
| 529 | ${val.func}() | |
| 530 | { | |
| 277 | 531 | VERR=0 |
| 532 | #foreach( $dep in $val.dependencies ) | |
| 533 | if dependency_error_$dep ; then | |
| 534 | VERR=1 | |
| 535 | fi | |
| 536 | #end | |
| 537 | if [ $VERR -ne 0 ]; then | |
| 538 | return 1 | |
| 539 | fi | |
| 540 | #foreach( $def in $val.defines ) | |
| 541 | TEMP_CFLAGS="$TEMP_CFLAGS ${def.toFlags()}" | |
| 542 | TEMP_CXXFLAGS="$TEMP_CXXFLAGS ${def.toFlags()}" | |
| 543 | #end | |
| 544 | #if( $val.hasMake() ) | |
| 545 | cat >> "$TEMP_DIR/make.mk" << __EOF__ | |
| 156 | 546 | $val.make |
| 547 | __EOF__ | |
| 277 | 548 | #end |
| 549 | return 0 | |
| 156 | 550 | } |
| 551 | #end | |
| 552 | #end | |
| 553 | ||
| 554 | # | |
| 555 | # TARGETS | |
| 556 | # | |
| 557 | ||
| 558 | #foreach( $target in $targets ) | |
| 277 | 559 | echo >> "$TEMP_DIR/flags.mk" |
| 156 | 560 | #if ( $target.name ) |
| 277 | 561 | echo "configuring target: $target.name" |
| 562 | echo "# flags for target $target.name" >> "$TEMP_DIR/flags.mk" | |
| 156 | 563 | #else |
| 277 | 564 | echo "configuring global target" |
| 565 | echo "# flags for unnamed target" >> "$TEMP_DIR/flags.mk" | |
| 156 | 566 | #end |
| 277 | 567 | TEMP_CFLAGS= |
| 568 | TEMP_CXXFLAGS= | |
| 569 | TEMP_LDFLAGS= | |
| 156 | 570 | |
| 571 | #foreach( $dependency in $target.dependencies ) | |
| 277 | 572 | if dependency_error_$dependency; then |
| 573 | DEPENDENCIES_FAILED="$DEPENDENCIES_FAILED ${dependency} " | |
| 574 | ERROR=1 | |
| 156 | 575 | fi |
| 576 | #end | |
| 577 | ||
|
158
4bde241c49b1
update build system
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
156
diff
changeset
|
578 | # Features |
|
4bde241c49b1
update build system
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
156
diff
changeset
|
579 | #foreach( $feature in $target.features ) |
| 277 | 580 | if [ -n "${D}${feature.varName}" ]; then |
|
158
4bde241c49b1
update build system
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
156
diff
changeset
|
581 | #foreach( $dependency in $feature.dependencies ) |
| 277 | 582 | # check dependency |
| 583 | if dependency_error_$dependency ; then | |
| 584 | # "auto" features can fail and are just disabled in this case | |
| 585 | if [ "${D}${feature.varName}" = "auto" ]; then | |
| 586 | DISABLE_${feature.varName}=1 | |
| 587 | else | |
| 588 | DEPENDENCIES_FAILED="$DEPENDENCIES_FAILED ${dependency} " | |
| 589 | ERROR=1 | |
| 590 | fi | |
| 591 | fi | |
|
158
4bde241c49b1
update build system
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
156
diff
changeset
|
592 | #end |
| 277 | 593 | if [ -n "$DISABLE_${feature.varName}" ]; then |
| 594 | unset ${feature.varName} | |
| 595 | fi | |
|
158
4bde241c49b1
update build system
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
156
diff
changeset
|
596 | fi |
| 573 | 597 | if [ -n "${D}${feature.varName}" ]; then |
| 598 | : | |
| 599 | #foreach( $def in $feature.defines ) | |
| 600 | TEMP_CFLAGS="$TEMP_CFLAGS ${def.toFlags()}" | |
| 601 | TEMP_CXXFLAGS="$TEMP_CXXFLAGS ${def.toFlags()}" | |
| 602 | #end | |
| 603 | #if( $feature.hasMake() ) | |
| 604 | cat >> "$TEMP_DIR/make.mk" << __EOF__ | |
| 605 | $feature.make | |
| 606 | __EOF__ | |
| 607 | #end | |
| 608 | else | |
| 609 | : | |
| 610 | #foreach( $def in $feature.disabled.defines ) | |
| 611 | TEMP_CFLAGS="$TEMP_CFLAGS ${def.toFlags()}" | |
| 612 | TEMP_CXXFLAGS="$TEMP_CXXFLAGS ${def.toFlags()}" | |
| 613 | #end | |
| 614 | #if( $feature.disabled.hasMake() ) | |
| 615 | cat >> "$TEMP_DIR/make.mk" << __EOF__ | |
| 616 | $feature.disabled.make | |
| 617 | __EOF__ | |
| 618 | #end | |
| 619 | #foreach( $dependency in $feature.disabled.dependencies ) | |
| 620 | if dependency_error_$dependency ; then | |
| 621 | DEPENDENCIES_FAILED="$DEPENDENCIES_FAILED ${dependency} " | |
| 622 | ERROR=1 | |
| 623 | fi | |
| 624 | #end | |
| 625 | fi | |
|
158
4bde241c49b1
update build system
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
156
diff
changeset
|
626 | #end |
|
4bde241c49b1
update build system
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
156
diff
changeset
|
627 | |
| 156 | 628 | #foreach( $opt in $target.options ) |
|
944
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
629 | # Option: --${opt.arg} |
| 277 | 630 | if [ -z "${D}${opt.varName}" ]; then |
|
944
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
631 | echo "auto-detecting option '${opt.arg}'" |
| 277 | 632 | SAVED_ERROR="$ERROR" |
| 633 | SAVED_DEPENDENCIES_FAILED="$DEPENDENCIES_FAILED" | |
| 634 | ERROR=1 | |
| 635 | while true | |
| 636 | do | |
| 637 | #foreach( $optdef in $opt.defaults ) | |
| 638 | #if( $optdef.platform ) | |
| 639 | if isplatform "$optdef.platform"; then | |
| 640 | #end | |
| 641 | if $optdef.func ; then | |
|
944
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
642 | echo " ${opt.arg}: ${optdef.valueName}" >> "$TEMP_DIR/options" |
| 277 | 643 | ERROR=0 |
| 644 | break | |
| 645 | fi | |
| 646 | #if( $optdef.platform ) | |
| 647 | fi | |
| 648 | #end | |
| 649 | #end | |
| 650 | break | |
| 651 | done | |
| 652 | if [ $ERROR -ne 0 ]; then | |
| 653 | SAVED_ERROR=1 | |
|
944
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
654 | SAVED_DEPENDENCIES_FAILED="option '${opt.arg}' $SAVED_DEPENDENCIES_FAILED" |
| 277 | 655 | fi |
| 656 | ERROR="$SAVED_ERROR" | |
| 657 | DEPENDENCIES_FAILED="$SAVED_DEPENDENCIES_FAILED" | |
| 156 | 658 | else |
|
944
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
659 | echo "checking option ${opt.arg} = ${D}${opt.varName}" |
| 277 | 660 | if false; then |
| 661 | false | |
| 662 | #foreach( $optval in $opt.values ) | |
| 663 | elif [ "${D}${opt.varName}" = "${optval.value}" ]; then | |
|
944
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
664 | echo " ${opt.arg}: ${D}${opt.varName}" >> $TEMP_DIR/options |
| 277 | 665 | if $optval.func ; then |
| 666 | : | |
| 667 | else | |
| 668 | ERROR=1 | |
|
944
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
669 | DEPENDENCIES_FAILED="option '${opt.arg}' $DEPENDENCIES_FAILED" |
| 277 | 670 | fi |
| 671 | #end | |
| 573 | 672 | else |
| 673 | echo | |
| 674 | echo "Invalid option value - usage:" | |
|
944
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
675 | echo " --${opt.arg}=${opt.valuesString}" |
| 573 | 676 | abort_configure |
| 277 | 677 | fi |
| 156 | 678 | fi |
| 679 | #end | |
| 680 | ||
| 277 | 681 | if [ -n "${TEMP_CFLAGS}" ] && [ -n "$lang_c" ]; then |
| 682 | echo "${target.cFlags} += $TEMP_CFLAGS" >> "$TEMP_DIR/flags.mk" | |
| 683 | fi | |
| 684 | if [ -n "${TEMP_CXXFLAGS}" ] && [ -n "$lang_cpp" ]; then | |
| 685 | echo "${target.cxxFlags} += $TEMP_CXXFLAGS" >> "$TEMP_DIR/flags.mk" | |
| 156 | 686 | fi |
| 277 | 687 | if [ -n "${TEMP_LDFLAGS}" ]; then |
| 688 | echo "${target.ldFlags} += $TEMP_LDFLAGS" >> "$TEMP_DIR/flags.mk" | |
| 156 | 689 | fi |
| 690 | ||
| 691 | #end | |
| 277 | 692 | |
| 693 | # final result | |
| 156 | 694 | if [ $ERROR -ne 0 ]; then |
| 277 | 695 | echo |
| 696 | echo "Error: Unresolved dependencies" | |
| 697 | echo "$DEPENDENCIES_FAILED" | |
| 698 | abort_configure | |
| 156 | 699 | fi |
| 700 | ||
| 701 | echo "configure finished" | |
| 702 | echo | |
|
944
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
703 | echo "Toolchain:" |
|
607
cfcc3fb12d7d
add support for building shared libraries
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
573
diff
changeset
|
704 | echo " name: $TOOLCHAIN_NAME" |
|
cfcc3fb12d7d
add support for building shared libraries
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
573
diff
changeset
|
705 | if [ -n "$TOOLCHAIN_CC" ]; then |
|
cfcc3fb12d7d
add support for building shared libraries
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
573
diff
changeset
|
706 | echo " cc: $TOOLCHAIN_CC" |
|
cfcc3fb12d7d
add support for building shared libraries
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
573
diff
changeset
|
707 | fi |
|
cfcc3fb12d7d
add support for building shared libraries
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
573
diff
changeset
|
708 | if [ -n "$TOOLCHAIN_CXX" ]; then |
|
cfcc3fb12d7d
add support for building shared libraries
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
573
diff
changeset
|
709 | echo " cxx: $TOOLCHAIN_CXX" |
|
cfcc3fb12d7d
add support for building shared libraries
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
573
diff
changeset
|
710 | fi |
|
cfcc3fb12d7d
add support for building shared libraries
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
573
diff
changeset
|
711 | if [ -n "$TOOLCHAIN_WSIZE" ]; then |
|
cfcc3fb12d7d
add support for building shared libraries
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
573
diff
changeset
|
712 | echo " word size: $TOOLCHAIN_WSIZE bit" |
|
cfcc3fb12d7d
add support for building shared libraries
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
573
diff
changeset
|
713 | fi |
|
cfcc3fb12d7d
add support for building shared libraries
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
573
diff
changeset
|
714 | if [ -n "$TOOLCHAIN_CSTD" ]; then |
|
cfcc3fb12d7d
add support for building shared libraries
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
573
diff
changeset
|
715 | echo " default C std: $TOOLCHAIN_CSTD" |
|
cfcc3fb12d7d
add support for building shared libraries
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
573
diff
changeset
|
716 | fi |
|
cfcc3fb12d7d
add support for building shared libraries
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
573
diff
changeset
|
717 | echo |
|
944
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
718 | echo "Config:" |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
719 | #foreach( $var in $vars ) |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
720 | #if ($var.overridable) |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
721 | printf ' %-16s' '${var.arg}:' |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
722 | echo "${D}${var.varName}" |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
723 | #end |
|
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
724 | #end |
| 156 | 725 | #if ( $options.size() > 0 ) |
|
607
cfcc3fb12d7d
add support for building shared libraries
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
573
diff
changeset
|
726 | echo |
| 156 | 727 | echo "Options:" |
| 277 | 728 | cat "$TEMP_DIR/options" |
| 729 | #end | |
| 730 | #if ( $features.size() > 0 ) | |
|
607
cfcc3fb12d7d
add support for building shared libraries
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
573
diff
changeset
|
731 | echo |
| 277 | 732 | echo "Features:" |
| 733 | #foreach( $feature in $features ) | |
|
944
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
734 | printf ' %-16s' '$feature.name:' |
| 277 | 735 | if [ -n "${D}${feature.varName}" ]; then |
|
944
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
736 | echo 'on' |
| 277 | 737 | else |
|
944
cc23aad6335e
move message handler to ui common
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
607
diff
changeset
|
738 | echo 'off' |
| 277 | 739 | fi |
| 740 | #end | |
| 156 | 741 | #end |
| 742 | echo | |
| 743 | ||
| 277 | 744 | # generate the config.mk file |
| 573 | 745 | pwd=`pwd` |
| 277 | 746 | cat > "$TEMP_DIR/config.mk" << __EOF__ |
| 747 | # | |
| 573 | 748 | # config.mk generated by: |
| 749 | # pwd: $pwd | |
| 750 | # $0 $@ | |
| 277 | 751 | # |
| 156 | 752 | |
| 277 | 753 | __EOF__ |
| 754 | write_toolchain_defaults "$TEMP_DIR/toolchain.mk" | |
| 573 | 755 | cat "$TEMP_DIR/config.mk" "$TEMP_DIR/vars.mk" "$TEMP_DIR/toolchain.mk" "$TEMP_DIR/flags.mk" "$TEMP_DIR/make.mk" > config.mk |
| 277 | 756 | rm -Rf "$TEMP_DIR" |