How to Fix Git Submodule Add, "a git directory is found locally" issue

6/13/2023

Info

Not interested in the Understanding the issue? Feel free to skip to the solution.

I use Git Submodules in my blog (curiouslychase.com) to separately version control my content and public assets from my blog architecture.

I find one of the most common issues I run into is when I add a Git submodule and get back a response of the "a git directory is found locally" issue.

If you've ever found yourself puzzled by the "a git directory is found locally" issue while trying to add a Git submodule, you're not alone. In this blog post, we're going to demystify this error message and provide a step-by-step solution to get you back on track.

This blog post aims to help you learn about why this problem occurs and how to fix it effectively. So, let's dive right into it!

The Problem

You may encounter this issue while trying to add a submodule to your repository using the command:

git submodule add <repository_url>

Instead of adding the repository as a submodule, Git responds with a error message:

"a git directory is found locally, rm the '.git' file in <local_directory> to clone."

Understanding the Issue

So, what's going on?

This error typically happens when there's already a '.git' directory present in the directory where you're trying to add the submodule. Git gets confused because it expects the directory to be empty when adding a new submodule.

The Solution

In order to fix this, there are 5 steps you have to do to get your submodules working again.

For this example, I'm going to use src/content as the path to the submodule and git@github.com:curiouslychase/content.git as the git repository URL.

Step 1: Remove the submodule from the cache and the disk

If you haven't already, remove the submodule from the cache using the git rm --cached command.

Also, remove the submodule directory using rm -rf.

git rm --cached src/content 
rm -rf src/content

Step 2: Delete the relevant lines from the .gitmodules file

Open your .gitmodules file and delete the section related to your submodule. This usually looks something like this:

[submodule "src/content"] 
	path = src/content 
	url = git@github.com:curiouslychase/content.git

Step 3: Delete the relevant section from .git/config

Next, open your .git/config file and delete the section related to your submodule. It will resemble this:

[submodule "src/content"] 
	url = git@github.com:curiouslychase/content.git

Step 4: Remove the relevant directory from .git/modules

Finally, remove the directory related to your submodule from the .git/modules directory.

rm -rf .git/modules/src/content

Step 5: Add the submodule back

With your project tidied up, you can now add your submodule without encountering the error:

git submodule add  git@github.com:curiouslychase/content.git

Wrapping Up

If you're regularly adding submodules, always ensure that your target directories are clean and devoid of any '.git' directory before adding a new submodule.

This way, you and Git can continue your version-controlled journey in harmony!

Chase Adams