Hi Peff, On Thu, 29 Mar 2018, Jeff King wrote: > On Thu, Mar 29, 2018 at 05:19:09PM +0200, Johannes Schindelin wrote: > > > It can happen quite easily that the last setting in a config section is > > removed, and to avoid confusion when there are comments in the config > > about that section, we keep a lone section header, i.e. an empty > > section. > > > > The code to add new entries in the config tries to be cute by reusing > > the parsing code that is used to retrieve config settings, but that > > poses the problem that the latter use case does *not* care about empty > > sections, therefore even the former user case won't see them. > > > > Fix this by introducing a mode where the parser reports also empty > > sections (with a trailing '.' as tell-tale), and then using that when > > adding new config entries. > > Heh, so it seems we are partway to the "event-stream" suggestion I made > earlier. I agree this is the right way to approach this problem. > > I wondered if we allow keys to end in ".", but it seems that we don't. > > > diff --git a/config.c b/config.c > > index eb1e0d335fc..b04c40f76bc 100644 > > --- a/config.c > > +++ b/config.c > > @@ -653,13 +653,15 @@ static int get_base_var(struct strbuf *name) > > } > > } > > > > -static int git_parse_source(config_fn_t fn, void *data) > > +static int git_parse_source(config_fn_t fn, void *data, > > + int include_section_headers) > > We already have a "struct config_options", but we do a terrible job of > passing it around (since it only impacts the include stuff right now, > and that all gets handled at a very outer level). > > Rather than plumb this one int through everywhere, should we add it to > that struct and plumb the struct through? Yesss! Again, thank you so much for this really valuable review. This is even better than what I hoped for. Ciao, Dscho