submodule: absorb git dir instead of dying on deinit
Currently, running 'git submodule deinit' on repos where the submodule's '.git' is a directory, aborts with a message that is not exactly user friendly. Let's change this to instead warn the user that the .git/ directory has been absorbed into the superproject. The rest of the deinit function can operate as it already does with new-style submodules. In one test, we used to require "git submodule deinit" to fail even with the "--force" option when the submodule's .git/ directory is not absorbed. Adjust it to expect the operation to pass. Suggested-by: Atharva Raykar <raykar.ath@gmail.com> Signed-off-by: Mugdha Pattnaik <mugdhapattnaik@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:

committed by
Junio C Hamano

parent
106298f7f9
commit
0adc8ba6ae
@ -1503,16 +1503,17 @@ static void deinit_submodule(const char *path, const char *prefix,
|
||||
struct strbuf sb_rm = STRBUF_INIT;
|
||||
const char *format;
|
||||
|
||||
/*
|
||||
* protect submodules containing a .git directory
|
||||
* NEEDSWORK: instead of dying, automatically call
|
||||
* absorbgitdirs and (possibly) warn.
|
||||
*/
|
||||
if (is_directory(sub_git_dir))
|
||||
die(_("Submodule work tree '%s' contains a .git "
|
||||
"directory (use 'rm -rf' if you really want "
|
||||
"to remove it including all of its history)"),
|
||||
displaypath);
|
||||
if (is_directory(sub_git_dir)) {
|
||||
if (!(flags & OPT_QUIET))
|
||||
warning(_("Submodule work tree '%s' contains a .git "
|
||||
"directory. This will be replaced with a "
|
||||
".git file by using absorbgitdirs."),
|
||||
displaypath);
|
||||
|
||||
absorb_git_dir_into_superproject(path,
|
||||
ABSORB_GITDIR_RECURSE_SUBMODULES);
|
||||
|
||||
}
|
||||
|
||||
if (!(flags & OPT_FORCE)) {
|
||||
struct child_process cp_rm = CHILD_PROCESS_INIT;
|
||||
|
Reference in New Issue
Block a user