3 # Name: wx-config{.in,}
4 # Purpose: wx configuration search and query tool {template,}
5 # Author: Ron <ron@debian.org>
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 ############################################################################
20 # Extra^2 debug mode, for if things ever get really weird.
21 [ -z "$WXDEBUG_X" ] || set -x
24 # On with some basic stuff, like the ability to die gracefully,
25 # and to tell people what we are about.
26 # ------------------------------------------------------------------
29 # Output a message to stderr.
30 decho
() { echo "$*" 1>&2; }
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.
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
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 ...]
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
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.
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.
76 # Unfussy people are the easiest to deal with, get them out of the way now.
77 [ $# -gt 0 ] || usage
1
80 # Contentious tools determined by configure.
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.
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.
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 # ------------------------------------------------------------------
102 # Options that specify a distinct library build.
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"
111 # Options that are expected to generate some output.
112 wxconfig_output_options
="prefix exec_prefix
114 release version version_full
116 cppflags cflags cxxflags
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"
128 # Input options that accept only a yes or no argument.
129 wxconfig_yesno_options
="universal unicode debug static"
131 # Boolean options that do something or not.
132 wxconfig_flag_options
="$wxconfig_yesno_options selected_config no_rpath inplace"
136 # Some simple sugar coating to keep things more readable below.
137 # --------------------------------------------------------------
139 # option_name _string
140 # Returns NAME if _string is of the form: --NAME[=...]
143 echo "$1" | sed 's/^--//;s/=.*//' | tr '-' '_'
146 # option_value _string
147 # Returns FOO if _string is of the form: --option=FOO
150 echo "$1" | sed 's/^[^=]*=//'
153 # match_field _value _list
154 # Returns true if _value is a field in _list
157 _match_field_match
="$1"
159 for _match_field_i
do
160 [ "x$_match_field_i" != "x$_match_field_match" ] || return 0
165 # remove_field _value _list
166 # Returns _list minus any field(s) that match _value.
172 if [ -n "$_remf_value" ]; then
174 [ "x$_remf_item" = "x$_remf_value" ] ||
175 _remf_list
="${_remf_list:+$_remf_list }$_remf_item"
183 # validate_arg _domain _set _name _value
184 # Boilerplate to validate an argument and initialise a psuedo-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:
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)"
197 # with the one liners you see on the page below.
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\""
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
216 eval "case \${yesno_option_$1-\${flag_option_$1-unset}} in
218 y*|Y*) input_option_$2=\"$3\" ;;
219 n*|N*) input_option_$2=\"$4\" ;;
222 decho \" *** Error: Invalid request '--$1=\$yesno_option_$1'\"
223 decho \" Valid arguments for --$1 are: [ yes, no ]\"
232 # Now we are ready to find out what the user wants from us.
233 # --------------------------------------------------------------
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.
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
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"
262 _name
=`option_name $arg`
263 if validate_arg wxconfig flag
"$_name" yes ||
264 validate_arg wxconfig output
"$_name" yes
271 # FIXME Surely we can validate the parameters too ...
272 input_parameters
="${input_parameters:+$input_parameters }$arg"
276 decho
" *** Error: Unrecognised option: '$arg'"
277 decho
"Use wx-config --help for information on command line options."
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.
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'
290 # Dump everything we just read in debug mode.
291 if [ -n "$WXDEBUG" ]; then
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\"`"
299 decho
" yes/no options = $yesno_options"
300 for y
in $yesno_options; do
301 decho
" $y = `eval echo \"\\\$yesno_option_$y\"`"
303 decho
" flag options = $flag_options"
304 for f
in $flag_options; do
305 decho
" $f = `eval echo \"\\\$flag_option_$f\"`"
307 decho
" output options = $output_options"
308 for o
in $output_options; do
309 decho
" $o = `eval echo \"\\\$output_option_$o\"`"
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
319 # --------------------------------------------------------------
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.
327 [ $# -gt 0 ] || set m
328 eval echo "\${$1_host}\${$1_toolkit}\${$1_widgetset}-\${$1_chartype}-\${$1_debugtype}\${$1_linkage}-\${$1_version}\${$1_flavour}"
331 # Returns true if this script is for a cross compiled config.
332 is_cross
() { [ "x@cross_compiling@" = "xyes" ]; }
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"
340 installed_configs
=`cd "$wxconfdir" 2> /dev/null && ls | grep -v "^inplace-"`
342 is_cross
&& target
="@host_alias@"
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'`
355 this_config
=`get_mask this`
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)?'}
369 configmask
="^`get_mask`$"
372 # Dump the user specification in debug mode.
373 if [ -n "$WXDEBUG" ]; then
376 decho
" prefix = '$prefix'"
377 decho
" exec_prefix = '$exec_prefix'"
378 decho
" wxconfdir = '$wxconfdir'"
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'"
389 decho
" configmask = '$configmask'"
390 decho
" this config = '$this_config'"
397 # From here on, we'll need to be able to figure out a delegation target.
398 # -----------------------------------------------------------------------
400 # The rules for delegation are:
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.
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
412 # c. If the list contains multiple candidates, pass on to step 3.
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.
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.
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.
436 # But first, more sugar to keep what follows clear and legible.
437 # --------------------------------------------------------------
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
; }
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; }
449 # Returns the number of IFS split fields in _word
450 count_fields
() { return $#; }
452 # count_delegates _mask
453 # Return the number of eligible config files that match _mask
454 count_delegates
() { count_fields
`find_eligible_delegates $1`; }
456 # is_set _variablename
457 # Returns true if $_variablename is initialised.
458 is_set
() { [ "x`eval echo \"\\\${$1-unset}\"`" != "xunset" ]; }
461 # true iff _cmd is false
462 not
() { if "$@"; then false
; else true
; fi; }
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.
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
()
490 if [ "x$WXDEBUG" = "xverbose" ]; then
491 _fbd_indent
="${_fbd_indent}. "
492 decho
" $_fbd_indent---> unbound options: $*"
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 ---"
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"
515 count_delegates
"$_mask"
518 if [ $_still_eligible -eq 1 ]; then
519 echo `find_eligible_delegates "$_mask"`
523 [ "x$WXDEBUG" != "xfindprogress" ] || printf "." 1>&2
525 [ $_still_eligible -gt 1 ] && [ $# -gt 1 ] &&
526 do_find_best_delegate
`remove_field $i $*`
532 elif [ $# -gt 1 ]; then
534 if [ "x$WXDEBUG" = "xverbose" ]; then
535 decho
" ${_fbd_indent}pruning: $i"
536 _pruned
="${_pruned:+$_pruned }$i"
538 set `remove_field $i $*`
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)
553 for _fbdi
in $wxconfig_schema; do
554 is_set input_option_
$_fbdi ||
555 _unbound_options
="${_unbound_options:+$_unbound_options }$_fbdi"
557 do_find_best_delegate
$_unbound_options
561 # Legacy wx-config helpers.
562 # -------------------------
565 # Returns a mask in the format used by wx2.4.
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"
574 # find_legacy_configs
575 # Returns a list of configs installed by wx2.4 releases.
576 find_legacy_configs
()
581 ls wx
*-2.4
-config | grep -v ^wxbase
582 ls wx
*-2.4
-config | grep ^wxbase
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
()
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
607 # The only action we can perform authoritatively prior to delegation
608 # is to list all the possible delegates.
609 # --------------------------------------------------------------
612 [ -z "$WXDEBUG" ] || config_spec
=$configmask
614 # Next chance for another satisfied customer then
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
620 _remains_in_prefix
=$installed_configs
621 _delegates
=`find_eligible_delegates $configmask`
622 _best_delegate
=`find_best_delegate`
624 if [ "x$WXDEBUG" = "xverbose" ]; then
626 decho
" all = $_remains_in_prefix"
627 decho
" matching = $_delegates"
628 decho
" best = $_best_delegate"
629 decho
" this = $this_config"
632 for d
in $_delegates; do
633 _remains_in_prefix
=`remove_field $d $_remains_in_prefix`
637 echo " Default config is $this_config"
640 if user_mask_fits
"$this_config" ; then
642 echo " Default config ${this_exec_prefix+in $this_exec_prefix }will be used for output"
644 if match_field
"$this_config" $_delegates ; then
645 _delegates
=`remove_field $this_config $_delegates`
647 echo " though it is not installed in: $prefix"
648 if [ -n "$_best_delegate" ] && [ "x$_best_delegate" != "x$this_config" ]; then
650 echo " Best alternate in $prefix:"
651 echo " $_best_delegate"
655 elif [ -n "$_best_delegate" ]; then
657 echo " Specification best match: $_best_delegate"
659 elif [ -z "$_delegates" ]; then
661 _last_chance
=`find_best_legacy_config`
662 if [ -n "$_last_chance" ]; then
664 echo " Specification matches legacy config: $_last_chance"
669 No config found to match: $config_spec
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.
681 echo " Specification was ambiguous. Use additional feature options"
682 echo " to choose between alternate matches."
685 _delegates
=`remove_field "$_best_delegate" $_delegates`
687 if [ -n "$_delegates" ]; then
689 echo " Alternate matches:"
690 for d
in $_delegates; do
694 if [ -n "$_remains_in_prefix" ]; then
696 echo " Also available in $prefix:"
697 for d
in $_remains_in_prefix; do
702 _legacy_configs
=`find_legacy_configs`
703 if [ -n "$_legacy_configs" ]; then
705 echo " Legacy configs available in $prefix:"
706 for d
in $_legacy_configs; do
707 echo " $d" | sed 's/-config$//'
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 # --------------------------------------------------------------
721 if not user_mask_fits
"$this_config" ; then
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.
728 if [ -n "$WXCONFIG_DELEGATED" ]; then
730 decho
" *** Error: Bad config delegation"
733 decho
" ($this_config) cannot satisfy:"
734 decho
" $config_spec"
735 decho
" Someone has been terribly careless."
740 count_delegates
"$configmask"
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
751 if [ $_numdelegates -eq 0 ]; then
753 _last_chance
=`find_best_legacy_config`
754 if [ -n "$_last_chance" ]; then
758 --prefix*|--exec-prefix*| \
759 --version|--release|--basename| \
760 --static|--libs|--gl_libs| \
761 --cppflags|--cflags|--cxxflags| \
763 --rezflags|--inplace)
764 _legacy_args
="$_legacy_args $arg"
767 --static|--static=y
*|--static=Y
*)
768 _legacy_args
="$_legacy_args --static"
773 if [ -n "$WXDEBUG" ]; then
774 decho
" found a suitable legacy delegate: $_last_chance"
775 decho
"--> $prefix/bin/$_last_chance $_legacy_args"
778 export WXCONFIG_DELEGATED
=yes
779 $prefix/bin
/$_last_chance $_legacy_args
786 Warning: No config found to match: $config_spec
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
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.
804 if [ $_numdelegates -gt 1 ]; then
806 [ -z "$WXDEBUG" ] || decho
" must prune the list of eligible delegates"
808 best_delegate
=`find_best_delegate`
810 if [ -n "$best_delegate" ]; then
812 if [ -n "$WXDEBUG" ]; then
813 decho
" found a suitable delegate: $best_delegate"
814 decho
"--> $wxconfdir/$best_delegate $*"
817 export WXCONFIG_DELEGATED
=yes
818 $wxconfdir/$best_delegate $
*
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
834 if [ -n "$WXDEBUG" ]; then
835 decho
" using the only suitable delegate"
836 decho
"--> $wxconfdir/`find_eligible_delegates $configmask` $*"
839 export WXCONFIG_DELEGATED
=yes
840 $wxconfdir/`find_eligible_delegates $configmask` $
*
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 # --------------------------------------------------------------
850 [ -z "$WXDEBUG" ] || decho
" using this config"
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}
859 includedir
="@includedir@"
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"
876 # --rezflags is deprecated and disabled (2005/11/29)
877 if [ -n "$output_option_rezflags" ]; then
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."
885 # The rest are going to need a little more work.
886 # --------------------------------------------------------------
888 is_monolithic
() { [ "x@MONOLITHIC@" = "x1" ]; }
889 is_static
() { [ -n "$this_linkage" ]; }
890 is_installed
() { [ -z "$this_prefix" ]; }
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:
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.
902 # and if such a thing still cannot be found, exit signalling an error.
903 if [ -n "$input_option_utility" ]; then
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"
909 if not is_installed
&& [ -x "$_util" ]; then
910 is_static
|| _preload
="eval LD_LIBRARY_PATH=$exec_prefix/lib"
911 echo $_preload $_util
916 _user_prefix
=${input_option_exec_prefix:-$input_option_prefix}
918 for _util
in "${input_option_utility}-@WX_RELEASE@@WX_FLAVOUR@" \
919 "${input_option_utility}-@WX_RELEASE@" \
920 "${input_option_utility}"
922 for p
in ${_user_prefix:+$_user_prefix/bin} $bindir $PATH; do
924 [ -z "$WXDEBUG" ] || decho
" checking for: '$p/$_util'"
926 if [ -x "$p/$_util" ]; then
938 # Still here? Then get the options together for building an app.
939 # ----------------------------------------------------------------
941 # Additional configuration for individual library components.
942 ldflags_gl
="@LDFLAGS_GL@"
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@"
953 # lib_flags_for _liblist
954 # This function returns a list of flags suitable to return with the
955 # output of --libs for all of the libraries in _liblist. You can
956 # add support for a new library by adding an entry for it in the
957 # psuedo-hashes above if it requires additional linker options.
960 [ -z "$WXDEBUG" ] || decho
" fetching lib flags for: '$*'"
966 is_cross
&& _target
="-${target}"
970 # We evidently can't trust people not to duplicate things in
971 # configure, or to keep them in any sort of sane order overall,
972 # so only add unique new fields here even if it takes us a while.
973 # In the case of libs, we bubble any duplicates to the end,
974 # because if multiple libs require it, static linking at least
975 # will require it to come after all of them. So long as local
976 # order is ok in configure then we should always be able to
977 # massage a correct result here like this.
979 # FIXME: ldlibs_core is totally bogus. Fix the duplication
980 # there independently of this. This covers for it, but we
981 # want to do this anyway because some libs may share common
982 # deps without a common ancestor in wx. This is not a licence
983 # for sloppy work elsewhere though and @GUI_TK_LIBRARY should
986 for f
in `eval echo \"\\\$ldflags_$lib\"`; do
987 match_field
"$f" $_all_ldflags || _all_ldflags
="$_all_ldflags $f"
990 if match_field
"$lib" @CORE_BASE_LIBS@
; then
991 _libname
="@WX_LIBRARY_BASENAME_NOGUI@"
993 _libname
="@WX_LIBRARY_BASENAME_GUI@"
995 [ $lib = base
] || _libname
="${_libname}_$lib"
996 _libname
="${_libname}-@WX_RELEASE@$_target"
999 _wxlibs
="$_wxlibs ${libdir}/lib${_libname}.a"
1000 for f
in `eval echo \"\\\$ldlibs_$lib\"`; do
1002 # Only propagate duplicate -libraries to their latest
1003 # possible position. Do not eliminate any other
1004 # duplicates that might occur. They should be fixed
1005 # in configure long before they get here.
1006 # This started as a workaround for Mac -framework,
1007 # but it seems like a better policy in general, which
1008 # will let the more heinous bugs in configure shake out.
1009 # We should maybe filter *.a here too, but not unless
1012 -l*) _all_libs
="`remove_field $f $_all_libs` $f" ;;
1013 *) _all_libs
="$_all_libs $f" ;;
1018 _wxlibs
="$_wxlibs -l${_libname}"
1023 if [ -n "$WXDEBUG" ]; then
1024 decho
" retrieved: ldflags = $_all_ldflags"
1025 decho
" wxlibs = $_wxlibs"
1026 decho
" alllibs = $_all_libs"
1029 echo $_all_ldflags $_wxlibs $_all_libs
1032 # this is the strict subset of the above function which returns only the
1033 # (static) libraries themselves: this is used for linkdeps output which should
1034 # output the list of libraries the main program should depend on
1036 # of course, this duplication is bad but I'll leave to somebody else the care
1037 # of refactoring this as I don't see any way to do it - VZ.
1039 # This (and the other cruft to support it) should be removed with
1040 # reference to the FIXME above when configure stops piping us a slurry
1041 # of options that need to be decomposed again for most practical uses - RL.
1046 is_cross
&& _target
="-${target}"
1049 if match_field
"$lib" @CORE_BASE_LIBS@
; then
1050 _libname
="@WX_LIBRARY_BASENAME_NOGUI@"
1052 _libname
="@WX_LIBRARY_BASENAME_GUI@"
1054 [ $lib = base
] || _libname
="${_libname}_$lib"
1055 _libname
="${_libname}-@WX_RELEASE@$_target"
1057 _wxlibs
="$_wxlibs ${libdir}/lib${_libname}.a"
1063 # Sanity check the list of libs the user provided us, if any.
1064 # --------------------------------------------------------------
1066 wx_libs
=`echo "$input_parameters" | tr ',' ' '`
1068 [ -z "$WXDEBUG" ] || decho
" user supplied libs: '$wx_libs'"
1070 if is_monolithic
; then
1072 # Core libs are already built into the blob.
1073 for i
in std @CORE_GUI_LIBS@ @CORE_BASE_LIBS@
; do
1074 wx_libs
=`remove_field $i $wx_libs`
1077 wx_libs
="@WXCONFIG_LDFLAGS_GUI@ `lib_flags_for $wx_libs`"
1079 # We still need the core lib deps for a static build though
1081 link_deps
="${libdir}/libwx_@TOOLCHAIN_NAME@.a"
1082 wx_libs
="$wx_libs $link_deps $ldlibs_core $ldlibs_base"
1084 wx_libs
="$wx_libs -lwx_@TOOLCHAIN_NAME@"
1089 else # MONOLITHIC = 0
1091 # Import everything by default, expand std if specified, or add base if omitted.
1092 if [ -z "$wx_libs" ]; then
1093 wx_libs
="@CORE_GUI_LIBS@ @CORE_BASE_LIBS@"
1094 elif match_field std
$wx_libs; then
1095 # Bubble any libs that were already specified to the end
1096 # of the list and ensure static linking order is retained.
1097 wx_libs
=`remove_field std $wx_libs`
1098 for i
in @CORE_GUI_LIBS@ @CORE_BASE_LIBS@
; do
1099 wx_libs
="`remove_field $i $wx_libs` $i"
1101 elif not match_field base
$wx_libs ; then
1102 wx_libs
="$wx_libs base"
1106 for i
in $wx_libs ; do
1107 if match_field
"$i" @CORE_GUI_LIBS@
; then
1108 _guildflags
="@WXCONFIG_LDFLAGS_GUI@"
1112 match_field
"$i" @CORE_BASE_LIBS@
|| using_gui
=yes
1116 link_deps
=`link_deps_for $wx_libs`
1118 wx_libs
="$_guildflags `lib_flags_for $wx_libs`"
1122 if [ -n "$WXDEBUG" ]; then
1124 decho
" using libs: '$wx_libs'"
1125 decho
" using_gui = $using_gui"
1130 # Endgame. Nothing left to discover now.
1131 # --------------------------------------------------------------
1133 [ "$using_gui" = "yes" ] || _gui_cppflags
="-DwxUSE_GUI=0"
1135 if is_installed
; then
1136 _include_cppflags
="-I${includedir}/wx-@WX_RELEASE@@WX_FLAVOUR@"
1138 _include_cppflags
="-I${includedir} -I${prefix}/contrib/include"
1141 _cppflags
=`echo "-I${libdir}/wx/include/@TOOLCHAIN_FULLNAME@" $_include_cppflags "@WXCONFIG_CPPFLAGS@" $_gui_cppflags`
1143 # now without further ado, we can answer these too.
1144 [ -z "$output_option_cppflags" ] || echo $_cppflags
1145 [ -z "$output_option_cflags" ] || echo $_cppflags "@WXCONFIG_CFLAGS@"
1146 [ -z "$output_option_cxxflags" ] || echo $_cppflags "@WXCONFIG_CXXFLAGS@"
1147 [ -z "$output_option_gl_libs" ] || echo `lib_flags_for gl`
1148 [ -z "$output_option_linkdeps" ] || echo $link_deps
1150 if [ -n "$output_option_libs" ]; then
1153 [ "x$libdir" = "x/usr/${target}/lib" ] ||
1154 [ "x$libdir" = "x/usr/lib" ] ||
1155 _ldflags
="-L$libdir"
1157 is_installed
|| [ -n "$flag_option_no_rpath" ] || _rpath
="@WXCONFIG_RPATH@"
1159 echo $_ldflags "@LDFLAGS@" $_rpath $wx_libs "@DMALLOC_LIBS@"
1163 # xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
1165 # Beyond here reside only machine or tool specific workarounds
1166 # that require knowlege not obtainable prior to this comment.
1168 # Please. Avoid addding things here, wx-config should avoid
1169 # hard coding tool specific details. Do not use things here
1170 # as an example of other things that should be here, These
1171 # shouldn't be here either. This is a place of last resort
1172 # for interim workarounds. I can but stress as strongly as
1173 # the censor will allow, there are only bad examples of things
1174 # that belong at this level of abstraction to follow. It is
1175 # a limbo for glitches awaiting the Next Design Repair. Ok.
1177 # With that firmly in mind, our debut dilemma is:
1179 # Resource compilers. An elusive term that covers some pretty
1180 # dissimilar concepts on various platforms. The good news is,
1181 # each platform has only one definition of 'resource', compiled
1182 # or not, and so we can abstract that neatly to return a platform
1183 # specific invocation of the appropriate tool. The bad news is,
1184 # windres (at least) requires knowledge of the wx header files
1185 # location(s) that cannot be predicted reliably before the call to
1186 # wx-config is made. Currently for all known resource compilers,
1187 # we can simply return a command and some salient configuration
1188 # options in response to a request for --rescomp. So here we
1189 # top up the options for any tools that may require information
1190 # that was only just determined in the last few machine cycles,
1191 # then output the necessary incantation for the platform.
1193 # Most things should already be constant by the time configure
1194 # has run. Do not add anything here that is already known there.
1196 if [ -n "$output_option_rescomp" ]; then
1200 # Note that with late model windres, we could just insert
1201 # _include_cppflags here, but use the old notation for now
1202 # as it is more universally accepted.
1203 if is_installed
; then
1204 echo "@RESCOMP@ --include-dir" \
1205 "${includedir}/wx-@WX_RELEASE@@WX_FLAVOUR@" \
1206 "@WXCONFIG_RESFLAGS@"
1208 echo "@RESCOMP@ --include-dir ${includedir}" \
1209 "--include-dir ${prefix}/contrib/include" \
1210 "@WXCONFIG_RESFLAGS@"
1214 # neither rez not emxbind have any specific needs from
1215 # us, so just output what was determined by configure.
1217 echo @RESCOMP@ @WXCONFIG_RESFLAGS@
1224 # xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
1226 # And so that's it, we're done. Have a nice build.