Hi Antonio, > I acknowledge that the two mechanisms are different, in particular > because git *writes* the gitmodules file itself. > > I am not opposed to change the name, something like > 'core.submodulesConfigFile' might highlight that the syntax of the file > is the one of git config, but I think it's too long. I was not speculating on a better name, but on the nature of the configuration, gitignore is additive and errors are easy to see, but in gitmodules, there is only one "correct" path+name, so the problem space is not additive, rather we can have a discussion where we get the correct config from with low odds of errors. >> > The new configuration setting can be used to set an *alternative* >> > location for the gitmodules file; IMHO there is no need to provide >> > *additional* locations like in the case of exclude files. >> >> I think there *may* be a need for additional files. >> Currently there is only the .gitmodules file and the configuration >> in .git/config overriding settings from .gitmodules. >> >> There was some discussion on the mailing list in the past, which >> presented a intermediate layer in between these two places, in >> a special ref, such that: >> base is in .gitmodules >> overwritten via refs/meta/submodules:.gitmodules >> overwritten via the .git/config >> >> The intermediate would be a config file that is tracked on another >> ref. This (a) decouples main project history from submodule history >> and (b) makes it easier to distribute as it is part of the repository. >> >> For example (a) is desired if you dig up an old project and the >> submodules have all moved from one git hosting provider to another. >> Another example would be when you fork a project with submodules >> and don't want to mess with the main history but you just want to >> adjust the submodule URLs. That is possible with such an intermediate >> additional place. >> >> For (b) you can imagine the fork that you want to distribute in your >> community and you don't want to tell everyone to change the >> submodule URLs, but instead you can provide them with a prepared >> .gitmodules file, that they have to place into that special ref (which >> can be done via fetching). >> >> I digress as these ideas seem to be orthogonal to your patch series, >> just FYI. prior discussion starting at: >> https://public-inbox.org/git/1462317985-640-1-git-send-email-sbeller@xxxxxxxxxx/ >> I recall there was a better discussion even prior to that, but have no >> link handy. >> > > Just to understand, is that 'refs/meta/submodules:.gitmodules' file > meant to be managed manually? Or do you imagine some options to > instruct "git submodule" to *write* to that file instead of .gitmodules? I imagined it to be managed manually as it would enable some workflows for downstream users of superproject repos. But I'd think a convenient way to write to this location would be super useful, so we ought to have that eventually. > In the latter case your idea could cover my use case too, couldn't it? I would think so, yes. > But most importantly, is this realistically going to be added? I plan on adding it eventually. It depends on the priorities and schedule, no promises, though. > Currently I am not that familiar with the git code base to do it > myself, and I've never explicitly dealt with special refs in git. I think core git only uses them for "actual refs", e.g. remote tracking branches are used to know about the sha1. This new special ref would be used to store content outside the main tree, so we'd have too lookup the blob in that not-checked-out commit and read and write there. > The approach of this patch series is a lot simpler, and something I can > work on in my spare time. > Presumably (b) could even be partially supported with my changes, by > having both '.gitmodules' and some custom '.gitmodules-alternative' > files in the repository and tell users to clone with: > > git clone --config core.submodulesFile=.gitmodules-alternative URL > > Not as clean as your idea but doable. Traditionally Git had a strong stance on not transporting config in the repo (except submodule URLs :/) itself, so I guess this .gitmodules-alternative would not be a file in the tree, but a URL or something? > [...] >> > Since the gitmodules file is meant to be checked in into the repository, >> > the overridden file path should be relative to the work-tree; is there >> > a way to enforce this constraint at run time (i.e. validate the config >> > value), or is it enough to have it documented? >> >> I think we'd want to check at run time, if we need this constraint. >> > > I'll look into it once we decide which the way to go. > > Thank you. > Thanks for bringing up this easier approach. Stefan