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