summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorJeremy Harris <jgh146exb@wizmail.org>2016-10-30 19:05:26 +0000
committerJeremy Harris <jgh146exb@wizmail.org>2016-11-02 21:41:03 +0000
commit81f0a58e297b6e2f3d30f3d1c60832977da25c43 (patch)
tree78e179f0cf2f6e35a86e8f8901481881bcd51a19 /src
parent1f187290089991b306083d9418a6cacb6a400f6b (diff)
Reverse the scan direction for option-table builtin macros
so that names with substring-names work usefully
Diffstat (limited to 'src')
-rw-r--r--src/src/readconf.c13
1 files changed, 11 insertions, 2 deletions
diff --git a/src/src/readconf.c b/src/src/readconf.c
index f53a5d27a..9cbad8474 100644
--- a/src/src/readconf.c
+++ b/src/src/readconf.c
@@ -567,6 +567,7 @@ macro_create(const uschar * name, const uschar * val,
unsigned namelen = Ustrlen(name);
macro_item * m = store_get(sizeof(macro_item) + namelen);
+/* fprintf(stderr, "%s: '%s' '%s'\n", __FUNCTION__, name, val) */
if (!macros)
{
macros = m;
@@ -865,8 +866,14 @@ readconf_options_from_list(optionlist * opts, unsigned nopt, uschar * group)
int i;
const uschar * s;
-/* Walk the array backwards to get substring-conflict names */
-for (i = nopt-1; i >= 0; i--) if (*(s = opts[i].name) && *s != '*')
+/* The 'previously-defined-substring' rule for macros in config file
+lines is done so for these builtin macros: we know that the table
+we source from is in strict alpha order, hence the builtins portion
+of the macros list is in reverse-alpha (we prepend them) - so longer
+macros that have substrings are always discovered first during
+expansion. */
+
+for (i = 0; i < nopt; i++) if (*(s = opts[i].name) && *s != '*')
macro_create(string_sprintf("_OPT_%T_%T", group, s), US"y", FALSE, TRUE);
}
@@ -1009,6 +1016,7 @@ for (;;)
for (t = s; (p = CUstrchr(t, '_')); t = p+1)
if (c = p[1], c == 'O' || c == 'D' || c == 'H')
{
+/* fprintf(stderr, "%s: builtins create triggered by '%s'\n", __FUNCTION__, s); */
macros_create_builtin();
break;
}
@@ -1028,6 +1036,7 @@ for (;;)
int moveby;
int replen = Ustrlen(m->replacement);
+/* fprintf(stderr, "%s: matched '%s' in '%s'\n", __FUNCTION__, m->name, t) */
/* Expand the buffer if necessary */
while (newlen - m->namelen + replen + 1 > big_buffer_size)