Merging git repos into subfolders with history

less than 1 minute read

Did you know you can merge a git repo into a subfolder of another, while keeping the commit history of the repo you’re merging in? It was surprisingly simple. Here’s how you do it:

# Navigate to the repo folder where you're merging into
cd path-to-destination-repo

# Add a remote that points to the repo you're merging in (replace <repo-url> with the actual URL obviously)
git remote add tobemerged <repo-url>

# Fetch changes from the new remote
git fetch tobemerged

# Merge the changes from remote master, but don't commit, and keep the changes from destination.
# This shouldn't actually do anything to the destination repo filesystem.
git merge -sours --no-commit --allow-unrelated-histories tobemerged/master

# Read the files from the repo you're merging in, and put them in the specified subfolder
git read-tree --prefix=subfolder/for/merge/ -u tobemerged/master

# Commit the merge
git commit -m"Merged repos"

That’s it! You should get the full git log from both repos with git log.

I’m not going to take credit for figuring out this all myself - it’s based on Eric Lee’s answer in this StackOverflow post: https://stackoverflow.com/questions/13040958/merge-two-git-repositories-without-breaking-file-history

Categories:

Updated:

Comments