diff options
| author | Peter Eisentraut | 2000-09-21 20:17:43 +0000 |
|---|---|---|
| committer | Peter Eisentraut | 2000-09-21 20:17:43 +0000 |
| commit | 353371874f3050bafa1a9f4d7ad7253d70165d81 (patch) | |
| tree | 6163bfea2613a1978cf8678df7dbdf6f4b9d3fc8 /config | |
| parent | b4c8d47ab0c3c570e31c29696f74a204a33df647 (diff) | |
Replace brain-dead Autoconf macros AC_ARG_{ENABLE,WITH} with something
that's actually useful, robust, consistent.
Better plan to generate aclocal.m4 as well: use m4 include directives,
rather than cat.
Diffstat (limited to 'config')
| -rw-r--r-- | config/general.m4 | 138 |
1 files changed, 138 insertions, 0 deletions
diff --git a/config/general.m4 b/config/general.m4 new file mode 100644 index 00000000000..2e17f2ba0bd --- /dev/null +++ b/config/general.m4 @@ -0,0 +1,138 @@ +# $Header: /cvsroot/pgsql/config/general.m4,v 1.1 2000/09/21 20:17:42 petere Exp $ + +# This file defines new macros to process configure command line +# arguments, to replace the brain-dead AC_ARG_WITH and AC_ARG_ENABLE. +# The flaw in these is particularly that they only differentiate +# between "given" and "not given" and do not provide enough help to +# process arguments that only accept "yes/no", that require an +# argument (other than "yes/no"), etc. +# +# The point of this implementation is to reduce code size and +# redundancy in configure.in and to improve robustness and consistency +# in the option evaluation code. + + +# print an error message and exit (while running `autoconf') +define([pgac_error], + [errprint(__file__:__line__[: error: $1 +]) + m4exit(10)]) + + +# Convert type and name to shell variable name (e.g., "enable_long_strings") +define([pgac_arg_to_variable], + [$1[]_[]patsubst($2, -, _)]) + + +# PGAC_ARG(TYPE, NAME, HELP-STRING, +# [ACTION-IF-YES], [ACTION-IF-NO], [ACTION-IF-ARG], +# [ACTION-IF-OMITTED]) +# ---------------------------------------------------------- +# This is the base layer. TYPE is either "with" or "enable", depending +# on what you like. NAME is the rest of the option name, HELP-STRING +# as usual. ACTION-IF-YES is executed if the option is given without +# and argument (or "yes", which is the same); similar for ACTION-IF-NO. + +AC_DEFUN([PGAC_ARG], +[dnl Check arguments +ifelse([$1], enable, , + [$1], with, , + [pgac_error([first argument of $0 must be `enable' or `with', not `$1'])])[]dnl +define([pgac_variable], [pgac_arg_to_variable([$1], [$2])])[]dnl +dnl Register help string, only if there is one +ifelse([$3], [], [], +[AC_DIVERT_PUSH(AC_DIVERSION_NOTICE)dnl +ac_help="$ac_help +[$3]" +AC_DIVERT_POP()])dnl +[#] Check whether --$1-$2 was given +if test x"[$]{pgac_variable+set}" = xset; then + case [$]pgac_variable in + yes) + ifelse([$4], [], :, [$4]) + ;; + no) + ifelse([$5], [], :, [$5]) + ;; +dnl Action if called with argument +ifelse([$6], [], [], +[ *) +dnl Set up $withval or $enableval + $1[]val=[$]pgac_variable + $6 + ;; +])[]dnl + esac [#] [$]pgac_variable +dnl Action if omitted +ifelse([$7], [], [], +[else + $7 +])[]dnl +fi[]dnl +undefine([pgac_variable])dnl +])# PGAC_ARG + + +# PGAC_ARG_BOOL(TYPE, NAME, DEFAULT, HELP-STRING, +# [ACTION-IF-YES], [ACTION-IF-NO]) +# ----------------------------------------------- +# Accept a boolean option, that is, one that only takes yes or no. +# ("no" is equivalent to "disable" or "without"). DEFAULT is what +# should be done if the option is omitted; it should be "yes" or "no". +# (Consequently, one of ACTION-IF-YES and ACTION-IF-NO will always +# execute.) + +AC_DEFUN([PGAC_ARG_BOOL], +[PGAC_ARG([$1], [$2], [$4], [$5], [$6], + [AC_MSG_ERROR([no argument expected for --$1-$2 option])], + [ifelse([$3], yes, [pgac_arg_to_variable([$1], [$2])=yes +$5], + [$3], no, [pgac_arg_to_variable([$1], [$2])=no +$6], + [pgac_error([third argument of $0 must be `yes' or `no', not `$3'])])])[]dnl +])# PGAC_ARG_BOOL + + +# PGAC_ARG_REQ(TYPE, NAME, HELP-STRING, [ACTION-IF-GIVEN], [ACTION-IF-NOT-GIVEN]) +# ------------------------------------------------------------------------------- +# This option will require an argument; "yes" or "no" will not be +# accepted. + +AC_DEFUN([PGAC_ARG_REQ], +[PGAC_ARG([$1], [$2], [$3], + [AC_MSG_ERROR([argument required for --$1-$2 option])], + [AC_MSG_ERROR([argument required for --$1-$2 option])], + [$4], + [$5])])# PGAC_ARG_REQ + + +# PGAC_ARG_OPTARG(TYPE, NAME, HELP-STRING, [DEFAULT-ACTION], [ARG-ACTION] +# [ACTION-ENABLED], [ACTION-DISABLED]) +# ----------------------------------------------------------------------- +# This will create an option that behaves as follows: If omitted, or +# called with "no", then set the enable_variable to "no" and do +# nothing else. If called with "yes", then execute DEFAULT-ACTION. If +# called with argument, set enable_variable to "yes" and execute +# ARG-ACTION. Additionally, execute ACTION-ENABLED if we ended up with +# "yes" either way, else ACTION-DISABLED. +# +# The intent is to allow enabling a feature, and optionally pass an +# additional piece of information. + +AC_DEFUN([PGAC_ARG_OPTARG], +[PGAC_ARG([$1], [$2], [$3], [$4], [], + [pgac_arg_to_variable([$1], [$2])=yes +$5], + [pgac_arg_to_variable([$1], [$2])=no]) +dnl Add this code only if there's a ACTION-ENABLED or ACTION-DISABLED. +ifelse([$6[]$7], [], [], +[ +if test "[$]pgac_arg_to_variable([$1], [$2])" = yes; then + ifelse([$6], [], :, [$6]) +ifelse([$7], [], [], +[else + $7 +])[]dnl +fi +])[]dnl +])# PGAC_ARG_OPTARG |
