Avoid spurious rebuilds of the dynamic lookups Makefile.
[exim.git] / src / scripts / lookups-Makefile
1 #! /bin/sh
2
3 # We turn the configure-built build-$foo/lookups/Makefile.predynamic into Makefile
4
5 # We always re-exec ourselves at least once, because it's the cleanest and
6 # most portable way to turn on various features we expect of POSIX sh.
7 if [ -z "$EXIM_LOOKUP_MAKEFILE_ADJUSTED" ]
8 then
9 SHELL=/bin/sh
10 EXIM_LOOKUP_MAKEFILE_ADJUSTED=yes
11 export EXIM_LOOKUP_MAKEFILE_ADJUSTED
12
13 # Solaris sh and tr are problematic until we get xpg4 variants
14 if [ -x /usr/xpg4/bin/sh ]
15 then
16 PATH="/usr/xpg4/bin:$PATH"
17 export PATH
18 SHELL=/usr/xpg4/bin/sh
19 export SHELL
20 fi
21
22 # IRIX uses /bin/ksh for sh but in a compatibility mode unless $_XPG == 1,
23 # where said compatibility mode disables $(...)
24 _XPG=1
25 export _XPG
26
27 exec "$SHELL" "$0" "$@"
28 fi
29
30 input=lookups/Makefile.predynamic
31 target=lookups/Makefile.postdynamic
32 defs_source=Makefile-t
33 tag_marker='MAGIC-TAG-MODS-OBJ-RULES-GO-HERE'
34
35 tab=' '
36
37 # We rely on tr(1) for translating case below. Some people export
38 # values of LC_CTYPE and LC_COLLATE which apparently break our assumptions.
39 # We're a script expecting certain output based on known inputs and not dealing
40 # with UTF8, so we should be safe doingthis:
41 LC_ALL=C
42 export LC_ALL
43
44 # nb: do not permit leading whitespace for this, as CFLAGS_DYNAMIC is exported
45 # to the lookups subdir via a line with leading whitespace which otherwise
46 # matches
47 if grep -q "^CFLAGS_DYNAMIC[ $tab?:]*=" "$defs_source"
48 then
49 # we have a definition, we're good to go
50 echo >&2 ">>> Creating lookups/Makefile for building dynamic modules"
51 enable_dynamic=yes
52 else
53 echo >&2 ">>> Creating lookups/Makefile without dynamic module support"
54 enable_dynamic=''
55 # We always do something now, since there should always be a lookup,
56 # and now we need to run in order to put the OBJ=$(OBJ)+ rules in. So we
57 # continue on.
58 fi
59
60 # For the want_ checks, we need to let the user override values from the make
61 # command-line, not just check the Makefile.
62
63 want_dynamic() {
64 local dyn_name="$1"
65 local re="LOOKUP_${dyn_name}[ $tab]*=[ $tab]*2"
66 env | grep -q "^$re"
67 if [ $? -eq 0 ]; then return 0; fi
68 grep -q "^[ $tab]*$re" "$defs_source"
69 }
70
71 want_at_all() {
72 local want_name="$1"
73 local re="LOOKUP_${want_name}[ $tab]*=[ $tab]*."
74 env | grep -q "^$re"
75 if [ $? -eq 0 ]; then return 0; fi
76 grep -q "^[ $tab]*$re" "$defs_source"
77 }
78
79 # The values of these variables will be emitted into the Makefile.
80
81 MODS=""
82 OBJ=""
83
84 emit_module_rule() {
85 local lookup_name="$1"
86 local mod_name pkgconf
87 if [ "${lookup_name%:*}" = "$lookup_name" ]
88 then
89 mod_name=$(echo $lookup_name | tr A-Z a-z)
90 else
91 mod_name="${lookup_name#*:}"
92 lookup_name="${lookup_name%:*}"
93 fi
94
95 if want_dynamic "$lookup_name"
96 then
97 if [ -z "$enable_dynamic" ]; then
98 echo >&2 "Missing CFLAGS_DYNAMIC prevents building dynamic $lookup_name"
99 exit 1
100 fi
101 MODS="${MODS} ${mod_name}.so"
102 pkgconf=$(grep "^LOOKUP_${lookup_name}_PC" "$defs_source")
103 if [ $? -eq 0 ]; then
104 pkgconf=$(echo $pkgconf | sed 's/^.*= *//')
105 echo "LOOKUP_${mod_name}_INCLUDE = $(pkg-config --cflags $pkgconf)"
106 echo "LOOKUP_${mod_name}_LIBS = $(pkg-config --libs $pkgconf)"
107 else
108 grep "^LOOKUP_${lookup_name}_" "$defs_source"
109 echo "LOOKUP_${mod_name}_INCLUDE = \$(LOOKUP_${lookup_name}_INCLUDE)"
110 echo "LOOKUP_${mod_name}_LIBS = \$(LOOKUP_${lookup_name}_LIBS)"
111 fi
112 elif want_at_all "$lookup_name"
113 then
114 OBJ="${OBJ} ${mod_name}.o"
115 fi
116 }
117
118 rm -f "$target"
119 exec 5>&1
120 exec > "$target"
121
122 sed -n "1,/$tag_marker/p" < "$input"
123
124 for name_mod in \
125 CDB DBM:dbmdb DNSDB DSEARCH IBASE LSEARCH MYSQL NIS NISPLUS ORACLE \
126 PASSWD PGSQL SQLITE TESTDB WHOSON
127 do
128 emit_module_rule $name_mod
129 done
130
131 if want_at_all LDAP
132 then
133 OBJ="${OBJ} ldap.o"
134 fi
135
136 # Because the variable is EXPERIMENTAL_SPF and not LOOKUP_SPF we
137 # always include spf.o and compile a dummy if EXPERIMENTAL_SPF is not
138 # defined.
139
140 OBJ="${OBJ} spf.o"
141
142 echo "MODS = $MODS"
143 echo "OBJ = $OBJ"
144
145 sed -n "/$tag_marker/,\$p" < "$input"
146
147 exec >&5
148
149 # Configure-Makefile will move $target into place
150
151 # vim: set ft=sh sw=2 :