]> git.saurik.com Git - wxWidgets.git/blob - wx-config.in
correct to int32 for range comparison
[wxWidgets.git] / wx-config.in
1 #!/bin/sh
2 #
3 # Name: wx-config{.in,}
4 # Purpose: wx configuration search and query tool {template,}
5 # Author: Ron <ron@debian.org>
6 # Modified by:
7 # Created: 8/9/2004
8 # RCS-ID: $Id$
9 # Copyright: (c) 2004 Ron <ron@debian.org>
10 # Essentially a fresh start this time around, but for maximum
11 # compatibility basic code was taken from, and heavy reference
12 # made to, the previously unattributed wx-config from cvs.
13 # All the usual suspects contributed to the dicussion that led
14 # to this new work and likewise to the ideas and content in the
15 # original (which was probably influenced by gtk), among them:
16 # Robert Roebling, Vadim Zeitlin, Vaclav Slavik, Robin Dunn
17 # Licence: wxWindows licence
18 ############################################################################
19
20 # We expect a posix shell, so if this is a Bourne shell,
21 # and apparently a few still exist, try for bash or ksh.
22
23 if [ ~ = '~' ]
24 then
25 if (bash -c echo) >/dev/null 2>&1
26 then
27 exec bash "$0" "$@"
28 fi
29 if (ksh -c echo) >/dev/null 2>&1
30 then
31 exec ksh "$0" "$@"
32 fi
33 echo "$0: this script requires bash or ksh"
34 exit 1
35 fi
36
37
38 # On with some basic stuff, like the ability to die gracefully,
39 # and to tell people what we are about.
40 # ------------------------------------------------------------------
41
42 # decho _message
43 # Output a message to stderr.
44 decho() { echo "$*" 1>&2; }
45
46 # usage _exitcode
47 # Outputs a usage message to stderr and exits with _exitcode.
48 # Try to keep this to a single page (ie. < 25 lines). We can add
49 # alternate or interactive help targets if people want more detail.
50 #
51 # Exit codes are now subject to a more strict interpretation.
52 # wx-config should return 0 upon successful operation, 1 if the
53 # reqested operation could not be completed successfully, and 2
54 # if the requested operation is not supported by this version of
55 # wx-config.
56 usage()
57 {
58 cat 1>&2 <<EOF
59
60 wx-config [--prefix[=DIR]] [--exec-prefix[=DIR]] [--release] [--version-full]
61 [--list] [--host=HOST] [--toolkit=TOOLKIT] [--universal[=yes|no]]
62 [--unicode[=yes|no]] [--debug[=yes|no]] [--static[=yes|no]]
63 [--version[=VERSION]] [--basename] [--cc] [--cppflags] [--cflags]
64 [--cxxflags] [--rezflags] [--libs] [--cxx] [--ld] [--linkdeps]
65 [--utility=UTIL] [LIB ...]
66
67 wx-config returns information about the wxWidgets libraries available
68 on your system. It may be used to retrieve the information you require
69 to build applications using these libraries.
70
71 If alternative builds of wxWidgets exist on the system, you can use the
72 options: --prefix, --host, --toolkit, --unicode, --debug, --static,
73 --version and --universal, to select from them. Use the --list option to
74 show alternatives available which match specified criteria. The unicode,
75 debug, and universal options take an optional yes or no argument, while
76 host and version accept posix extended regex. The --utility option will
77 return the correct version of UTIL to use with the selected library build.
78 --linkdeps returns only static libraries for your makefile link rule deps.
79
80 Optional LIB arguments (comma or space separated) may be used to specify
81 the wxWidgets libraries that you wish to use. The magic "std" label may
82 be used to import all libraries that would be used by default if none were
83 specified explicitly. eg. wx-config --libs core,base.
84
85 EOF
86
87 exit $1
88 }
89
90 # Unfussy people are the easiest to deal with, get them out of the way now.
91 [ $# -gt 0 ] || usage 1
92
93
94
95 # For the people who know what they want, or think they do:
96 # Divide the valid arguments into functional groups for later examination,
97 # then parse all command line arguments completely, deferring action on
98 # output options until all significant input has been processed and any
99 # decision about delegation has been taken.
100
101 # Note early, that '-' is a complete no-no for use in option names below.
102 # It totally falls apart as soon as it becomes part of a variable name.
103 # Use '_' instead, and by the magic of it all just being bits, you'll
104 # be able to use --my-option or --my_option from the command line at
105 # your discretion. They are synonymous as user input, but _ALWAYS_ use
106 # underscores for compound names in the code here, never a dash.
107
108
109 # The list of all options we recognise. If it is not in here, then
110 # it is not something we want to handle.
111 # ------------------------------------------------------------------
112
113 # Options that specify a distinct library build.
114 #
115 # Note also that order in this list is significant later on, as this sets
116 # the precedence with which we will try to gauge the similarity of other
117 # configs to this one. Options earlier in the list should be more crucial
118 # to match well than those that follow. Options specified by the user will
119 # always take precedence and are not subject to any partial ordering here.
120 wxconfig_schema="host toolkit widgetset chartype debugtype flavour version linkage"
121
122 # Options that are expected to generate some output.
123 wxconfig_output_options="prefix exec_prefix
124 list
125 release version version_full
126 basename
127 cppflags cflags cxxflags
128 rezflags
129 libs
130 linkdeps
131 cc cxx ld
132 gl_libs"
133
134 # Options that permit the user to supply hints that may affect the output.
135 # These options all accept arbitrary values, to interpret as they please.
136 wxconfig_input_options="prefix exec_prefix utility $wxconfig_schema"
137
138 # Input options that accept only a yes or no argument.
139 wxconfig_yesno_options="universal unicode debug static"
140
141 # Boolean options that do something or not.
142 wxconfig_flag_options="$wxconfig_yesno_options no_rpath inplace"
143
144
145
146 # Some simple sugar coating to keep things more readable below.
147 # --------------------------------------------------------------
148
149 # option_name _string
150 # Returns NAME if _string is of the form: --NAME[=...]
151 option_name()
152 {
153 _option_name_temp=${1%%=*}
154 echo "${_option_name_temp#--}" | tr '-' '_'
155 }
156
157 # option_value _string
158 # Returns FOO if _string is of the form: --option=FOO
159 option_value()
160 {
161 echo "${1#*=}"
162 }
163
164 # match_field _value _list
165 # Returns true if _value is a field in _list
166 match_field()
167 {
168 _match_field_match="$1"
169 shift
170 for _match_field_i; do
171 [ "x$_match_field_i" != "x$_match_field_match" ] || return 0
172 done
173 false
174 }
175
176 # remove_field _value _list
177 # Returns _list minus any field(s) that match _value.
178 remove_field()
179 {
180 _remf_value="$1"
181 _remf_list=''
182 shift
183 if [ -n "$_remf_value" ]; then
184 for _remf_item; do
185 [ "x$_remf_item" = "x$_remf_value" ] ||
186 _remf_list="${_remf_list:+$_remf_list }$_remf_item"
187 done
188 echo "$_remf_list"
189 else
190 echo $*
191 fi
192 }
193
194 # validate_arg _domain _set _name _value
195 # Boilerplate to validate an argument and initialise a psuedo-hash.
196 # This one is almost reduction into absurdity, and perhaps makes the
197 # precise action of the argument parser below just a little more
198 # obscure, but oh so neat and compact to use for multiple option
199 # groups. It expands to replace repetitive clauses of the form:
200 #
201 # i="$(option_name $arg)"
202 # if match_field "$i" $wxconfig_input_options; then
203 # input_options="${input_options:+$input_options }$i"
204 # eval "input_option_$i=$(option_value $arg)"
205 # continue
206 # fi
207 #
208 # with the one liners you see on the page below.
209 validate_arg()
210 {
211 if match_field "$3" $(eval echo \"\$$1_$2_options\"); then
212 eval "$2_options=\"\${$2_options:+\$$2_options }$3\""
213 eval "$2_option_$3=\"$4\""
214 return
215 fi
216 false
217 }
218
219 # check_yesno_option _ynoption _option _yesval _noval
220 # This one might be made more generic and/or incorporated into
221 # validate_arg above at some later stage, but right now we just
222 # condition any specialist options into a generic one for later
223 # handling. Once they are sanity checked there is no difference
224 # in any case.
225 check_yesno_option()
226 {
227 eval "case \${yesno_option_$1-\${flag_option_$1-unset}} in
228 unset) ;;
229 y*|Y*) input_option_$2=\"$3\" ;;
230 n*|N*) input_option_$2=\"$4\" ;;
231 *)
232 decho
233 decho \" *** Error: Invalid request '--$1=\$yesno_option_$1'\"
234 decho \" Valid arguments for --$1 are: [ yes, no ]\"
235 decho
236 exit 1
237 ;;
238 esac"
239 }
240
241
242
243 # Now we are ready to find out what the user wants from us.
244 # --------------------------------------------------------------
245
246 # With just a little more complexity here we could have shortest
247 # unique string matching for options, but that is probably overkill
248 # today, so lets just get the job done.
249 #
250 # The important thing now then is that we simply read all input from
251 # the user and don't try to act prematurely on partial information.
252 # --help or an illegal argument are the only shortcuts out of here
253 # at this point, otherwise, it's time to just shut up and listen for
254 # a moment.
255
256 for arg; do
257 case "$arg" in
258 --help|-h)
259 usage
260 ;;
261
262 --*=*)
263 _name=$(option_name $arg)
264 _value=$(option_value $arg)
265 if validate_arg wxconfig input "$_name" "$_value" ||
266 validate_arg wxconfig yesno "$_name" "$_value"
267 then
268 continue
269 fi
270 ;;
271
272 --*)
273 _name=$(option_name $arg)
274 if validate_arg wxconfig flag "$_name" yes ||
275 validate_arg wxconfig output "$_name" yes
276 then
277 continue
278 fi
279 ;;
280
281 *)
282 # FIXME Surely we can validate the parameters too ...
283 input_parameters="${input_parameters:+$input_parameters }$arg"
284 continue
285 ;;
286 esac
287 decho " *** Error: Unrecognised option: '$arg'"
288 decho "Use wx-config --help for information on command line options."
289 exit 2
290 done
291
292 # validate_arg only checks and decomposes form. Sanity check the yes/no
293 # options now too and push their respective mask values into place.
294
295 check_yesno_option universal widgetset univ
296 check_yesno_option unicode chartype unicode ansi
297 check_yesno_option debug debugtype debug release
298 check_yesno_option static linkage '-static'
299
300
301 # Dump everything we just read in debug mode.
302 if [ -n "$WXDEBUG" ]; then
303
304 decho
305 decho " input parameters = $input_parameters"
306 decho " input options = $input_options"
307 for i in $input_options; do
308 decho " $i = $(eval echo \"\$input_option_$i\")"
309 done
310 decho " yes/no options = $yesno_options"
311 for y in $yesno_options; do
312 decho " $y = $(eval echo \"\$yesno_option_$y\")"
313 done
314 decho " flag options = $flag_options"
315 for f in $flag_options; do
316 decho " $f = $(eval echo \"\$flag_option_$f\")"
317 done
318 decho " output options = $output_options"
319 for o in $output_options; do
320 decho " $o = $(eval echo \"\$output_option_$o\")"
321 done
322
323 fi
324
325
326
327 # Everything came in as a legal argument then, lets put some of
328 # the pieces together with a little self knowledge to see what
329 # we should do next.
330 # --------------------------------------------------------------
331
332 # get_mask [ _hash ]
333 # Construct a config filename mask from a psuedo-hash of component variables.
334 # The optional argument is the prefix of the hash to use. If not specified
335 # this will return a mask derived from the command line options that were used.
336 get_mask()
337 {
338 [ $# -gt 0 ] || set m
339 eval echo "\${$1_host}\${$1_toolkit}\${$1_widgetset}-\${$1_chartype}-\${$1_debugtype}\${$1_linkage}-\${$1_version}\${$1_flavour}"
340 }
341
342
343 # Determine the base directories we require.
344 prefix=${input_option_prefix-${this_prefix:-@prefix@}}
345 exec_prefix=${input_option_exec_prefix-${input_option_prefix-${this_exec_prefix:-@exec_prefix@}}}
346 wxconfdir="@libdir@/wx/config"
347
348 installed_configs=$( cd "$wxconfdir" 2> /dev/null && ls | grep -v "^inplace-" )
349
350 target="@host_alias@"
351
352 # Define a pseudo-hash to contain the specification of this wx-config
353 # instance and its associated library.
354 this_host="${target:+${target}-}"
355 this_toolkit="@TOOLKIT_DIR@@TOOLKIT_VERSION@"
356 this_widgetset="@WIDGET_SET@"
357 this_chartype="@WX_CHARTYPE@"
358 this_debugtype="@WX_DEBUGTYPE@"
359 this_flavour="@WX_FLAVOUR@"
360 this_version="@WX_RELEASE@"
361 this_linkage=$( [ "x@SHARED@" = "x1" ] || echo '-static' )
362
363 this_config=$(get_mask this)
364
365 # Extract the user specification from the options parsed.
366 m_host=${input_option_host:+${input_option_host}-?}
367 m_host=${m_host:-${input_option_host-$this_host}}
368 m_toolkit=${input_option_toolkit:-[^-]+}
369 m_widgetset=${input_option_widgetset-(univ)?}
370 m_chartype=${input_option_chartype:-(unicode|ansi)}
371 m_debugtype=${input_option_debugtype:-(debug|release)}
372 m_flavour=${input_option_flavour:+-$input_option_flavour}
373 m_flavour=${m_flavour:-${input_option_flavour-(-[^-]+)?}}
374 m_version=${input_option_version:-[0-9]+\.[0-9]+}
375 m_linkage=${input_option_linkage-(-static)?}
376
377 configmask="^$(get_mask)$"
378
379
380 # Dump the user specification in debug mode.
381 if [ -n "$WXDEBUG" ]; then
382
383 decho
384 decho " prefix = '$prefix'"
385 decho " exec_prefix = '$exec_prefix'"
386 decho " wxconfdir = '$wxconfdir'"
387
388 decho " m_host = '$m_host'"
389 decho " m_toolkit = '$m_toolkit'"
390 decho " m_widgetset = '$m_widgetset'"
391 decho " m_chartype = '$m_chartype'"
392 decho " m_debugtype = '$m_debugtype'"
393 decho " m_flavour = '$m_flavour'"
394 decho " m_version = '$m_version'"
395 decho " m_linkage = '$m_linkage'"
396
397 decho " configmask = '$configmask'"
398 decho " this config = '$this_config'"
399 decho
400
401 fi
402
403
404
405 # From here on, we'll need to be able to figure out a delegation target.
406 # -----------------------------------------------------------------------
407
408 # The rules for delegation are:
409 #
410 # 1. If the specification is so general that it matches the default config
411 # (ie. this one on a first pass), then the default config will be used
412 # even if other installed libs would also match the spec.
413 #
414 # 2. If the default config does not match, find a list of all installed
415 # libraries that do match.
416 # a. If that list is empty, the specification is incompatible
417 # with any installed lib. Warn and abort.
418 # b. If that list contains exactly one candidate. Delegate to
419 # that candidate.
420 # c. If the list contains multiple candidates, pass on to step 3.
421 #
422 # 3. Attempt to discriminate among rival candidates by their similarity
423 # to the default configuration (ie. this one). If we can find a unique
424 # candidate in this way, delegate to it. If not, present a list of
425 # options to the user and request that they disambiguate it with one or
426 # more additional fields.
427 #
428 # To refine the specified pattern, we specialise each unbound field
429 # using the default value from this config file. If that results in
430 # no matches, we unbind it again and try the next field. If it still
431 # results in multiple matches we try binding the next field as well
432 # until a unique or null result again occurs.
433 #
434 # A more general way to look at this, is the feature specifiers are all
435 # modifiers of the wx-config you are calling. If you supply none, the
436 # default for that build configuration will be used. If you supply one
437 # or more that the default build cannot satisfy, it will try to find the
438 # config most like itself with the desired feature(s) enabled.
439 # The features configured into the first wx-config called will be taken
440 # as implicitly specified if it is necessary to disambiguate likely
441 # candidates from the information that was explicitly provided.
442
443
444 # But first, more sugar to keep what follows clear and legible.
445 # --------------------------------------------------------------
446
447 # find_eligible_delegates _mask
448 # Outputs all the config files installed which match the
449 # (extended regex) _mask passed as an argument.
450 find_eligible_delegates() { echo "$installed_configs" | grep -E "$1" 2> /dev/null; }
451
452 # user_mask_fits _config
453 # Returns true if the string _config satisfies the user specified mask.
454 user_mask_fits() { echo "$1" | grep -E "$configmask" > /dev/null 2>&1; }
455
456 # count_fields _word
457 # Returns the number of IFS split fields in _word
458 count_fields() { return $#; }
459
460 # count_delegates _mask
461 # Return the number of eligible config files that match _mask
462 count_delegates() { count_fields $(find_eligible_delegates $1); }
463
464 # is_set _variablename
465 # Returns true if $_variablename is initialised.
466 is_set() { [ "x$(eval echo \"\${$1-unset}\")" != "xunset" ]; }
467
468 # do_find_best_delegate _unbound-options
469 # The real worker part of find_best_delegate below. Recurses though all
470 # unbound options binding them one at a time to the default derived from
471 # this file until a unique match is made or no alternatives remain that
472 # may be sensibly guessed at. It will preferentially bind the unspecified
473 # options in the order they are listed in wxconfig_schema. Using this
474 # partial ordering it should find the first match with the most significant
475 # similarity to this file that unambiguously meets the user specification.
476 # If such a match exists it will be output to stdout.
477 #
478 # Be careful if you modify this function. If the pruning logic is rendered
479 # inoperative it will simply recurse over every permutation in the search
480 # space, which may still appear to work, but add a couple more options (or
481 # explicitly specify a few less) and you may not live long enough to learn
482 # the result. WXDEBUG=findprogress is your friend here, it will show you
483 # how many nodes get searched before a result. If you start seeing
484 # increases in that number for the same input, check your work.
485 # Raising the number of discriminating options from 6 to 8 raised the worst
486 # case time for this to run (without pruning) from 3 to nearly 15 seconds
487 # and its downhill fast from here if we have to ride that boat.
488 # Early pruning still gets that down to under half a second (up from about
489 # .25), so we have some breathing space yet before a different search method
490 # will be called for, but lets not squander it.
491 do_find_best_delegate()
492 {
493 (
494 if [ "x$WXDEBUG" = "xverbose" ]; then
495 _fbd_indent="${_fbd_indent}. "
496 decho " $_fbd_indent---> unbound options: $*"
497 fi
498
499 for i; do
500
501 if [ "x$WXDEBUG" = "xverbose" ]; then
502 decho " ${_fbd_indent}binding '$i' with '$(remove_field $i $*)' still free"
503 [ -z "$_pruned" ] || decho " ${_fbd_indent} --- pruned: $_pruned ---"
504 fi
505
506 if (
507 eval m_$i=\$this_$i
508 _mask="^$(get_mask)$"
509
510 if [ "x$WXDEBUG" = "xverbose" ]; then
511 decho " ${_fbd_indent} checking: $_mask"
512 count_delegates "$_mask"
513 decho " $_fbd_indent $? eligible delegates"
514 for d in $(find_eligible_delegates "$_mask"); do
515 decho " ${_fbd_indent} $d"
516 done
517 fi
518
519 count_delegates "$_mask"
520 _still_eligible=$?
521
522 if [ $_still_eligible -eq 1 ]; then
523 echo $(find_eligible_delegates "$_mask")
524 return
525 fi
526
527 [ "x$WXDEBUG" != "xfindprogress" ] || printf "." 1>&2
528
529 [ $_still_eligible -gt 1 ] && [ $# -gt 1 ] &&
530 do_find_best_delegate $(remove_field $i $*)
531 )
532 then
533
534 return
535
536 elif [ $# -gt 1 ]; then
537
538 if [ "x$WXDEBUG" = "xverbose" ]; then
539 decho " ${_fbd_indent}pruning: $i"
540 _pruned="${_pruned:+$_pruned }$i"
541 fi
542 set $(remove_field $i $*)
543
544 fi
545
546 done
547 false
548 )
549 }
550
551 # find_best_delegate
552 # A simple wrapper around do_find_best_delegate that first determines
553 # the unbound options (ie. the ones that the user did not explicitly
554 # declare a preference for on the command line)
555 find_best_delegate()
556 {
557 for _fbdi in $wxconfig_schema; do
558 is_set input_option_$_fbdi ||
559 _unbound_options="${_unbound_options:+$_unbound_options }$_fbdi"
560 done
561 do_find_best_delegate $_unbound_options
562 }
563
564
565 # Legacy wx-config helpers.
566 # -------------------------
567
568 # get_legacy_mask
569 # Returns a mask in the format used by wx2.4.
570 get_legacy_mask()
571 {
572 [ $# -gt 0 ] || set m
573 eval [ "x\${$1_chartype}" != "xunicode" ] || _unicode_flag=u
574 eval [ "x\${$1_debugtype}" != "xdebug" ] || _debug_flag=d
575 eval echo "wx\${$1_toolkit}${_unicode_flag}${_debug_flag}-\${$1_version}\${$1_host}-config"
576 }
577
578 # find_legacy_configs
579 # Returns a list of configs installed by wx2.4 releases.
580 find_legacy_configs()
581 {
582 (
583 cd "$prefix/bin" &&
584 {
585 ls wx*-2.4-config | grep -v ^wxbase
586 ls wx*-2.4-config | grep ^wxbase
587 }
588 ) 2> /dev/null
589 }
590
591 # find_best_legacy_config
592 # Returns the best legacy config for a given specification.
593 # This assumes no matching new style config has been found.
594 find_best_legacy_config()
595 {
596 _legacy_configs=$(find_legacy_configs)
597 if [ -n "$_legacy_configs" ]; then
598 _legacy_mask=$(get_legacy_mask)
599 for d in $_legacy_configs; do
600 if echo $d | grep -E $_legacy_mask > /dev/null 2>&1 ; then
601 echo "$d"
602 return
603 fi
604 done
605 fi
606 false
607 }
608
609
610
611 # The only action we can perform authoritatively prior to delegation
612 # is to list all the possible delegates.
613 # --------------------------------------------------------------
614
615 config_spec="$0 $*"
616 [ -z "$WXDEBUG" ] || config_spec=$configmask
617
618 # Next chance for another satisfied customer then
619 #
620 # If we want to get really polished here we can do plural checking,
621 # but we should probably leave that until the day we gettextise it.
622 if [ -n "$output_option_list" ]; then
623
624 _remains_in_prefix=$installed_configs
625 _delegates=$(find_eligible_delegates $configmask)
626 _best_delegate=$(find_best_delegate)
627
628 if [ "x$WXDEBUG" = "xverbose" ]; then
629 decho
630 decho " all = $_remains_in_prefix"
631 decho " matching = $_delegates"
632 decho " best = $_best_delegate"
633 decho " this = $this_config"
634 fi
635
636 for d in $_delegates; do
637 _remains_in_prefix=$(remove_field $d $_remains_in_prefix)
638 done
639
640 echo
641 echo " Default config is $this_config"
642 echo
643
644 if user_mask_fits "$this_config" ; then
645
646 echo " Default config ${this_exec_prefix+in $this_exec_prefix }will be used for output"
647
648 if match_field "$this_config" $_delegates ; then
649 _delegates=$(remove_field $this_config $_delegates)
650 else
651 echo " though it is not installed in: $prefix"
652 if [ -n "$_best_delegate" ] && [ "x$_best_delegate" != "x$this_config" ]; then
653 echo
654 echo " Best alternate in $prefix:"
655 echo " $_best_delegate"
656 fi
657 fi
658
659 elif [ -n "$_best_delegate" ]; then
660
661 echo " Specification best match: $_best_delegate"
662
663 elif [ -z "$_delegates" ]; then
664
665 _last_chance=$(find_best_legacy_config)
666 if [ -n "$_last_chance" ]; then
667
668 echo " Specification matches legacy config: $_last_chance"
669
670 else
671
672 cat <<-EOF
673 No config found to match: $config_spec
674 in $wxconfdir
675
676 Please install the desired library build, or specify a different
677 prefix where it may be found. If the library is not installed
678 you may call its wx-config directly by specifying its full path.
679
680 EOF
681
682 fi
683
684 else
685 echo " Specification was ambiguous. Use additional feature options"
686 echo " to choose between alternate matches."
687 fi
688
689 _delegates=$(remove_field "$_best_delegate" $_delegates)
690
691 if [ -n "$_delegates" ]; then
692 echo
693 echo " Alternate matches:"
694 for d in $_delegates; do
695 echo " $d"
696 done
697 fi
698 if [ -n "$_remains_in_prefix" ]; then
699 echo
700 echo " Also available in $prefix:"
701 for d in $_remains_in_prefix; do
702 echo " $d"
703 done
704 fi
705
706 _legacy_configs=$(find_legacy_configs)
707 if [ -n "$_legacy_configs" ]; then
708 echo
709 echo " Legacy configs available in $prefix:"
710 for d in $_legacy_configs; do
711 echo " ${d%-config}"
712 done
713 fi
714
715 echo
716 exit
717 fi
718
719
720
721 # ... so if that wasn't what they wanted, then we need to know for
722 # certain, can this config satisfy the user specification?
723 # --------------------------------------------------------------
724
725 if ! user_mask_fits "$this_config" ; then
726
727 # No? Then lets see if it knows anybody who can.
728 # But first, just be sure someone hasn't typo'd us into a loop.
729 # In present day wx, correct delegation should never need more
730 # than one hop so this is trivial to detect.
731
732 if [ -n "$WXCONFIG_DELEGATED" ]; then
733 decho
734 decho " *** Error: Bad config delegation"
735 decho
736 decho " to: $0"
737 decho " ($this_config) cannot satisfy:"
738 decho " $config_spec"
739 decho " Someone has been terribly careless."
740 decho
741 exit 1
742 fi
743
744 count_delegates "$configmask"
745 _numdelegates=$?
746
747 if [ -n "$WXDEBUG" ]; then
748 decho " must delegate to an alternate config"
749 decho " potential delegates ($_numdelegates):"
750 for i in $(find_eligible_delegates "$configmask"); do
751 decho " $i"
752 done
753 fi
754
755 if [ $_numdelegates -eq 0 ]; then
756
757 _last_chance=$(find_best_legacy_config)
758 if [ -n "$_last_chance" ]; then
759
760 for arg; do
761 case "$arg" in
762 --prefix*|--exec-prefix*| \
763 --version|--release|--basename| \
764 --static|--libs|--gl_libs| \
765 --cppflags|--cflags|--cxxflags| \
766 --cc|--cxx|--ld| \
767 --rezflags|--inplace)
768 _legacy_args="$_legacy_args $arg"
769 ;;
770
771 --static|--static=y*|--static=Y*)
772 _legacy_args="$_legacy_args --static"
773 ;;
774 esac
775 done
776
777 if [ -n "$WXDEBUG" ]; then
778 decho " found a suitable legacy delegate: $_last_chance"
779 decho "--> $prefix/bin/$_last_chance $_legacy_args"
780 fi
781
782 export WXCONFIG_DELEGATED=yes
783 $prefix/bin/$_last_chance $_legacy_args
784 exit
785
786 else
787
788 cat 1>&2 <<-EOF
789
790 Warning: No config found to match: $config_spec
791 in $wxconfdir
792 If you require this configuration, please install the desired
793 library build. If this is part of an automated configuration
794 test and no other errors occur, you may safely ignore it.
795 You may use wx-config --list to see all configs available in
796 the default prefix.
797
798 EOF
799
800 # PIPEDREAM: This will probably give Vadim an aneurysm if I
801 # mention it out of context, but from here we are actually
802 # just a teensy step from simply building the missing config
803 # for the user on the fly if this is an in tree wx-config.
804
805 exit 1
806 fi
807 fi
808
809 if [ $_numdelegates -gt 1 ]; then
810
811 [ -z "$WXDEBUG" ] || decho " must prune the list of eligible delegates"
812
813 best_delegate=$(find_best_delegate)
814
815 if [ -n "$best_delegate" ]; then
816
817 if [ -n "$WXDEBUG" ]; then
818 decho " found a suitable delegate: $best_delegate"
819 decho "--> $wxconfdir/$best_delegate $*"
820 fi
821
822 export WXCONFIG_DELEGATED=yes
823 $wxconfdir/$best_delegate $*
824 exit
825 fi
826
827 decho
828 decho " *** Error: Specification is ambiguous"
829 decho " as $config_spec"
830 decho " Use additional feature options to choose between:"
831 for i in $(find_eligible_delegates "$configmask"); do
832 decho " $i"
833 done
834 decho
835
836 exit 1
837 fi
838
839 if [ -n "$WXDEBUG" ]; then
840 decho " using the only suitable delegate"
841 decho "--> $wxconfdir/$(find_eligible_delegates $configmask) $*"
842 fi
843
844 export WXCONFIG_DELEGATED=yes
845 $wxconfdir/$(find_eligible_delegates $configmask) $*
846 exit
847 fi
848
849
850
851 # If we are still here, then from now on we are responsible for
852 # all the user's needs. Time to rustle up some output for them.
853 # --------------------------------------------------------------
854
855 [ -z "$WXDEBUG" ] || decho " using this config"
856
857 # If the user supplied a prefix, and the in tree config did not
858 # delegate out to anything in that prefix, then reset the build
859 # tree prefix to provide the correct output for using this
860 # uninstalled wx build. Or put more simply:
861 prefix=${this_prefix-$prefix}
862 exec_prefix=${this_exec_prefix-$exec_prefix}
863
864 includedir="@includedir@"
865 libdir="@libdir@"
866 bindir="@bindir@"
867
868 # Trivial queries we can answer now.
869 [ -z "$output_option_prefix" ] || echo $prefix
870 [ -z "$output_option_exec_prefix" ] || echo $exec_prefix
871 [ -z "$output_option_release" ] || echo "@WX_RELEASE@"
872 [ -z "$output_option_version" ] || echo "@WX_VERSION@"
873 [ -z "$output_option_version_full" ] || echo "@WX_SUBVERSION@"
874 [ -z "$output_option_basename" ] || echo "@WX_LIBRARY_BASENAME_GUI@"
875 [ -z "$output_option_rezflags" ] || echo $(eval echo "@MACRESWXCONFIG@")
876 [ -z "$output_option_cc" ] || echo "@CC@"
877 [ -z "$output_option_cxx" ] || echo "@CXX@"
878 [ -z "$output_option_ld" ] || echo "@EXE_LINKER@"
879
880
881 # The rest are going to need a little more work.
882 # --------------------------------------------------------------
883
884 is_cross() { [ "x@cross_compiling@" = "xyes" ]; }
885 is_monolithic() { [ "x@MONOLITHIC@" = "x1" ]; }
886 is_static() { [ -n "$this_linkage" ]; }
887 is_installed() { [ -z "$this_prefix" ]; }
888
889
890 # Is the user after a support utility?
891 # If this is a cross build, we need to find and return a suitable
892 # native utility for the job, so we search:
893 #
894 # 1. local build dir (for native uninstalled builds only).
895 # 2. (optional) user supplied prefix.
896 # 3. configured install prefix.
897 # 4. environment $PATH.
898 #
899 # and if such a thing still cannot be found, exit signalling an error.
900 if [ -n "$input_option_utility" ]; then
901
902 # This is dumb, in tree binaries should be in a standard location
903 # like the libs, but work with what we've got for now.
904 is_cross || _util="$exec_prefix/utils/$input_option_utility/$input_option_utility"
905
906 if ! is_installed && [ -x "$_util" ]; then
907 is_static || _preload="eval LD_LIBRARY_PATH=$exec_prefix/lib"
908 echo $_preload $_util
909 exit
910 fi
911
912 IFS=':'
913 _user_prefix=${input_option_exec_prefix:-$input_option_prefix}
914
915 for _util in "${input_option_utility}-@WX_RELEASE@@WX_FLAVOUR@" \
916 "${input_option_utility}-@WX_RELEASE@" \
917 "${input_option_utility}"
918 do
919 for p in ${_user_prefix:+$_user_prefix/bin} $bindir $PATH; do
920
921 [ -z "$WXDEBUG" ] || decho " checking for: '$p/$_util'"
922
923 if [ -x "$p/$_util" ]; then
924 echo "$p/$_util"
925 exit
926 fi
927
928 done
929 done
930 exit 1
931
932 fi
933
934
935 # Still here? Then get the options together for building an app.
936 # ----------------------------------------------------------------
937
938 # Additional configuration for individual library components.
939 ldflags_gl="@LDFLAGS_GL@"
940
941 ldlibs_base="@WXCONFIG_EXTRALIBS@"
942 ldlibs_core="@EXTRALIBS_GUI@"
943 ldlibs_gl="@OPENGL_LIBS@"
944 ldlibs_html="@EXTRALIBS_HTML@"
945 ldlibs_xml="@EXTRALIBS_XML@"
946 ldlibs_odbc="@EXTRALIBS_ODBC@"
947 ldlibs_adv="@EXTRALIBS_SDL@"
948
949
950 # lib_flags_for _liblist
951 # This function returns a list of flags suitable to return with the
952 # output of --libs for all of the libraries in _liblist. You can
953 # add support for a new library by adding an entry for it in the
954 # psuedo-hashes above if it requires additional linker options.
955 lib_flags_for()
956 {
957 [ -z "$WXDEBUG" ] || decho " fetching lib flags for: '$*'"
958
959 _all_ldflags=''
960 _all_libs=''
961 _wxlibs=''
962
963 is_cross && _target="-${target}"
964
965 for lib; do
966
967 # We evidently can't trust people not to duplicate things in
968 # configure, or to keep them in any sort of sane order overall,
969 # so only add unique new fields here even if it takes us a while.
970 # In the case of libs, we bubble any duplicates to the end,
971 # because if multiple libs require it, static linking at least
972 # will require it to come after all of them. So long as local
973 # order is ok in configure then we should always be able to
974 # massage a correct result here like this.
975 #
976 # FIXME: ldlibs_core is totally bogus. Fix the duplication
977 # there independently of this. This covers for it, but we
978 # want to do this anyway because some libs may share common
979 # deps without a common ancestor in wx. This is not a licence
980 # for sloppy work elsewhere though and @GUI_TK_LIBRARY should
981 # be fixed.
982
983 for f in $(eval echo \"\$ldflags_$lib\"); do
984 match_field "$f" $_all_ldflags || _all_ldflags="$_all_ldflags $f"
985 done
986
987 if match_field "$lib" @CORE_BASE_LIBS@ ; then
988 _libname="@WX_LIBRARY_BASENAME_NOGUI@"
989 else
990 _libname="@WX_LIBRARY_BASENAME_GUI@"
991 fi
992 [ $lib = base ] || _libname="${_libname}_$lib"
993 _libname="${_libname}-@WX_RELEASE@$_target"
994
995 if is_static; then
996 _wxlibs="$_wxlibs ${libdir}/lib${_libname}.a"
997 for f in $(eval echo \"\$ldlibs_$lib\"); do
998 _all_libs="$(remove_field $f $_all_libs) $f"
999 done
1000 else
1001 _wxlibs="$_wxlibs -l${_libname}"
1002 fi
1003
1004 done
1005
1006 if [ -n "$WXDEBUG" ]; then
1007 decho " retrieved: ldflags = $_all_ldflags"
1008 decho " wxlibs = $_wxlibs"
1009 decho " alllibs = $_all_libs"
1010 fi
1011
1012 echo $_all_ldflags $_wxlibs $_all_libs
1013 }
1014
1015 # this is the strict subset of the above function which returns only the
1016 # (static) libraries themselves: this is used for linkdeps output which should
1017 # output the list of libraries the main program should depend on
1018 #
1019 # of course, this duplication is bad but I'll leave to somebody else the care
1020 # of refactoring this as I don't see any way to do it
1021 link_deps_for()
1022 {
1023 _wxlibs=''
1024
1025 is_cross && _target="-${target}"
1026
1027 for lib; do
1028 if match_field "$lib" @CORE_BASE_LIBS@ ; then
1029 _libname="@WX_LIBRARY_BASENAME_NOGUI@"
1030 else
1031 _libname="@WX_LIBRARY_BASENAME_GUI@"
1032 fi
1033 [ $lib = base ] || _libname="${_libname}_$lib"
1034 _libname="${_libname}-@WX_RELEASE@$_target"
1035
1036 _wxlibs="$_wxlibs ${libdir}/lib${_libname}.a"
1037 done
1038
1039 echo $_wxlibs
1040 }
1041
1042 # Sanity check the list of libs the user provided us, if any.
1043 # --------------------------------------------------------------
1044
1045 wx_libs=$(echo "$input_parameters" | tr ',' ' ')
1046
1047 [ -z "$WXDEBUG" ] || decho " user supplied libs: '$wx_libs'"
1048
1049 if is_monolithic; then
1050
1051 # Core libs are already built into the blob.
1052 for i in std @CORE_GUI_LIBS@ @CORE_BASE_LIBS@; do
1053 wx_libs=$(remove_field $i $wx_libs)
1054 done
1055
1056 wx_libs="@WXCONFIG_LDFLAGS_GUI@ $(lib_flags_for $wx_libs)"
1057
1058 # We still need the core lib deps for a static build though
1059 if is_static; then
1060 link_deps="${libdir}/libwx_@TOOLCHAIN_NAME@.a"
1061 wx_libs="$wx_libs $link_deps $ldlibs_core @LIBS@"
1062 else
1063 wx_libs="$wx_libs -lwx_@TOOLCHAIN_NAME@"
1064 fi
1065
1066 using_gui=yes
1067
1068 else # MONOLITHIC = 0
1069
1070 # Import everything by default, expand std if specified, or add base if omitted.
1071 if [ -z "$wx_libs" ]; then
1072 wx_libs="@CORE_GUI_LIBS@ @CORE_BASE_LIBS@"
1073 elif match_field std $wx_libs; then
1074 # Bubble any libs that were already specified to the end
1075 # of the list and ensure static linking order is retained.
1076 wx_libs=$(remove_field std $wx_libs)
1077 for i in @CORE_GUI_LIBS@ @CORE_BASE_LIBS@; do
1078 wx_libs="$(remove_field $i $wx_libs) $i"
1079 done
1080 elif ! match_field base $wx_libs ; then
1081 wx_libs="$wx_libs base"
1082 fi
1083
1084 using_gui=no
1085 for i in $wx_libs ; do
1086 if match_field "$i" @CORE_GUI_LIBS@ ; then
1087 _guildflags="@WXCONFIG_LDFLAGS_GUI@"
1088 using_gui=yes
1089 break
1090 fi
1091 match_field "$i" @CORE_BASE_LIBS@ || using_gui=yes
1092 done
1093
1094 if is_static; then
1095 link_deps=$(link_deps_for $wx_libs)
1096 fi
1097 wx_libs="$_guildflags $(lib_flags_for $wx_libs)"
1098 fi
1099
1100
1101 if [ -n "$WXDEBUG" ]; then
1102 decho
1103 decho " using libs: '$wx_libs'"
1104 decho " using_gui = $using_gui"
1105 decho
1106 fi
1107
1108
1109 # Endgame. Nothing left to discover now.
1110 # --------------------------------------------------------------
1111
1112 [ "$using_gui" = "yes" ] || _gui_cppflags="-DwxUSE_GUI=0"
1113
1114 if is_installed; then
1115 _include_cppflags="-I${includedir}/wx-@WX_RELEASE@@WX_FLAVOUR@"
1116 else
1117 _include_cppflags="-I${includedir} -I${prefix}/contrib/include"
1118 fi
1119
1120 _cppflags=$(echo "-I${libdir}/wx/include/@TOOLCHAIN_FULLNAME@" $_include_cppflags "@WXDEBUG_DEFINE@" "@TOOLCHAIN_DEFS@" "@TOOLCHAIN_DLL_DEFS@" $_gui_cppflags "@WXCONFIG_INCLUDE@" "@WX_LARGEFILE_FLAGS@" "@GCC_PRAGMA_FLAGS@")
1121
1122 # now without further ado, we can answer these too.
1123 [ -z "$output_option_cppflags" ] || echo $_cppflags
1124 [ -z "$output_option_cflags" ] || echo $_cppflags "@CODE_GEN_FLAGS@"
1125 [ -z "$output_option_cxxflags" ] || echo $_cppflags "@CODE_GEN_FLAGS@" "@CODE_GEN_FLAGS_CXX@"
1126 [ -z "$output_option_gl_libs" ] || echo $(lib_flags_for gl)
1127 [ -z "$output_option_linkdeps" ] || echo $link_deps
1128
1129 if [ -n "$output_option_libs" ]; then
1130
1131 is_cross &&
1132 [ "x$libdir" = "x/usr/${target}/lib" ] ||
1133 [ "x$libdir" = "x/usr/lib" ] ||
1134 _ldflags="-L$libdir"
1135
1136 is_installed || [ -n "$flag_option_no_rpath" ] || _rpath="@WXCONFIG_RPATH@"
1137
1138 echo $_ldflags "@LDFLAGS@" $_rpath $wx_libs "@DMALLOC_LIBS@"
1139 fi
1140
1141 # And so that's it, we're done. Have a nice build.
1142
1143 exit 0
1144
1145