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