好的工具。a curated list of tools
lorem ipsum but it’s picture
https://placehold.co/600x400/orange/blue
copy a directory and its git history
This article outlines the cherry-picking approach.
- Create a new git repo,
git init
- Set original repo as a remote,
git remote add hmwk file://path/to/original/repo
- Download history from original repo,
git remote update
- List commits that change this directory,
git log -- day2009-bouncing-discs
. Or use helper in IDE. - Cherry-pick commits from remote,
git cherry-pick f1a6884d^..5dfa0336
if commits are consecutive. Or cherry-pick them one by one.
However, cherry-pick will throw fatal error if specified hash range contains merge commit. And commits from another branch will be “merged” to HEAD which is a very undesirable behaviour.
Subtree merging approach preserves merge commits and full commit history, see this link. Excerpt:
Here is the command sequence you need:
1 2 3 4 5 $ git remote add -f Bproject /path/to/B <1> $ git merge -s ours --no-commit --allow-unrelated-histories Bproject/master <2> $ git read-tree --prefix=dir-B/ -u Bproject/master <3> $ git commit -m "Merge B project as our subdirectory" <4> $ git pull -s subtree Bproject master <5>
- name the other project “Bproject”, and fetch.
- prepare for the later step to record the result as a merge.
- read “master” branch of Bproject to the subdirectory “dir-B”.
- record the merge result.
- maintain the result with subsequent merges using “subtree”
The first four commands are used for the initial merge, while the last one is to merge updates from B project.
git stash
git stash
common commands includes: list
, push
, pop
/apply
, show
. Their meaning are pretty strateforward and don’t forget to use git stash show -p
to show stash detail. For options other than “-p” see “DIFF FORMATTING” section in git show --help
.