diff options
author | Jeremy Harris <jgh146exb@wizmail.org> | 2021-10-23 21:57:23 +0100 |
---|---|---|
committer | Jeremy Harris <jgh146exb@wizmail.org> | 2021-10-23 21:57:23 +0100 |
commit | 8f9402a038a0ad2ce5b4d60ba8891a3ef4f3f1ac (patch) | |
tree | eee4724dfc969f07bd76769a6ac06469669da7a5 | |
parent | df586a7720a17ac8221c9dfcf915d8185a25b282 (diff) |
Fix pcre2 interface for older versions
-rw-r--r-- | src/src/exim.c | 18 |
1 files changed, 3 insertions, 15 deletions
diff --git a/src/src/exim.c b/src/src/exim.c index a17dd92ad..a31a8a1b9 100644 --- a/src/src/exim.c +++ b/src/src/exim.c @@ -40,20 +40,7 @@ extern void init_lookup_list(void); for store allocation via Exim's store manager. The normal calls are actually macros that pass over location information to make tracing easier. These functions just interface to the standard macro calls. A good compiler will -optimize out the tail recursion and so not make them too expensive. There -are two sets of functions; one for use when we want to retain the compiled -regular expression for a long time; the other for short-term use. */ - -static void * -function_store_get(PCRE2_SIZE size, void * tag) -{ -/* For now, regard all RE results as potentially tainted. We might need -more intelligence on this point. */ -return store_get((int)size, TRUE); -} - -static void -function_dummy_free(void * block, void * tag) {} +optimize out the tail recursion and so not make them too expensive. */ static void * function_store_malloc(PCRE2_SIZE size, void * tag) @@ -64,7 +51,8 @@ return store_malloc((int)size); static void function_store_free(void * block, void * tag) { -store_free(block); +/* At least some version of pcre2 pass a null pointer */ +if (block) store_free(block); } |