aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--main/postfix/APKBUILD28
-rw-r--r--main/postfix/dynamic-maps.patch (renamed from main/postfix/dynamic-maps3.patch)193
2 files changed, 123 insertions, 98 deletions
diff --git a/main/postfix/APKBUILD b/main/postfix/APKBUILD
index 063be4ec58..c9e1961f2d 100644
--- a/main/postfix/APKBUILD
+++ b/main/postfix/APKBUILD
@@ -1,7 +1,7 @@
# Maintainer: Natanael Copa <ncopa@alpinelinux.org>
pkgname=postfix
-pkgver=2.10.2
-pkgrel=1
+pkgver=2.11.1
+pkgrel=0
pkgdesc="Secure and fast drop-in replacement for Sendmail (MTA)"
url="http://www.postfix.org/"
arch="all"
@@ -14,7 +14,7 @@ subpackages="$pkgname-doc $pkgname-ldap $pkgname-mysql $pkgname-pcre
$pkgname-pgsql $pkgname-sqlite"
source="ftp://ftp.porcupine.org/mirrors/$pkgname-release/official/$pkgname-$pkgver.tar.gz
$pkgname.initd
- dynamic-maps3.patch
+ dynamic-maps.patch
dynamicmaps.cf
postfix-ldap.post-install
postfix-mysql.post-install
@@ -46,7 +46,7 @@ prepare() {
sed -i -e "s:/usr/local/:/usr/:g" conf/master.cf || return 1
}
-build () {
+build () {
cd "$srcdir/$pkgname-$pkgver"
# needed for dynamic maps.
local ccargs="-DHAS_DLOPEN -DHAS_SHL_LOAD"
@@ -60,7 +60,7 @@ build () {
# ssl
ccargs="$ccargs -DUSE_TLS"
- auxlibs="$auxlibs -lssl -lcrypto"
+ auxlibs="$auxlibs -lssl -lcrypto"
## dovecot-sasl
#ccargs="$ccargs -DUSE_SASL_AUTH -DDEF_SERVER_SASL_TYPE=\\\"dovecot\\\""
@@ -80,7 +80,7 @@ build () {
# ldap
ccargs="$ccargs -DHAS_LDAP"
#auxlibs="$auxlibs -lldap -llber"
-
+
# sqlite
ccargs="$ccargs -DHAS_SQLITE"
@@ -90,8 +90,8 @@ build () {
CCARGS="$ccargs" \
AUXLIBS="$auxlibs" \
makefiles || return 1
-
- make OPT="$CFLAGS" || return 1
+
+ make -j1 OPT="$CFLAGS" || return 1
}
package() {
@@ -159,27 +159,27 @@ pcre() { _mv_dict pcre ; }
pgsql() { _mv_dict pgsql ; }
sqlite() { _mv_dict sqlite ; }
-md5sums="109e753aecafe487207b425dd46e6ee9 postfix-2.10.2.tar.gz
+md5sums="56ac1f1a79737c4ac1e24535a122a4a6 postfix-2.11.1.tar.gz
d773f01dcc965d219a8a37b88f89c5bf postfix.initd
-cf6b5ddf6adabd12224c083b8b2ec5e8 dynamic-maps3.patch
+c03239969df760e2a74c4e048ce514a1 dynamic-maps.patch
442efd1a95b0c061dfb8ab75456e0f24 dynamicmaps.cf
2ebe51a882eb9d6d7866583eb6af3969 postfix-ldap.post-install
2ebe51a882eb9d6d7866583eb6af3969 postfix-mysql.post-install
fd16ec00b60269c4ede4a0a0a514cefa postfix-pcre.post-install
2ebe51a882eb9d6d7866583eb6af3969 postfix-pgsql.post-install
2ebe51a882eb9d6d7866583eb6af3969 postfix-sqlite.post-install"
-sha256sums="f1a735a5a9ffeac8fca59046c437c3b76e7f923fb4249db2a55b2bff0306ddd4 postfix-2.10.2.tar.gz
+sha256sums="487f98a73b95a5799409caf21ec065efea91c1dcdfb84c038a0e3a265d6489e2 postfix-2.11.1.tar.gz
6b3fe71542ab783c7adddbfa161f7e2dcb2325913ad5d611ca56f730876ce4ab postfix.initd
-d91df2fb9a4d6d535c58ab839a05abc228ef9b4a7d26a9162a1355b0f07d1188 dynamic-maps3.patch
+cfa5000955f1941082567a9e50764f52851f33c468f534c0431f6932d73e8ffb dynamic-maps.patch
2041ff6cd71fe16f3d75603ff40d90a08a8b97f0883e1de1d58563ab1521b5ea dynamicmaps.cf
fbd75ef31a5d78d5f82b67e08e5bf5ada380afa58a69ef4a07d756c47b3bb498 postfix-ldap.post-install
fbd75ef31a5d78d5f82b67e08e5bf5ada380afa58a69ef4a07d756c47b3bb498 postfix-mysql.post-install
8dbe9339aeac4932e5ee383bfe497512607cd819fe67c38cbf7273118c4b0f71 postfix-pcre.post-install
fbd75ef31a5d78d5f82b67e08e5bf5ada380afa58a69ef4a07d756c47b3bb498 postfix-pgsql.post-install
fbd75ef31a5d78d5f82b67e08e5bf5ada380afa58a69ef4a07d756c47b3bb498 postfix-sqlite.post-install"
-sha512sums="fa6c123da040a8e332c0bf2430f5b098523c2eff42a6cf4bfe6618b82d59be8e5a7f5c85b09ab8fd0312058b2135b174e00890423e4d3f8f732c3dc3c91f01c3 postfix-2.10.2.tar.gz
+sha512sums="988659ed7f256fdc831c6a211c33aede922d5baf32da7129afe0ec2fe5011ac95dacb21e59c92f658323b6ea773ebf2bcd66a796d9271c1e7b949d5d9b9ee977 postfix-2.11.1.tar.gz
c179534a7243bcf8c19b5367a703b54fcc88b7587ce7ef07ec111cfe00053779eed23b3ccda81eb20059599b857cae0a57cc02613526209f3dd966d65abd9a3f postfix.initd
-31f3900152444d6af019dda63cbbb715d401d0727d05b6a813a93f54f43d1f02fa4cfeee69b0e01ba279bdebcd0463e0691f9a0c4afcc98980a52ea043812d08 dynamic-maps3.patch
+1a92089410691d400953472be522c872be1456521203560a4feadb632cb85cfacaf3721108d62111873fb23478976b8a949077734cf801374ca58bcaf363922c dynamic-maps.patch
49b8205166f575e5fb9bdaaaaa042dc1be9b556331bf659a55b1115c9fa48486896941f18ca9fb633dd54675079f29a9d69d53c214170731c2127862456ec90b dynamicmaps.cf
b35931865eb15b5cd6a2b95bbf486cd064d1447eac1a91d507a7d23155229ac7e7fdf6b8518e663c5c7072b201786c72aead0d95e94d8708a9b5a7c3f37be138 postfix-ldap.post-install
b35931865eb15b5cd6a2b95bbf486cd064d1447eac1a91d507a7d23155229ac7e7fdf6b8518e663c5c7072b201786c72aead0d95e94d8708a9b5a7c3f37be138 postfix-mysql.post-install
diff --git a/main/postfix/dynamic-maps3.patch b/main/postfix/dynamic-maps.patch
index 81848ab744..b19446c74d 100644
--- a/main/postfix/dynamic-maps3.patch
+++ b/main/postfix/dynamic-maps.patch
@@ -1,5 +1,5 @@
diff --git a/conf/postfix-files b/conf/postfix-files
-index 90ef957..c4c522a 100644
+index 9e1804a..daa6328 100644
--- a/conf/postfix-files
+++ b/conf/postfix-files
@@ -65,6 +65,11 @@ $queue_directory/saved:d:$mail_owner:-:700:ucr
@@ -62,7 +62,7 @@ index bbc5e98..e14c6fe 100644
update: $(LIB_DIR)/$(LIB) $(HDRS)
-for i in $(HDRS); \
diff --git a/src/global/Makefile.in b/src/global/Makefile.in
-index d8fb3db..0b26b6f 100644
+index 2e7ec04..8d541bc 100644
--- a/src/global/Makefile.in
+++ b/src/global/Makefile.in
@@ -37,8 +37,8 @@ OBJS = abounce.o anvil_clnt.o been_here.o bounce.o bounce_log.o \
@@ -76,7 +76,7 @@ index d8fb3db..0b26b6f 100644
dsb_scan.o dsn.o dsn_buf.o dsn_mask.o dsn_print.o dsn_util.o \
ehlo_mask.o ext_prop.o file_id.o flush_clnt.o header_opts.o \
header_token.o input_transp.o int_filt.o is_header.o log_adhoc.o \
-@@ -112,10 +112,14 @@ LIBS = ../../lib/libutil.a
+@@ -113,10 +113,14 @@ LIBS = ../../lib/libutil.a
LIB_DIR = ../../lib
INC_DIR = ../../include
MAKES =
@@ -93,7 +93,7 @@ index d8fb3db..0b26b6f 100644
$(OBJS): ../../conf/makedefs.out
-@@ -125,14 +129,36 @@ Makefile: Makefile.in
+@@ -126,14 +130,36 @@ Makefile: Makefile.in
test: $(TESTPROG)
$(LIB): $(OBJS)
@@ -134,7 +134,7 @@ index d8fb3db..0b26b6f 100644
-for i in $(HDRS); \
do \
cmp -s $$i $(INC_DIR)/$$i 2>/dev/null || cp $$i $(INC_DIR); \
-@@ -577,7 +603,7 @@ lint:
+@@ -584,7 +610,7 @@ lint:
lint $(DEFS) $(SRCS) $(LINTFIX)
clean:
@@ -181,7 +181,7 @@ index 6dbf6ee..ff0eee6 100644
0,
};
diff --git a/src/global/mail_params.c b/src/global/mail_params.c
-index 0e098b3..dac095d 100644
+index 6e4378c..9dab202 100644
--- a/src/global/mail_params.c
+++ b/src/global/mail_params.c
@@ -79,6 +79,7 @@
@@ -200,7 +200,7 @@ index 0e098b3..dac095d 100644
/* char *var_trace_service;
/* char *var_proxymap_service;
/* char *var_proxywrite_service;
-@@ -268,6 +270,7 @@ char *var_import_environ;
+@@ -274,6 +276,7 @@ char *var_import_environ;
char *var_export_environ;
char *var_debug_peer_list;
int var_debug_peer_level;
@@ -208,7 +208,7 @@ index 0e098b3..dac095d 100644
int var_fault_inj_code;
char *var_bounce_service;
char *var_cleanup_service;
-@@ -279,6 +282,7 @@ char *var_showq_service;
+@@ -285,6 +288,7 @@ char *var_showq_service;
char *var_error_service;
char *var_flush_service;
char *var_verify_service;
@@ -217,10 +217,10 @@ index 0e098b3..dac095d 100644
char *var_proxymap_service;
char *var_proxywrite_service;
diff --git a/src/global/mkmap_open.c b/src/global/mkmap_open.c
-index d939d44..b2e729e 100644
+index dfa9bc2..30409aa 100644
--- a/src/global/mkmap_open.c
+++ b/src/global/mkmap_open.c
-@@ -82,7 +82,7 @@
+@@ -83,7 +83,7 @@
* We use a different table (in dict_open.c) when querying maps.
*/
typedef struct {
@@ -229,28 +229,28 @@ index d939d44..b2e729e 100644
MKMAP *(*before_open) (const char *);
} MKMAP_OPEN_INFO;
-@@ -161,7 +161,16 @@ MKMAP *mkmap_open(const char *type, const char *path,
+@@ -166,7 +166,16 @@ MKMAP *mkmap_open(const char *type, const char *path,
*/
for (mp = mkmap_types; /* void */ ; mp++) {
if (mp->type == 0)
+#ifndef NO_DYNAMIC_MAPS
-+ {
-+ static MKMAP_OPEN_INFO oi;
-+ oi.before_open=(MKMAP*(*)(const char*))dict_mkmap_func(type);
-+ oi.type=type;
-+ mp=&oi;
-+ }
++ {
++ static MKMAP_OPEN_INFO oi;
++ oi.before_open=(MKMAP*(*)(const char*))dict_mkmap_func(type);
++ oi.type=type;
++ mp=&oi;
++ }
+#else
- msg_fatal("unsupported map type: %s", type);
+ msg_fatal("unsupported map type for this operation: %s", type);
+#endif
if (strcmp(type, mp->type) == 0)
break;
}
diff --git a/src/master/Makefile.in b/src/master/Makefile.in
-index f1a59f6..0eb5d2d 100644
+index d1be8fe..be0bb69 100644
--- a/src/master/Makefile.in
+++ b/src/master/Makefile.in
-@@ -20,7 +20,7 @@ LIB_DIR = ../../lib
+@@ -22,7 +22,7 @@ LIB_DIR = ../../lib
INC_DIR = ../../include
BIN_DIR = ../../libexec
@@ -259,7 +259,7 @@ index f1a59f6..0eb5d2d 100644
all: $(PROG) $(LIB)
-@@ -39,12 +39,10 @@ tests:
+@@ -41,12 +41,10 @@ tests:
root_tests:
$(LIB): $(LIB_OBJ)
@@ -274,7 +274,7 @@ index f1a59f6..0eb5d2d 100644
$(BIN_DIR)/$(PROG): $(PROG)
cp $(PROG) $(BIN_DIR)
diff --git a/src/milter/Makefile.in b/src/milter/Makefile.in
-index c28263a..c475629 100644
+index 99b6469..0769778 100644
--- a/src/milter/Makefile.in
+++ b/src/milter/Makefile.in
@@ -14,7 +14,7 @@ LIB_DIR = ../../lib
@@ -301,10 +301,10 @@ index c28263a..c475629 100644
update: $(LIB_DIR)/$(LIB) $(HDRS)
-for i in $(HDRS); \
diff --git a/src/postconf/postconf_other.c b/src/postconf/postconf_other.c
-index 04f9404..1752450 100644
+index e93dfab..ac415ba 100644
--- a/src/postconf/postconf_other.c
+++ b/src/postconf/postconf_other.c
-@@ -55,6 +55,10 @@
+@@ -56,6 +56,10 @@
#include <xsasl.h>
@@ -315,7 +315,7 @@ index 04f9404..1752450 100644
/* Application-specific. */
#include <postconf.h>
-@@ -65,7 +69,16 @@ void show_maps(void)
+@@ -66,7 +70,16 @@ void pcf_show_maps(void)
{
ARGV *maps_argv;
int i;
@@ -325,7 +325,7 @@ index 04f9404..1752450 100644
+ char *config_dir;
+
+ if (var_config_dir == 0)
-+ set_config_dir();
++ pcf_set_config_dir();
+ path = concatenate(var_config_dir, "/", "dynamicmaps.cf", (char *) 0);
+ dict_open_dlinfo(path);
+ myfree(path);
@@ -334,7 +334,7 @@ index 04f9404..1752450 100644
for (i = 0; i < maps_argv->argc; i++)
vstream_printf("%s\n", maps_argv->argv[i]);
diff --git a/src/postmap/postmap.c b/src/postmap/postmap.c
-index 8249d79..8833dc4 100644
+index e10ac16..92e85d6 100644
--- a/src/postmap/postmap.c
+++ b/src/postmap/postmap.c
@@ -5,7 +5,7 @@
@@ -355,7 +355,7 @@ index 8249d79..8833dc4 100644
/* .IP \fB-v\fR
/* Enable verbose logging for debugging purposes. Multiple \fB-v\fR
/* options make the software increasingly verbose.
-@@ -748,6 +750,18 @@ static void postmap_seq(const char *map_type, const char *map_name,
+@@ -764,6 +766,18 @@ static void postmap_seq(const char *map_type, const char *map_name,
dict_close(dict);
}
@@ -374,7 +374,7 @@ index 8249d79..8833dc4 100644
/* usage - explain */
static NORETURN usage(char *myname)
-@@ -768,6 +782,7 @@ int main(int argc, char **argv)
+@@ -784,6 +798,7 @@ int main(int argc, char **argv)
int postmap_flags = POSTMAP_FLAG_AS_OWNER | POSTMAP_FLAG_SAVE_PERM;
int open_flags = O_RDWR | O_CREAT | O_TRUNC;
int dict_flags = DICT_FLAG_DUP_WARN | DICT_FLAG_FOLD_FIX;
@@ -382,7 +382,7 @@ index 8249d79..8833dc4 100644
char *query = 0;
char *delkey = 0;
int sequence = 0;
-@@ -817,7 +832,7 @@ int main(int argc, char **argv)
+@@ -833,7 +848,7 @@ int main(int argc, char **argv)
/*
* Parse JCL.
*/
@@ -391,7 +391,7 @@ index 8249d79..8833dc4 100644
switch (ch) {
default:
usage(argv[0]);
-@@ -834,8 +849,8 @@ int main(int argc, char **argv)
+@@ -850,8 +865,8 @@ int main(int argc, char **argv)
msg_fatal("out of memory");
break;
case 'd':
@@ -402,7 +402,7 @@ index 8249d79..8833dc4 100644
delkey = optarg;
break;
case 'f':
-@@ -861,8 +876,8 @@ int main(int argc, char **argv)
+@@ -877,8 +892,8 @@ int main(int argc, char **argv)
postmap_flags &= ~POSTMAP_FLAG_SAVE_PERM;
break;
case 'q':
@@ -413,7 +413,7 @@ index 8249d79..8833dc4 100644
query = optarg;
break;
case 'r':
-@@ -870,10 +885,15 @@ int main(int argc, char **argv)
+@@ -886,10 +901,15 @@ int main(int argc, char **argv)
dict_flags |= DICT_FLAG_DUP_REPLACE;
break;
case 's':
@@ -431,7 +431,7 @@ index 8249d79..8833dc4 100644
case 'v':
msg_verbose++;
break;
-@@ -944,6 +964,21 @@ int main(int argc, char **argv)
+@@ -964,6 +984,21 @@ int main(int argc, char **argv)
exit(0);
}
exit(1);
@@ -454,7 +454,7 @@ index 8249d79..8833dc4 100644
if (optind + 1 > argc)
usage(argv[0]);
diff --git a/src/tls/Makefile.in b/src/tls/Makefile.in
-index 1dbe154..b952aa4 100644
+index 1af9419..5a9a814 100644
--- a/src/tls/Makefile.in
+++ b/src/tls/Makefile.in
@@ -24,7 +24,7 @@ LIB_DIR = ../../lib
@@ -480,8 +480,21 @@ index 1dbe154..b952aa4 100644
update: $(LIB_DIR)/$(LIB) $(HDRS)
-for i in $(HDRS); \
+diff --git a/src/tlsproxy/Makefile.in b/src/tlsproxy/Makefile.in
+index 137752a..b669790 100644
+--- a/src/tlsproxy/Makefile.in
++++ b/src/tlsproxy/Makefile.in
+@@ -9,7 +9,7 @@ TESTPROG=
+ PROG = tlsproxy
+ INC_DIR = ../../include
+ LIBS = ../../lib/libtls.a ../../lib/libmaster.a ../../lib/libglobal.a \
+- ../../lib/libutil.a
++ ../../lib/libutil.a ../../lib/libdns.a
+
+ .c.o:; $(CC) $(CFLAGS) -c $*.c
+
diff --git a/src/util/Makefile.in b/src/util/Makefile.in
-index dc7a4bb..4454085 100644
+index 5ab2232..c3c37b1 100644
--- a/src/util/Makefile.in
+++ b/src/util/Makefile.in
@@ -1,5 +1,6 @@
@@ -491,16 +504,19 @@ index dc7a4bb..4454085 100644
attr_print64.c attr_print_plain.c attr_scan0.c attr_scan64.c \
attr_scan_plain.c auto_clnt.c base64_code.c basename.c binhash.c \
chroot_uid.c cidr_match.c clean_env.c close_on_exec.c concatenate.c \
-@@ -36,13 +37,14 @@ SRCS = alldig.c allprint.c argv.c argv_split.c attr_clnt.c attr_print0.c \
- ip_match.c nbbio.c stream_pass_connect.c base32_code.c dict_test.c \
- dict_fail.c msg_rate_delay.c dict_surrogate.c warn_stat.c
- OBJS = alldig.o allprint.o argv.o argv_split.o attr_clnt.o attr_print0.o \
-+ load_lib.o \
- attr_print64.o attr_print_plain.o attr_scan0.o attr_scan64.o \
- attr_scan_plain.o auto_clnt.o base64_code.o basename.o binhash.o \
+@@ -12,7 +13,7 @@ SRCS = alldig.c allprint.c argv.c argv_split.c attr_clnt.c attr_print0.c \
+ fullname.c get_domainname.c get_hostname.c hex_code.c hex_quote.c \
+ host_port.c htable.c inet_addr_host.c inet_addr_list.c \
+ inet_addr_local.c inet_connect.c inet_listen.c inet_proto.c \
+- inet_trigger.c line_wrap.c lowercase.c lstat_as.c mac_expand.c \
++ inet_trigger.c load_lib.c line_wrap.c lowercase.c lstat_as.c mac_expand.c \
+ mac_parse.c make_dirs.c mask_addr.c match_list.c match_ops.c msg.c \
+ msg_output.c msg_syslog.c msg_vstream.c mvect.c myaddrinfo.c myflock.c \
+ mymalloc.c myrand.c mystrtok.c name_code.c name_mask.c netstring.c \
+@@ -43,14 +44,14 @@ OBJS = alldig.o allprint.o argv.o argv_split.o attr_clnt.o attr_print0.o \
chroot_uid.o cidr_match.o clean_env.o close_on_exec.o concatenate.o \
ctable.o dict.o dict_alloc.o dict_cdb.o dict_cidr.o dict_db.o \
- dict_dbm.o dict_debug.o dict_env.o dict_ht.o dict_ni.o dict_nis.o \
+ dict_dbm.o dict_debug.o dict_env.o dict_ht.o dict_lmdb.o dict_ni.o dict_nis.o \
- dict_nisplus.o dict_open.o dict_pcre.o dict_regexp.o dict_sdbm.o \
- dict_static.o dict_tcp.o dict_unix.o dir_forest.o doze.o dummy_read.o \
+ dict_nisplus.o dict_open.o dict_regexp.o dict_sdbm.o \
@@ -508,15 +524,22 @@ index dc7a4bb..4454085 100644
dummy_write.o duplex_pipe.o environ.o events.o exec_command.o \
fifo_listen.o fifo_trigger.o file_limit.o find_inet.o fsspace.o \
fullname.o get_domainname.o get_hostname.o hex_code.o hex_quote.o \
-@@ -72,6 +74,7 @@ OBJS = alldig.o allprint.o argv.o argv_split.o attr_clnt.o attr_print0.o \
- ip_match.o nbbio.o stream_pass_connect.o base32_code.o dict_test.o \
- dict_fail.o msg_rate_delay.o dict_surrogate.o warn_stat.o
+ host_port.o htable.o inet_addr_host.o inet_addr_list.o \
+ inet_addr_local.o inet_connect.o inet_listen.o inet_proto.o \
+- inet_trigger.o line_wrap.o lowercase.o lstat_as.o mac_expand.o \
++ inet_trigger.o load_lib.o line_wrap.o lowercase.o lstat_as.o mac_expand.o \
+ mac_parse.o make_dirs.o mask_addr.o match_list.o match_ops.o msg.o \
+ msg_output.o msg_syslog.o msg_vstream.o mvect.o myaddrinfo.o myflock.o \
+ mymalloc.o myrand.o mystrtok.o name_code.o name_mask.o netstring.o \
+@@ -76,6 +77,7 @@ OBJS = alldig.o allprint.o argv.o argv_split.o attr_clnt.o attr_print0.o \
+ dict_sockmap.o line_number.o recv_pass_attr.o pass_accept.o \
+ poll_fd.o timecmp.o slmdb.o
HDRS = argv.h attr.h attr_clnt.h auto_clnt.h base64_code.h binhash.h \
+ load_lib.h \
chroot_uid.h cidr_match.h clean_env.h connect.h ctable.h dict.h \
dict_cdb.h dict_cidr.h dict_db.h dict_dbm.h dict_env.h dict_ht.h \
- dict_ni.h dict_nis.h dict_nisplus.h dict_pcre.h dict_regexp.h \
-@@ -98,6 +101,7 @@ DEFS = -I. -D$(SYSTYPE)
+ dict_lmdb.h dict_ni.h dict_nis.h dict_nisplus.h dict_pcre.h dict_regexp.h \
+@@ -103,6 +105,7 @@ DEFS = -I. -D$(SYSTYPE)
CFLAGS = $(DEBUG) $(OPT) $(DEFS)
FILES = Makefile $(SRCS) $(HDRS)
INCL =
@@ -524,7 +547,7 @@ index dc7a4bb..4454085 100644
LIB = libutil.a
TESTPROG= dict_open dup2_pass_on_exec events exec_command fifo_open \
fifo_rdonly_bug fifo_rdwr_bug fifo_trigger fsspace fullname \
-@@ -113,10 +117,11 @@ TESTPROG= dict_open dup2_pass_on_exec events exec_command fifo_open \
+@@ -119,10 +122,11 @@ TESTPROG= dict_open dup2_pass_on_exec events exec_command fifo_open \
LIB_DIR = ../../lib
INC_DIR = ../../include
@@ -538,7 +561,7 @@ index dc7a4bb..4454085 100644
$(OBJS): ../../conf/makedefs.out
-@@ -125,15 +130,19 @@ Makefile: Makefile.in
+@@ -131,15 +135,19 @@ Makefile: Makefile.in
test: $(TESTPROG)
@@ -562,7 +585,7 @@ index dc7a4bb..4454085 100644
-for i in $(HDRS); \
do \
cmp -s $$i $(INC_DIR)/$$i 2>/dev/null || cp $$i $(INC_DIR); \
-@@ -155,7 +164,7 @@ lint:
+@@ -161,7 +169,7 @@ lint:
lint $(DEFS) $(SRCS) $(LINTFIX)
clean:
@@ -572,18 +595,18 @@ index dc7a4bb..4454085 100644
tidy: clean
diff --git a/src/util/dict.h b/src/util/dict.h
-index f8e91a4..d7ae8fe 100644
+index a217603..9a84b1d 100644
--- a/src/util/dict.h
+++ b/src/util/dict.h
-@@ -80,6 +80,7 @@ extern DICT *dict_debug(DICT *);
+@@ -94,6 +94,7 @@ extern DICT *dict_debug(DICT *);
#define DICT_FLAG_NO_UNAUTH (1<<13) /* disallow unauthenticated data */
#define DICT_FLAG_FOLD_FIX (1<<14) /* case-fold key with fixed-case map */
#define DICT_FLAG_FOLD_MUL (1<<15) /* case-fold key with multi-case map */
+#define DICT_FLAG_UPGRADE (1<<30) /* Upgrade the db */
#define DICT_FLAG_FOLD_ANY (DICT_FLAG_FOLD_FIX | DICT_FLAG_FOLD_MUL)
- #define DICT_FLAG_OPEN_LOCK (1<<16) /* open file with exclusive lock */
-
-@@ -166,6 +167,11 @@ extern int dict_error(const char *);
+ #define DICT_FLAG_OPEN_LOCK (1<<16) /* perm lock if not multi-writer safe */
+ #define DICT_FLAG_BULK_UPDATE (1<<17) /* optimize for bulk updates */
+@@ -187,6 +188,11 @@ extern int dict_error(const char *);
extern DICT *dict_open(const char *, int, int);
extern DICT *dict_open3(const char *, const char *, int, int);
extern void dict_open_register(const char *, DICT *(*) (const char *, int, int));
@@ -613,11 +636,11 @@ index 93ee480..cf382e3 100644
if ((errno = db->open(db, 0, db_path, 0, type, db_flags, 0644)) != 0)
FREE_RETURN(dict_surrogate(class, path, open_flags, dict_flags,
diff --git a/src/util/dict_dbm.c b/src/util/dict_dbm.c
-index 37e1463..56fd3dc 100644
+index a1f25ff..5c64412 100644
--- a/src/util/dict_dbm.c
+++ b/src/util/dict_dbm.c
@@ -417,6 +417,10 @@ DICT *dict_dbm_open(const char *path, int open_flags, int dict_flags)
- char *dbm_path;
+ char *dbm_path = 0;
int lock_fd;
+#ifdef HAVE_GDBM
@@ -625,42 +648,44 @@ index 37e1463..56fd3dc 100644
+ path);
+#endif
/*
- * Note: DICT_FLAG_LOCK is used only by programs that do fine-grained (in
- * the time domain) locking while accessing individual database records.
+ * Let the optimizer worry about eliminating redundant code.
+ */
diff --git a/src/util/dict_open.c b/src/util/dict_open.c
-index 7b7c0c5..241c337 100644
+index c8706da..2bad6dc 100644
--- a/src/util/dict_open.c
+++ b/src/util/dict_open.c
-@@ -44,6 +44,8 @@
- /* DICT *(*open) (const char *, int, int);
+@@ -45,6 +45,7 @@
/*
/* ARGV *dict_mapnames()
-+/*
-+/* void (*)() dict_mkmap_func(const char *dict_type)
- /* DESCRIPTION
- /* This module implements a low-level interface to multiple
- /* physical dictionary types.
-@@ -166,6 +168,9 @@
/*
++/* void (*)() dict_mkmap_func(const char *dict_type)
+ /* int dict_isjmp(dict)
+ /* DICT *dict;
+ /*
+@@ -193,6 +194,9 @@
/* dict_mapnames() returns a sorted list with the names of all available
/* dictionary types.
+ /*
++/* dict_mkmap_func() returns a pointer to the mkmap setup function
++/* for the given map type, as given in /etc/dynamicmaps.cf
+/*
-+/* dict_mkmap_func() returns a pointer to the mkmap setup function
-+/* for the given map type, as given in /etc/dynamicmaps.cf
- /* DIAGNOSTICS
- /* Fatal error: open error, unsupported dictionary type, attempt to
- /* update non-writable dictionary.
-@@ -213,6 +218,9 @@
+ /* dict_setjmp() saves processing context and makes that context
+ /* available for use with dict_longjmp(). Normally, dict_setjmp()
+ /* returns zero. A non-zero result means that dict_setjmp()
+@@ -251,6 +255,12 @@
#include <strings.h>
#endif
+#include <sys/stat.h>
+#include <unistd.h>
+
++#include <sys/stat.h>
++#include <unistd.h>
++
/* Utility library. */
#include <argv.h>
-@@ -241,6 +249,27 @@
+@@ -281,6 +291,27 @@
#include <htable.h>
#include <myflock.h>
@@ -688,7 +713,7 @@ index 7b7c0c5..241c337 100644
/*
* lookup table for available map types.
*/
-@@ -256,7 +285,9 @@ static const DICT_OPEN_INFO dict_open_info[] = {
+@@ -296,7 +327,9 @@ static const DICT_OPEN_INFO dict_open_info[] = {
DICT_TYPE_ENVIRON, dict_env_open,
DICT_TYPE_HT, dict_ht_open,
DICT_TYPE_UNIX, dict_unix_open,
@@ -698,7 +723,7 @@ index 7b7c0c5..241c337 100644
#ifdef HAS_SDBM
DICT_TYPE_SDBM, dict_sdbm_open,
#endif
-@@ -276,9 +307,11 @@ static const DICT_OPEN_INFO dict_open_info[] = {
+@@ -319,9 +352,11 @@ static const DICT_OPEN_INFO dict_open_info[] = {
#ifdef HAS_NETINFO
DICT_TYPE_NETINFO, dict_ni_open,
#endif
@@ -710,7 +735,7 @@ index 7b7c0c5..241c337 100644
#ifdef HAS_POSIX_REGEXP
DICT_TYPE_REGEXP, dict_regexp_open,
#endif
-@@ -338,9 +371,28 @@ DICT *dict_open3(const char *dict_type, const char *dict_name,
+@@ -382,9 +417,28 @@ DICT *dict_open3(const char *dict_type, const char *dict_name,
dict_type, dict_name);
if (dict_open_hash == 0)
dict_open_init();
@@ -740,7 +765,7 @@ index 7b7c0c5..241c337 100644
if ((dict = dp->open(dict_name, open_flags, dict_flags)) == 0)
return (dict_surrogate(dict_type, dict_name, open_flags, dict_flags,
"cannot open %s:%s: %m", dict_type, dict_name));
-@@ -359,6 +411,36 @@ DICT *dict_open3(const char *dict_type, const char *dict_name,
+@@ -408,6 +462,36 @@ DICT *dict_open3(const char *dict_type, const char *dict_name,
return (dict);
}
@@ -777,7 +802,7 @@ index 7b7c0c5..241c337 100644
/* dict_open_register - register dictionary type */
void dict_open_register(const char *type,
-@@ -392,6 +474,9 @@ ARGV *dict_mapnames()
+@@ -441,6 +525,9 @@ ARGV *dict_mapnames()
HTABLE_INFO **ht;
DICT_OPEN_INFO *dp;
ARGV *mapnames;
@@ -787,7 +812,7 @@ index 7b7c0c5..241c337 100644
if (dict_open_hash == 0)
dict_open_init();
-@@ -400,6 +485,13 @@ ARGV *dict_mapnames()
+@@ -449,6 +536,13 @@ ARGV *dict_mapnames()
dp = (DICT_OPEN_INFO *) ht[0]->value;
argv_add(mapnames, dp->type, ARGV_END);
}
@@ -801,7 +826,7 @@ index 7b7c0c5..241c337 100644
qsort((void *) mapnames->argv, mapnames->argc, sizeof(mapnames->argv[0]),
dict_sort_alpha_cpp);
myfree((char *) ht_info);
-@@ -407,6 +499,89 @@ ARGV *dict_mapnames()
+@@ -456,6 +550,89 @@ ARGV *dict_mapnames()
return mapnames;
}