Question

Since gitmodules were introduced in Git, I like to add them like so:

[submodule "actionbarsherlock"]
path = actionbarsherlock
url = git://github.com/JakeWharton/ActionBarSherlock.git
ignore = dirty

The important part here is ignore = dirty.

When using the git submodule add command, I'm forced to add this line by myself in the .gitmodules file.

How can I make this the default behavior for every git submodule add I'll make in the futur?

I know about the submodule.<name>.ignore configuration, but how to apply it to all by default?

Était-ce utile?

La solution 2

So to close this, no, there is not default option for it (sadly).

Autres conseils

Note that even if there were such a config, git 2.0.1 (June 25th, 2014) would still show you a submodule which has been staged.

See commit 1d2f393 by Jens Lehmann (jlehmann)

Currently setting submodule.<name>.ignore and/or diff.ignoreSubmodules to "all" suppresses all output of submodule changes for the diff family, status and commit.

For status and commit this is really confusing, as it even when the user chooses to record a new commit for an ignored submodule by adding it manually this change won't show up under the to-be-committed changes.
To add insult to injury, a later "git commit" will error out with "nothing to commit" when only ignored submodules are staged.

Fix that by making wt_status always print staged submodule changes, no matter what ignore settings are configured.
The only exception is when the user explicitly uses the "--ignore-submodules=all" command line option, in that case the submodule output is still suppressed.
This also makes "git commit" work again when only modifications of ignored submodules are staged, as that command uses the "commitable" member of the wt_status struct to determine if staged changes are present.

See also commit c215d3d for the git commit part.

Today I found out that can use git config to change the .gitmodules file, and therefore can add the ignore dirty flag without going into the file and adding the line by hand:

git config -f .gitmodules submodule.actionbarsherlock.ignore dirty

In my case, I was able to automate the two steps in a script with that command.

I'm not sure about a default option. Were it a binary state (ignore or not), you could get traction with:

diff.ignoreSubmodules
   Sets the default value of --ignore-submodules. Note that this affects only git diff Porcelain, and not lower level diff commands such as git diff-files.  git checkout also
   honors this setting when reporting uncommitted changes.

But as you're using dirty I'm not sure there's a way to set a default. Regardless, you could do this with a git alias in your $PATH. Write a script that accepts the submodule as an argument and set the proper dirty configuration value, then add that script to your $PATH. Call it git-<command> and it'll be available as git <command>.

Do you mean this?

git config --global core.ignore dirty

which writes the preference to your ~/.gitconfig file.

Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow
scroll top