On 7/1/2019 10:29 AM, Derrick Stolee via GitGitGadget wrote: > Here is a second run at this RFC, which aims to create a "meta" config > setting that automatically turns on other settings according to a user's > willingness to trade new Git behavior or new feature risk for performance > benefits. The new name for the setting is "core.featureAdoptionRate" and is > an integer scale from 0 to 10. There will be multiple "categories" of > settings, and the intention is to allow more granular levels as necessary. (Adding people who contributed feedback to CC line.) It seems that this "Feature Adoption Rate" idea was too simplistic, and had several issues. Time to take a different stab at this direction, but with these clear goals in mind: 1. We want intermediate users to be able to take advantage of new config options without watching every release for new config options. 2. The config name should match the general effect of the implied settings. 3. There are orthogonal settings that may not apply beneficially to all repos. With this in mind, I propose instead a set of "feature.*" config settings that form groups of "community recommended" settings (with some caveats). In the space below, I'll list a set of possible feature names and the implied config options. First, the main two categories we've discussed so far: many commits and many files. These two feature sets are for when your repo is large in one of these dimensions. Perhaps there are other settings to include in these? feature.manyFiles: index.version = 4 index.threads = true core.untrackedCache = true feature.manyCommits: core.commitGraph = true gc.writeCommitGraph = true (future: fetch.writeSplitCommitGraph = true) Note: the `fetch.writeSplitCommitGraph` does not exist yet, but could be introduced in a later release to write a new commit-graph (with --split) on fetch. The other category that has been discussed already is that of "experimental features that we generally think are helpful but change behavior slightly in some cases". feature.experimental: pack.useSparse = true status.aheadBehind = false fetch.showForcedUpdates = false merge.directoryRenames = true protocol.version = 2 fetch.negotiationAlgorithm = skipping We have not discussed anything like the next category, but Dscho thought a set of configs to make pretty diffs could be a fun "meta-config" setting: feature.prettyDiff: diff.color = auto ui.color = auto diff.context = 5 diff.colorMoved = true diff.colorMovedWs = allow-indentation-change diff.algorithm = minimal These are just a first round of suggestions. I'm sure we would enjoy a debate around an optimal set of diff settings. Finally, here is a kind of feature that I could imagine being helpful in the future, but maybe is not a good idea to pursue right now. In some cases users use "gc.auto = 0" to prevent all user-time blocking maintenance. This can degrade performance over time as loose objects and pack-files accumulate. The performance could mostly be recovered by using a multi-pack-index, but there is not current way to automatically write the file. This would not solve the space issues that happen here. feature.noGC: gc.auto = 0 core.multiPackIndex = true (future: fetch.writeMultiPackIndex = true) What do people think about this general idea? Are there any other feature.* settings that could be useful? Any additional settings to add to these groups? Thanks, -Stolee