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