Created
December 17, 2014 19:30
-
-
Save slattery/6f4f4eca4b7a22b2d72c to your computer and use it in GitHub Desktop.
pluck a dir from one git repo and make a fresh one
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| thx http://gbayer.com/development/moving-files-from-one-git-repository-to-another-preserving-history/ | |
| Make a copy of repository A so you can mess with it without worrying about mistakes too much. It’s also a good idea to delete the link to the original repository to avoid accidentally making any remote changes (line 3). Line 4 is the critical step here. It goes through your history and files, removing anything that is not in directory 1. The result is the contents of directory 1 spewed out into to the base of repository A. You probably want to import these files into repository B within a directory, so move them into one now (lines 5/6). Commit your changes and we’re ready to merge these files into the new repository. | |
| ```sh | |
| git clone <git repository A url> | |
| cd <git repository A directory> | |
| git remote rm origin | |
| git filter-branch --subdirectory-filter <directory 1> -- --all | |
| mkdir <directory 1> | |
| mv * <directory 1> | |
| git add . | |
| git commit | |
| ``` | |
| Make a copy of repository B if you don’t have one already. On line 3, you’ll create a remote connection to repository A as a branch in repository B. Then simply pull from this branch (containing only the directory you want to move) into repository B. The pull copies both files and history. Note: You can use a merge instead of a pull, but pull worked better for me. Finally, you probably want to clean up a bit by removing the remote connection to repository A. Commit and you’re all set. | |
| ```sh | |
| git clone <git repository B url> | |
| cd <git repository B directory> | |
| git remote add repo-A-branch <git repository A directory> | |
| git pull repo-A-branch master | |
| git remote rm repo-A-branch | |
| ``` |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment