X-Git-Url: https://git.exim.org/users/heiko/exim.git/blobdiff_plain/88d5edb00796448347da8544088b0db1f9b61ddf..bc4bc4c581f45f7afae0e06e5279026dae7e519a:/src/scripts/lookups-Makefile?ds=inline diff --git a/src/scripts/lookups-Makefile b/src/scripts/lookups-Makefile index 2c4dc96b8..7f45eea03 100755 --- a/src/scripts/lookups-Makefile +++ b/src/scripts/lookups-Makefile @@ -18,9 +18,16 @@ tag_marker='MAGIC-TAG-MODS-OBJ-RULES-GO-HERE' tab=' ' -# We always do something now, since there should always be a lookup, -# and now we need to run in order to put the OBJ+= rules in. - +# We rely on tr(1) for translating case below. Some people export +# values of LC_CTYPE and LC_COLLATE which apparently break our assumptions. +# We're a script expecting certain output based on known inputs and not dealing +# with UTF8, so we should be safe doingthis: +LC_ALL=C +export LC_ALL + +# nb: do not permit leading whitespace for this, as CFLAGS_DYNAMIC is exported +# to the lookups subdir via a line with leading whitespace which otherwise +# matches if grep -q "^CFLAGS_DYNAMIC[ $tab]*=" "$defs_source" then # we have a definition, we're good to go @@ -28,20 +35,37 @@ then else echo >&2 "Missing CFLAGS_DYNAMIC inhibits building dynamic module lookup" enable_dynamic='' + # We always do something now, since there should always be a lookup, + # and now we need to run in order to put the OBJ=$(OBJ)+ rules in. So we + # continue on. fi tmp="$target.t" +# For the want_ checks, we need to let the user override values from the make +# command-line, not just check the Makefile. + want_dynamic() { local dyn_name="$1" - grep -q "^LOOKUP_${dyn_name}[ $tab]*=[ $tab]*2" "$defs_source" + local re="LOOKUP_${dyn_name}[ $tab]*=[ $tab]*2" + env | grep -q "^$re" + if [ $? -eq 0 ]; then return 0; fi + grep -q "^[ $tab]*$re" "$defs_source" } want_at_all() { local want_name="$1" - grep -q "^LOOKUP_${want_name}[ $tab]*=[ $tab]*." "$defs_source" + local re="LOOKUP_${want_name}[ $tab]*=[ $tab]*." + env | grep -q "^$re" + if [ $? -eq 0 ]; then return 0; fi + grep -q "^[ $tab]*$re" "$defs_source" } +# The values of these variables will be emitted into the Makefile. + +MODS="" +OBJ="" + emit_module_rule() { local lookup_name="$1" local mod_name @@ -59,13 +83,13 @@ emit_module_rule() { echo >&2 "Inhibited dynamic modules prevents building dynamic $lookup_name" exit 1 fi - echo "MODS += ${mod_name}.so" + MODS="${MODS} ${mod_name}.so" grep "^LOOKUP_${lookup_name}_" "$defs_source" echo "LOOKUP_${mod_name}_INCLUDE = \$(LOOKUP_${lookup_name}_INCLUDE)" echo "LOOKUP_${mod_name}_LIBS = \$(LOOKUP_${lookup_name}_LIBS)" elif want_at_all "$lookup_name" then - echo "OBJ += ${mod_name}.o" + OBJ="${OBJ} ${mod_name}.o" fi } @@ -83,9 +107,18 @@ done if want_at_all LDAP then - echo "OBJ += ldap.o" + OBJ="${OBJ} ldap.o" fi +# Because the variable is EXPERIMENTAL_SPF and not LOOKUP_SPF we +# always include spf.o and compile a dummy if EXPERIMENTAL_SPF is not +# defined. + +OBJ="${OBJ} spf.o" + +echo "MODS = $MODS" +echo "OBJ = $OBJ" + sed -n "/$tag_marker/,\$p" < "$input" exec >&5