Skip to content

Instantly share code, notes, and snippets.

@dannyroberts
Last active May 16, 2025 10:26
Show Gist options
  • Select an option

  • Save dannyroberts/857b9f7e52acd6b83c89 to your computer and use it in GitHub Desktop.

Select an option

Save dannyroberts/857b9f7e52acd6b83c89 to your computer and use it in GitHub Desktop.
Moving files with git read-tree to preserve history

Did you know...

...that git lets you move and rename whole directories while preserving the git history of those files?

If you run

git read-tree --prefix=$NEW_PATH -u master:$OLD_PATH
rm -rf $OLD_PATH
# ...you probably want to change some imports...
git commit -m $MESSAGE

that will move the directory tree to the new location, and, when you commit, it'll preserve this history of those files.

Things that still work:

  • git blame
  • git merge with code that branched off before the renaming (incredible!)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment