X-Git-Url: https://git.exim.org/exim.git/blobdiff_plain/6d9b05ae272ca2122b48451c317d601e449af932..b94ea1bd61485a97c2d0dc2cab4c4d86ffe82e89:/src/src/functions.h diff --git a/src/src/functions.h b/src/src/functions.h index 5db9bc610..39119ca09 100644 --- a/src/src/functions.h +++ b/src/src/functions.h @@ -157,7 +157,7 @@ extern gstring *authres_spf(gstring *); extern uschar *b64encode(const uschar *, int); extern uschar *b64encode_taint(const uschar *, int, const void *); -extern int b64decode(const uschar *, uschar **); +extern int b64decode(const uschar *, uschar **, const void *); extern int bdat_getc(unsigned); extern uschar *bdat_getbuf(unsigned *); extern BOOL bdat_hasc(void); @@ -576,6 +576,7 @@ extern uschar *string_dequote(const uschar **); extern uschar *string_format_size(int, uschar *); extern int string_interpret_escape(const uschar **); extern int string_is_ip_address(const uschar *, int *); +extern int string_is_ip_addressX(const uschar *, int *, const uschar **); #ifdef SUPPORT_I18N extern BOOL string_is_utf8(const uschar *); #endif @@ -1109,6 +1110,22 @@ store_free_dns_answer_trc(dns_answer * dnsa, const uschar * func, unsigned line) store_free_3(dnsa, CCS func, line); } + +/* Check for an RR being large enough. Return TRUE iff bad. */ +static inline BOOL +rr_bad_size(const dns_record * rr, size_t minbytes) +{ +return rr->size < minbytes; +} + +/* Check for an RR having further data beyond a given pointer. +Return TRUE iff bad. */ +static inline BOOL +rr_bad_increment(const dns_record * rr, const uschar * ptr, size_t minbytes) +{ +return rr_bad_size(rr, ptr - rr->data + minbytes); +} + /******************************************************************************/ /* Routines with knowledge of spool layout */