mirror of
https://github.com/jesseduffield/lazygit.git
synced 2025-01-20 05:19:24 +02:00
Edit by breaking after current commit
Instead of rebasing from the commit below the current one and then setting the current one to "edit", we rebase from the current one and insert a "break" after it. In most cases the behavior is exactly the same as before, except that the new method also works if the current commit is a merge commit. This is useful if you want to create a new commit at the very beginning of your branch (by editing the last commit before your branch).
This commit is contained in:
parent
bb856ad7c6
commit
67b8ef449c
@ -117,6 +117,16 @@ func (self *RebaseCommands) InteractiveRebase(commits []*models.Commit, index in
|
|||||||
return self.PrepareInteractiveRebaseCommand(sha, todo, true).Run()
|
return self.PrepareInteractiveRebaseCommand(sha, todo, true).Run()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (self *RebaseCommands) InteractiveRebaseBreakAfter(commits []*models.Commit, index int) error {
|
||||||
|
todo, sha, err := self.BuildSingleActionTodo(commits, index-1, "pick")
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
todo = append(todo, TodoLine{Action: "break", Commit: nil})
|
||||||
|
return self.PrepareInteractiveRebaseCommand(sha, todo, true).Run()
|
||||||
|
}
|
||||||
|
|
||||||
// PrepareInteractiveRebaseCommand returns the cmd for an interactive rebase
|
// PrepareInteractiveRebaseCommand returns the cmd for an interactive rebase
|
||||||
// we tell git to run lazygit to edit the todo list, and we pass the client
|
// we tell git to run lazygit to edit the todo list, and we pass the client
|
||||||
// lazygit a todo string to write to the todo file
|
// lazygit a todo string to write to the todo file
|
||||||
@ -400,5 +410,9 @@ type TodoLine struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (self *TodoLine) ToString() string {
|
func (self *TodoLine) ToString() string {
|
||||||
return self.Action + " " + self.Commit.Sha + " " + self.Commit.Name + "\n"
|
if self.Action == "break" {
|
||||||
|
return self.Action + "\n"
|
||||||
|
} else {
|
||||||
|
return self.Action + " " + self.Commit.Sha + " " + self.Commit.Name + "\n"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -298,7 +298,8 @@ func (self *LocalCommitsController) edit(commit *models.Commit) error {
|
|||||||
|
|
||||||
return self.c.WithWaitingStatus(self.c.Tr.RebasingStatus, func() error {
|
return self.c.WithWaitingStatus(self.c.Tr.RebasingStatus, func() error {
|
||||||
self.c.LogAction(self.c.Tr.Actions.EditCommit)
|
self.c.LogAction(self.c.Tr.Actions.EditCommit)
|
||||||
return self.interactiveRebase("edit")
|
err := self.git.Rebase.InteractiveRebaseBreakAfter(self.model.Commits, self.context().GetSelectedLineIdx())
|
||||||
|
return self.helpers.MergeAndRebase.CheckMergeOrRebase(err)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user