On Tue, Aug 31 2021, Derrick Stolee wrote: > On 8/31/2021 4:32 AM, Ævar Arnfjörð Bjarmason wrote: >> >> On Mon, Aug 30 2021, Johannes Schindelin via GitGitGadget wrote: >> >>> The `git` executable has these two very useful options: >>> >>> -C <directory>: >>> switch to the specified directory before performing any actions >>> >>> -c <key>=<value>: >>> temporarily configure this setting for the duration of the >>> specified scalar subcommand >>> >>> With this commit, we teach the `scalar` executable the same trick. >>> [...] >>> + while (argc > 1 && *argv[1] == '-') { >>> + if (!strcmp(argv[1], "-C")) { >>> + if (argc < 3) >>> + die(_("-C requires a <directory>")); >>> + if (chdir(argv[2]) < 0) >>> + die_errno(_("could not change to '%s'"), >>> + argv[2]); >>> + argc -= 2; >>> + argv += 2; >>> + } else if (!strcmp(argv[1], "-c")) { >>> + if (argc < 3) >>> + die(_("-c requires a <key>=<value> argument")); >>> + git_config_push_parameter(argv[2]); >>> + argc -= 2; >>> + argv += 2; >>> + } else >>> + break; >>> + } >> >> This along with my earlier comment about the Makefile copy/pasting makes >> me wonder if an easier way to integrate this wouldn't be to refactor >> git.c a bit to have it understand either "git" or "scalar", then instead >> of "ls-tree" etc. as "git" the subcommands would become "built-ins". >> >> Which would give us both "[git|scalar] [-c ...] <cmd>" for free, and >> elimante the need for the inevetable future divergence of wanting -p, >> -P, --exec-path etc. in both. > > Such a change would likely eliminate the ability to not include Scalar > when building the Git codebase, which we tried to avoid by keeping it > within contrib and have it be compiled via an opt-in flag. I mean to still have it behind a flag, but to handle it similar to how we handle NO_CURL, EXCLUDED_PROGRAMS and the like, i.e. not requiring parallel maintenance of copy/pasted Makefile logic in contrib/. > If we want to talk about integrating Scalar into Git in a deeper way, > then that is an interesting discussion to have, but it lives at a much > higher level than Makefile details. To be clear I'm proposing no change at all in term of what happens when you run "make install", just commenting on the implementation details of how we arrange for things to be built and configured before that step. I realize that this is following some prior art of e.g. contrib/subtree/Makefile, but IMNSHO that approach is a historical mistake we should be backing out of. There was some recent discussion of this here: https://lore.kernel.org/git/87pmz4ig4o.fsf@xxxxxxxxxxxxxxxxxxx/ E.g. now we have some painful management of the depencency graph between /Makefile and Documentation/Makefile requiring fixes like 56550ea7180 (Makefile: add missing dependencies of 'config-list.h', 2021-04-08), adding yet another Makefile into the mix which (to take one example) depends on doc.dep, which in turn depends on ...; It's all a bunch of needless complexity we can avoid. > The questions we are really looking to answer in this RFC are: > > 1. Will the Git project accept Scalar into its codebase? > > 2. What is the best place for Scalar to live in the Git codebase? > > We erred on the side of keeping Scalar as optional as possible. If > the community is more interested in a deeper integration, then that > could be an interesting direction. Indeed, to be clear I realize I'm entirely punting on the real questions you're interested in. I just gave this an initial cursory skimming for now, I have not formed an informed opinion on your #1, but just a little bit of #2. My initial reaction to #1 without having looked into it deeply is some combination of "sure, why not?", and that the people/group contributing major scalability work to git.git should be given the benefit of the doubt. Maybe we won't keep "scalar" long-term, or change its UI etc., all of that can be handled in some carefully worded documentation somewhere. Of course all these suggestions I'm making about Makefile arrangement are rather pointless if there isn't consensus to get past the hurdle of your #1. > In my opinion, I think the current tactic is safest. We could always > decide on a deeper integration later by moving the code around. It > seems harder to do the reverse. I think "deeper integration" is the reverse of what you think it is. I.e. if I'm patching or maintaining part of the Makefile logic to it's deeper (or perhaps "gnarlier" is the righ word?) integration to need to duplicate that work in two places, or always take into account that some not-built-by-default-but-quite-common command's *.txt docs and *.sh tests live in some unusual place for the purposes of CI, lint, tooling etc. In other words, it's a question of how much net complexity is being added to the (build) system. That complexity doesn't automatically reduce just because some files live in another directory, sometimes that's an increase in complexity. Whereas just conditionally adding it to some list in the top-level Makefile (or Documentation/Makefile) is relatively maintenance-free, and to our users / packagers the result should be the same or near enough. It won't matter to them if building the optional thing is another "make" command or just a flag to the existing "make" command.