diff options
author | Jeremy Harris <jgh146exb@wizmail.org> | 2016-10-30 19:05:26 +0000 |
---|---|---|
committer | Jeremy Harris <jgh146exb@wizmail.org> | 2016-11-02 21:41:03 +0000 |
commit | 81f0a58e297b6e2f3d30f3d1c60832977da25c43 (patch) | |
tree | 78e179f0cf2f6e35a86e8f8901481881bcd51a19 /src | |
parent | 1f187290089991b306083d9418a6cacb6a400f6b (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.c | 13 |
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) |