我想从线性提交树中删除选定的提交日志项,这样这些项就不会显示在提交日志中。

我的提交树看起来像这样:

R--A--B--C--D--E--HEAD

我想删除B和C条目,这样它们就不会显示在提交日志中,但是应该保留从A到D的更改。也许通过引入一次提交,这样B和C就变成了BC,树看起来就像。

R--A--BC--D--E--HEAD

或者,理想情况下,A后面直接是D。D'表示从A到B, B到C, C到D的变化。

R--A--D'--E--HEAD

这可能吗?如果是,怎么做?

这是一个相当新的项目,所以目前还没有分支,因此也没有合并。


当前回答

刚刚收集了所有人的答案:(我是git的新手,请仅供参考)

Git重基删除任何提交

git 日志

-first check from which commit you want to rebase

我们回来了

-Here i want to rebase on the second last commit- commit count starts from '1')
-this will open the command line editor (called vim editor i guess)

然后屏幕看起来会是这样的:

pick 0c2236d Added new line. Rebase 2a1cd65..0c2236d onto 2a1cd65 (1 command) # Commands: p, pick = use commit r, reword = use commit, but edit the commit message e, edit = use commit, but stop for amending s, squash = use commit, but meld into previous commit f, fixup = like "squash", but discard this commit's log message x, exec = run command (the rest of the line) using shell d, drop = remove commit # These lines can be re-ordered; they are executed from top to bottom. # If you remove a line here THAT COMMIT WILL BE LOST. # However, if you remove everything, the rebase will be aborted. # Note that empty commits are commented out ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~

这里根据您的需要更改第一行(使用上面列出的命令,例如。'drop'删除提交等) 编辑完成后,按“:x”保存并退出编辑器(这仅适用于vim编辑器)

然后

git push

如果它的显示问题,那么你需要强行将更改推到远程(非常关键:如果你是团队工作,不要强行推)

Git push -f origin

其他回答

我发现这个过程更安全,更容易理解,从A的SHA1创建另一个分支,并选择所需的更改,这样我就可以确保我对这个新分支的外观感到满意。在此之后,很容易删除旧分支并重命名新分支。

git checkout <SHA1 of A>
git log #verify looks good
git checkout -b rework
git cherry-pick <SHA1 of D>
....
git log #verify looks good
git branch -D <oldbranch>
git branch -m rework <oldbranch>
# detach head and move to D commit
git checkout <SHA1-for-D>

# move HEAD to A, but leave the index and working tree as for D
git reset --soft <SHA1-for-A>

# Redo the D commit re-using the commit message, but now on top of A
git commit -C <SHA1-for-D>

# Re-apply everything from the old D onwards onto this new place 
git rebase --onto HEAD <SHA1-for-D> master

下面是一种删除特定提交id的方法,只知道您想删除的提交id。

git rebase --onto commit-id^ commit-id

注意,这实际上删除了提交所引入的更改。

刚刚收集了所有人的答案:(我是git的新手,请仅供参考)

Git重基删除任何提交

git 日志

-first check from which commit you want to rebase

我们回来了

-Here i want to rebase on the second last commit- commit count starts from '1')
-this will open the command line editor (called vim editor i guess)

然后屏幕看起来会是这样的:

pick 0c2236d Added new line. Rebase 2a1cd65..0c2236d onto 2a1cd65 (1 command) # Commands: p, pick = use commit r, reword = use commit, but edit the commit message e, edit = use commit, but stop for amending s, squash = use commit, but meld into previous commit f, fixup = like "squash", but discard this commit's log message x, exec = run command (the rest of the line) using shell d, drop = remove commit # These lines can be re-ordered; they are executed from top to bottom. # If you remove a line here THAT COMMIT WILL BE LOST. # However, if you remove everything, the rebase will be aborted. # Note that empty commits are commented out ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~

这里根据您的需要更改第一行(使用上面列出的命令,例如。'drop'删除提交等) 编辑完成后,按“:x”保存并退出编辑器(这仅适用于vim编辑器)

然后

git push

如果它的显示问题,那么你需要强行将更改推到远程(非常关键:如果你是团队工作,不要强行推)

Git push -f origin

Git-rebase(1)正是这样做的。

$ git rebase -i HEAD~5

Git awesome -ness [Git rebase——interactive]包含了一个例子。

不要在公共(远程)提交上使用git-rebase。 确保您的工作目录是干净的(提交或保存当前的更改)。 执行上述命令。它会启动你的$编辑器。 将C和D之前的pick替换为squash。它会将C和D合并为b。如果你想删除一个提交,那么只需删除它的行。

如果你迷路了,输入:

$ git rebase --abort