mirror of
https://github.com/jesseduffield/lazygit.git
synced 2025-01-06 03:53:59 +02:00
remove old rebase code now that we're only ever interactively rebasing
This commit is contained in:
parent
95d451e59a
commit
1a19b1412d
@ -419,22 +419,9 @@ func (c *GitCommand) IsInMergeState() (bool, error) {
|
|||||||
return strings.Contains(output, "conclude merge") || strings.Contains(output, "unmerged paths"), nil
|
return strings.Contains(output, "conclude merge") || strings.Contains(output, "unmerged paths"), nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// RebaseMode returns "" for non-rebase mode, "normal" for normal rebase
|
// IsInRebasingState tells us if we are rebasing
|
||||||
// and "interactive" for interactive rebase
|
func (c *GitCommand) IsInRebasingState() (bool, error) {
|
||||||
func (c *GitCommand) RebaseMode() (string, error) {
|
return c.OSCommand.FileExists(".git/rebase-merge")
|
||||||
exists, err := c.OSCommand.FileExists(".git/rebase-apply")
|
|
||||||
if err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
if exists {
|
|
||||||
return "normal", nil
|
|
||||||
}
|
|
||||||
exists, err = c.OSCommand.FileExists(".git/rebase-merge")
|
|
||||||
if exists {
|
|
||||||
return "interactive", err
|
|
||||||
} else {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// RemoveFile directly
|
// RemoveFile directly
|
||||||
|
@ -3,9 +3,6 @@ package git
|
|||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"os"
|
|
||||||
"path/filepath"
|
|
||||||
"regexp"
|
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/fatih/color"
|
"github.com/fatih/color"
|
||||||
@ -46,13 +43,13 @@ func NewCommitListBuilder(log *logrus.Entry, gitCommand *commands.GitCommand, os
|
|||||||
func (c *CommitListBuilder) GetCommits() ([]*commands.Commit, error) {
|
func (c *CommitListBuilder) GetCommits() ([]*commands.Commit, error) {
|
||||||
commits := []*commands.Commit{}
|
commits := []*commands.Commit{}
|
||||||
var rebasingCommits []*commands.Commit
|
var rebasingCommits []*commands.Commit
|
||||||
rebaseMode, err := c.GitCommand.RebaseMode()
|
isRebasing, err := c.GitCommand.IsInRebasingState()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
if rebaseMode != "" {
|
if isRebasing {
|
||||||
// here we want to also prepend the commits that we're in the process of rebasing
|
// here we want to also prepend the commits that we're in the process of rebasing
|
||||||
rebasingCommits, err = c.getRebasingCommits(rebaseMode)
|
rebasingCommits, err = c.getRebasingCommits()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
@ -77,7 +74,7 @@ func (c *CommitListBuilder) GetCommits() ([]*commands.Commit, error) {
|
|||||||
DisplayString: strings.Join(splitLine, " "),
|
DisplayString: strings.Join(splitLine, " "),
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
if rebaseMode != "" {
|
if isRebasing {
|
||||||
currentCommit := commits[len(rebasingCommits)]
|
currentCommit := commits[len(rebasingCommits)]
|
||||||
blue := color.New(color.FgYellow)
|
blue := color.New(color.FgYellow)
|
||||||
youAreHere := blue.Sprintf("<-- %s ---", c.Tr.SLocalize("YouAreHere"))
|
youAreHere := blue.Sprintf("<-- %s ---", c.Tr.SLocalize("YouAreHere"))
|
||||||
@ -86,59 +83,6 @@ func (c *CommitListBuilder) GetCommits() ([]*commands.Commit, error) {
|
|||||||
return c.setCommitMergedStatuses(commits)
|
return c.setCommitMergedStatuses(commits)
|
||||||
}
|
}
|
||||||
|
|
||||||
// getRebasingCommits obtains the commits that we're in the process of rebasing
|
|
||||||
func (c *CommitListBuilder) getRebasingCommits(rebaseMode string) ([]*commands.Commit, error) {
|
|
||||||
switch rebaseMode {
|
|
||||||
case "normal":
|
|
||||||
return c.getNormalRebasingCommits()
|
|
||||||
case "interactive":
|
|
||||||
return c.getInteractiveRebasingCommits()
|
|
||||||
default:
|
|
||||||
return nil, nil
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (c *CommitListBuilder) getNormalRebasingCommits() ([]*commands.Commit, error) {
|
|
||||||
rewrittenCount := 0
|
|
||||||
bytesContent, err := ioutil.ReadFile(".git/rebase-apply/rewritten")
|
|
||||||
if err == nil {
|
|
||||||
content := string(bytesContent)
|
|
||||||
rewrittenCount = len(strings.Split(content, "\n"))
|
|
||||||
}
|
|
||||||
|
|
||||||
// we know we're rebasing, so lets get all the files whose names have numbers
|
|
||||||
commits := []*commands.Commit{}
|
|
||||||
err = filepath.Walk(".git/rebase-apply", func(path string, f os.FileInfo, err error) error {
|
|
||||||
if rewrittenCount > 0 {
|
|
||||||
rewrittenCount--
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
re := regexp.MustCompile(`^\d+$`)
|
|
||||||
if !re.MatchString(f.Name()) {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
bytesContent, err := ioutil.ReadFile(path)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
content := string(bytesContent)
|
|
||||||
commit, err := c.commitFromPatch(content)
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
commits = append([]*commands.Commit{commit}, commits...)
|
|
||||||
return nil
|
|
||||||
})
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
return commits, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// git-rebase-todo example:
|
// git-rebase-todo example:
|
||||||
// pick ac446ae94ee560bdb8d1d057278657b251aaef17 ac446ae
|
// pick ac446ae94ee560bdb8d1d057278657b251aaef17 ac446ae
|
||||||
// pick afb893148791a2fbd8091aeb81deba4930c73031 afb8931
|
// pick afb893148791a2fbd8091aeb81deba4930c73031 afb8931
|
||||||
@ -148,10 +92,10 @@ func (c *CommitListBuilder) getNormalRebasingCommits() ([]*commands.Commit, erro
|
|||||||
// pick ac446ae94ee560bdb8d1d057278657b251aaef17 blah commit on master
|
// pick ac446ae94ee560bdb8d1d057278657b251aaef17 blah commit on master
|
||||||
// pick afb893148791a2fbd8091aeb81deba4930c73031 fourth commit on master
|
// pick afb893148791a2fbd8091aeb81deba4930c73031 fourth commit on master
|
||||||
|
|
||||||
// getInteractiveRebasingCommits takes our git-rebase-todo and our git-rebase-todo.backup files
|
// getRebasingCommits takes our git-rebase-todo and our git-rebase-todo.backup files
|
||||||
// and extracts out the sha and names of commits that we still have to go
|
// and extracts out the sha and names of commits that we still have to go
|
||||||
// in the rebase:
|
// in the rebase:
|
||||||
func (c *CommitListBuilder) getInteractiveRebasingCommits() ([]*commands.Commit, error) {
|
func (c *CommitListBuilder) getRebasingCommits() ([]*commands.Commit, error) {
|
||||||
bytesContent, err := ioutil.ReadFile(".git/rebase-merge/git-rebase-todo")
|
bytesContent, err := ioutil.ReadFile(".git/rebase-merge/git-rebase-todo")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
c.Log.Info(fmt.Sprintf("error occured reading git-rebase-todo: %s", err.Error()))
|
c.Log.Info(fmt.Sprintf("error occured reading git-rebase-todo: %s", err.Error()))
|
||||||
@ -177,22 +121,6 @@ func (c *CommitListBuilder) getInteractiveRebasingCommits() ([]*commands.Commit,
|
|||||||
return nil, nil
|
return nil, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// assuming the file starts like this:
|
|
||||||
// From e93d4193e6dd45ca9cf3a5a273d7ba6cd8b8fb20 Mon Sep 17 00:00:00 2001
|
|
||||||
// From: Lazygit Tester <test@example.com>
|
|
||||||
// Date: Wed, 5 Dec 2018 21:03:23 +1100
|
|
||||||
// Subject: second commit on master
|
|
||||||
func (c *CommitListBuilder) commitFromPatch(content string) (*commands.Commit, error) {
|
|
||||||
lines := strings.Split(content, "\n")
|
|
||||||
sha := strings.Split(lines[0], " ")[1][0:7]
|
|
||||||
name := strings.TrimPrefix(lines[3], "Subject: ")
|
|
||||||
return &commands.Commit{
|
|
||||||
Sha: sha,
|
|
||||||
Name: name,
|
|
||||||
Status: "rebasing",
|
|
||||||
}, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (c *CommitListBuilder) setCommitMergedStatuses(commits []*commands.Commit) ([]*commands.Commit, error) {
|
func (c *CommitListBuilder) setCommitMergedStatuses(commits []*commands.Commit) ([]*commands.Commit, error) {
|
||||||
ancestor, err := c.getMergeBase()
|
ancestor, err := c.getMergeBase()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
@ -94,14 +94,14 @@ func (gui *Gui) updateWorkTreeState() error {
|
|||||||
gui.State.WorkingTreeState = "merging"
|
gui.State.WorkingTreeState = "merging"
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
rebaseMode, err := gui.GitCommand.RebaseMode()
|
isRebasing, err := gui.GitCommand.IsInRebasingState()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
if rebaseMode != "" {
|
if isRebasing {
|
||||||
gui.State.WorkingTreeState = "rebasing"
|
gui.State.WorkingTreeState = "rebasing"
|
||||||
return nil
|
} else {
|
||||||
|
gui.State.WorkingTreeState = "normal"
|
||||||
}
|
}
|
||||||
gui.State.WorkingTreeState = "normal"
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user