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