git_commands

package
v0.0.0-...-8fc5405 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: May 1, 2023 License: MIT Imports: 29 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func IsBareRepo

func IsBareRepo(osCommand *oscommands.OSCommand) (bool, error)

Types

type Author

type Author struct {
	Name  string
	Email string
}

type BisectCommands

type BisectCommands struct {
	*GitCommon
}

func NewBisectCommands

func NewBisectCommands(gitCommon *GitCommon) *BisectCommands

func (*BisectCommands) GetInfo

func (self *BisectCommands) GetInfo() *BisectInfo

This command is pretty cheap to run so we're not storing the result anywhere. But if it becomes problematic we can chang that.

func (*BisectCommands) IsDone

func (self *BisectCommands) IsDone() (bool, []string, error)

tells us whether we've found our problem commit(s). We return a string slice of commit sha's if we're done, and that slice may have more that one item if skipped commits are involved.

func (*BisectCommands) Mark

func (self *BisectCommands) Mark(ref string, term string) error

func (*BisectCommands) ReachableFromStart

func (self *BisectCommands) ReachableFromStart(bisectInfo *BisectInfo) bool

tells us whether the 'start' ref that we'll be sent back to after we're done bisecting is actually a descendant of our current bisect commit. If it's not, we need to render the commits from the bad commit.

func (*BisectCommands) Reset

func (self *BisectCommands) Reset() error

func (*BisectCommands) Skip

func (self *BisectCommands) Skip(ref string) error

func (*BisectCommands) Start

func (self *BisectCommands) Start() error

type BisectInfo

type BisectInfo struct {
	// contains filtered or unexported fields
}

func NewNullBisectInfo

func NewNullBisectInfo() *BisectInfo

null object pattern

func (*BisectInfo) Bisecting

func (self *BisectInfo) Bisecting() bool

this is where we have both a good and bad revision and we're actually starting to narrow things down

func (*BisectInfo) GetCurrentSha

func (self *BisectInfo) GetCurrentSha() string

func (*BisectInfo) GetNewSha

func (self *BisectInfo) GetNewSha() string

func (*BisectInfo) GetStartSha

func (self *BisectInfo) GetStartSha() string

func (*BisectInfo) NewTerm

func (self *BisectInfo) NewTerm() string

func (*BisectInfo) OldTerm

func (self *BisectInfo) OldTerm() string

func (*BisectInfo) Started

func (self *BisectInfo) Started() bool

this is for when we have called `git bisect start`. It does not mean that we have actually started narrowing things down or selecting good/bad commits

func (*BisectInfo) Status

func (self *BisectInfo) Status(commitSha string) (BisectStatus, bool)

type BisectStatus

type BisectStatus int
const (
	BisectStatusOld BisectStatus = iota
	BisectStatusNew
	BisectStatusSkipped
)

type BranchCommands

type BranchCommands struct {
	*GitCommon
}

func NewBranchCommands

func NewBranchCommands(gitCommon *GitCommon) *BranchCommands

func (*BranchCommands) AllBranchesLogCmdObj

func (self *BranchCommands) AllBranchesLogCmdObj() oscommands.ICmdObj

func (*BranchCommands) Checkout

func (self *BranchCommands) Checkout(branch string, options CheckoutOptions) error

func (*BranchCommands) CurrentBranchInfo

func (self *BranchCommands) CurrentBranchInfo() (BranchInfo, error)

CurrentBranchInfo get the current branch information.

func (*BranchCommands) Delete

func (self *BranchCommands) Delete(branch string, force bool) error

Delete delete branch

func (*BranchCommands) GetCommitDifferences

func (self *BranchCommands) GetCommitDifferences(from, to string) (string, string)

GetCommitDifferences checks how many pushables/pullables there are for the current branch

func (*BranchCommands) GetCurrentBranchUpstreamDifferenceCount

func (self *BranchCommands) GetCurrentBranchUpstreamDifferenceCount() (string, string)

func (*BranchCommands) GetGraph

func (self *BranchCommands) GetGraph(branchName string) (string, error)

GetGraph gets the color-formatted graph of the log for the given branch Currently it limits the result to 100 commits, but when we get async stuff working we can do lazy loading

func (*BranchCommands) GetGraphCmdObj

func (self *BranchCommands) GetGraphCmdObj(branchName string) oscommands.ICmdObj

func (*BranchCommands) GetRawBranches

func (self *BranchCommands) GetRawBranches() (string, error)

func (*BranchCommands) GetUpstreamDifferenceCount

func (self *BranchCommands) GetUpstreamDifferenceCount(branchName string) (string, string)

func (*BranchCommands) IsHeadDetached

func (self *BranchCommands) IsHeadDetached() bool

func (*BranchCommands) Merge

func (self *BranchCommands) Merge(branchName string, opts MergeOpts) error

func (*BranchCommands) New

func (self *BranchCommands) New(name string, base string) error

New creates a new branch

func (*BranchCommands) Rename

func (self *BranchCommands) Rename(oldName string, newName string) error

func (*BranchCommands) SetCurrentBranchUpstream

func (self *BranchCommands) SetCurrentBranchUpstream(remoteName string, remoteBranchName string) error

func (*BranchCommands) SetUpstream

func (self *BranchCommands) SetUpstream(remoteName string, remoteBranchName string, branchName string) error

func (*BranchCommands) UnsetUpstream

func (self *BranchCommands) UnsetUpstream(branchName string) error

type BranchInfo

type BranchInfo struct {
	RefName      string
	DisplayName  string // e.g. '(HEAD detached at 123asdf)'
	DetachedHead bool
}

type BranchLoader

type BranchLoader struct {
	*common.Common
	// contains filtered or unexported fields
}

BranchLoader returns a list of Branch objects for the current repo

func NewBranchLoader

func NewBranchLoader(
	cmn *common.Common,
	getRawBranches func() (string, error),
	getCurrentBranchInfo func() (BranchInfo, error),
	config BranchLoaderConfigCommands,
) *BranchLoader

func (*BranchLoader) Load

func (self *BranchLoader) Load(reflogCommits []*models.Commit) ([]*models.Branch, error)

Load the list of branches for the current repo

type BranchLoaderConfigCommands

type BranchLoaderConfigCommands interface {
	Branches() (map[string]*config.Branch, error)
}

type CheckoutOptions

type CheckoutOptions struct {
	Force   bool
	EnvVars []string
}

Checkout checks out a branch (or commit), with --force if you set the force arg to true

type CommitCommands

type CommitCommands struct {
	*GitCommon
}

func NewCommitCommands

func NewCommitCommands(gitCommon *GitCommon) *CommitCommands

func (*CommitCommands) AmendHead

func (self *CommitCommands) AmendHead() error

AmendHead amends HEAD with whatever is staged in your working tree

func (*CommitCommands) AmendHeadCmdObj

func (self *CommitCommands) AmendHeadCmdObj() oscommands.ICmdObj

func (*CommitCommands) CommitCmdObj

func (self *CommitCommands) CommitCmdObj(message string) oscommands.ICmdObj

func (*CommitCommands) CommitEditorCmdObj

func (self *CommitCommands) CommitEditorCmdObj() oscommands.ICmdObj

runs git commit without the -m argument meaning it will invoke the user's editor

func (*CommitCommands) CreateFixupCommit

func (self *CommitCommands) CreateFixupCommit(sha string) error

CreateFixupCommit creates a commit that fixes up a previous commit

func (*CommitCommands) GetCommitAuthor

func (self *CommitCommands) GetCommitAuthor(commitSha string) (Author, error)

func (*CommitCommands) GetCommitDiff

func (self *CommitCommands) GetCommitDiff(commitSha string) (string, error)

func (*CommitCommands) GetCommitMessage

func (self *CommitCommands) GetCommitMessage(commitSha string) (string, error)

func (*CommitCommands) GetCommitMessageFirstLine

func (self *CommitCommands) GetCommitMessageFirstLine(sha string) (string, error)

func (*CommitCommands) GetCommitMessagesFirstLine

func (self *CommitCommands) GetCommitMessagesFirstLine(shas []string) (string, error)

func (*CommitCommands) GetCommitsOneline

func (self *CommitCommands) GetCommitsOneline(shas []string) (string, error)

func (*CommitCommands) GetHeadCommitMessage

func (self *CommitCommands) GetHeadCommitMessage() (string, error)

Get the subject of the HEAD commit

func (*CommitCommands) ResetAuthor

func (self *CommitCommands) ResetAuthor() error

ResetAuthor resets the author of the topmost commit

func (*CommitCommands) ResetToCommit

func (self *CommitCommands) ResetToCommit(sha string, strength string, envVars []string) error

ResetToCommit reset to commit

func (*CommitCommands) Revert

func (self *CommitCommands) Revert(sha string) error

Revert reverts the selected commit by sha

func (*CommitCommands) RevertMerge

func (self *CommitCommands) RevertMerge(sha string, parentNumber int) error

func (*CommitCommands) RewordLastCommit

func (self *CommitCommands) RewordLastCommit(message string) error

RewordLastCommit rewords the topmost commit with the given message

func (*CommitCommands) SetAuthor

func (self *CommitCommands) SetAuthor(value string) error

Sets the commit's author to the supplied value. Value is expected to be of the form 'Name <Email>'

func (*CommitCommands) ShowCmdObj

func (self *CommitCommands) ShowCmdObj(sha string, filterPath string, ignoreWhitespace bool) oscommands.ICmdObj

type CommitFileLoader

type CommitFileLoader struct {
	*common.Common
	// contains filtered or unexported fields
}

func NewCommitFileLoader

func NewCommitFileLoader(common *common.Common, cmd oscommands.ICmdObjBuilder) *CommitFileLoader

func (*CommitFileLoader) GetFilesInDiff

func (self *CommitFileLoader) GetFilesInDiff(from string, to string, reverse bool) ([]*models.CommitFile, error)

GetFilesInDiff get the specified commit files

type CommitLoader

type CommitLoader struct {
	*common.Common
	// contains filtered or unexported fields
}

CommitLoader returns a list of Commit objects for the current repo

func NewCommitLoader

func NewCommitLoader(
	cmn *common.Common,
	cmd oscommands.ICmdObjBuilder,
	dotGitDir string,
	getCurrentBranchInfo func() (BranchInfo, error),
	getRebaseMode func() (enums.RebaseMode, error),
) *CommitLoader

making our dependencies explicit for the sake of easier testing

func (*CommitLoader) GetCommits

func (self *CommitLoader) GetCommits(opts GetCommitsOptions) ([]*models.Commit, error)

GetCommits obtains the commits of the current branch

func (*CommitLoader) MergeRebasingCommits

func (self *CommitLoader) MergeRebasingCommits(commits []*models.Commit) ([]*models.Commit, error)

type ConfigCommands

type ConfigCommands struct {
	*common.Common
	// contains filtered or unexported fields
}

func NewConfigCommands

func NewConfigCommands(
	common *common.Common,
	gitConfig git_config.IGitConfig,
	repo *gogit.Repository,
) *ConfigCommands

func (*ConfigCommands) Branches

func (self *ConfigCommands) Branches() (map[string]*config.Branch, error)

returns the repo's branches as specified in the git config

func (*ConfigCommands) ConfiguredPager

func (self *ConfigCommands) ConfiguredPager() string

func (*ConfigCommands) GetCoreEditor

func (self *ConfigCommands) GetCoreEditor() string

func (*ConfigCommands) GetGitFlowPrefixes

func (self *ConfigCommands) GetGitFlowPrefixes() string

func (*ConfigCommands) GetPager

func (self *ConfigCommands) GetPager(width int) string

func (*ConfigCommands) GetPushToCurrent

func (self *ConfigCommands) GetPushToCurrent() bool

this determines whether the user has configured to push to the remote branch of the same name as the current or not

func (*ConfigCommands) GetRemoteURL

func (self *ConfigCommands) GetRemoteURL() string

GetRemoteURL returns current repo remote url

func (*ConfigCommands) GetShowUntrackedFiles

func (self *ConfigCommands) GetShowUntrackedFiles() string

func (*ConfigCommands) UsingGpg

func (self *ConfigCommands) UsingGpg() bool

UsingGpg tells us whether the user has gpg enabled so that we can know whether we need to run a subprocess to allow them to enter their password

type CustomCommands

type CustomCommands struct {
	*GitCommon
}

func NewCustomCommands

func NewCustomCommands(gitCommon *GitCommon) *CustomCommands

func (*CustomCommands) RunWithOutput

func (self *CustomCommands) RunWithOutput(cmdStr string) (string, error)

Only to be used for the sake of running custom commands specified by the user. If you want to run a new command, try finding a place for it in one of the neighbouring files, or creating a new BlahCommands struct to hold it.

type FetchOptions

type FetchOptions struct {
	Background bool
	RemoteName string
	BranchName string
}

type FileCommands

type FileCommands struct {
	*GitCommon
}

func NewFileCommands

func NewFileCommands(gitCommon *GitCommon) *FileCommands

func (*FileCommands) Cat

func (self *FileCommands) Cat(fileName string) (string, error)

Cat obtains the content of a file

func (*FileCommands) GetEditAtLineAndWaitCmdStr

func (self *FileCommands) GetEditAtLineAndWaitCmdStr(filename string, lineNumber int) string

func (*FileCommands) GetEditAtLineCmdStr

func (self *FileCommands) GetEditAtLineCmdStr(filename string, lineNumber int) (string, bool)

func (*FileCommands) GetEditCmdStr

func (self *FileCommands) GetEditCmdStr(filename string) (string, bool)

func (*FileCommands) GetEditCmdStrLegacy

func (self *FileCommands) GetEditCmdStrLegacy(filename string, lineNumber int) (string, error)

type FileLoader

type FileLoader struct {
	*common.Common
	// contains filtered or unexported fields
}

func NewFileLoader

func NewFileLoader(cmn *common.Common, cmd oscommands.ICmdObjBuilder, config FileLoaderConfig) *FileLoader

func (*FileLoader) GetStatusFiles

func (self *FileLoader) GetStatusFiles(opts GetStatusFileOptions) []*models.File

func (*FileLoader) GitStatus

func (c *FileLoader) GitStatus(opts GitStatusOptions) ([]FileStatus, error)

type FileLoaderConfig

type FileLoaderConfig interface {
	GetShowUntrackedFiles() string
}

type FileStatus

type FileStatus struct {
	StatusString string
	Change       string // ??, MM, AM, ...
	Name         string
	PreviousName string
}

type FlowCommands

type FlowCommands struct {
	*GitCommon
}

func NewFlowCommands

func NewFlowCommands(
	gitCommon *GitCommon,
) *FlowCommands

func (*FlowCommands) FinishCmdObj

func (self *FlowCommands) FinishCmdObj(branchName string) (oscommands.ICmdObj, error)

func (*FlowCommands) GitFlowEnabled

func (self *FlowCommands) GitFlowEnabled() bool

func (*FlowCommands) StartCmdObj

func (self *FlowCommands) StartCmdObj(branchType string, name string) oscommands.ICmdObj

type GetCommitsOptions

type GetCommitsOptions struct {
	Limit                bool
	FilterPath           string
	IncludeRebaseCommits bool
	RefName              string // e.g. "HEAD" or "my_branch"
	// determines if we show the whole git graph i.e. pass the '--all' flag
	All bool
}

type GetStatusFileOptions

type GetStatusFileOptions struct {
	NoRenames bool
}

type GitCommon

type GitCommon struct {
	*common.Common
	// contains filtered or unexported fields
}

func NewGitCommon

func NewGitCommon(
	cmn *common.Common,
	version *GitVersion,
	cmd oscommands.ICmdObjBuilder,
	osCommand *oscommands.OSCommand,
	dotGitDir string,
	repo *gogit.Repository,
	config *ConfigCommands,
	syncMutex *deadlock.Mutex,
) *GitCommon

type GitStatusOptions

type GitStatusOptions struct {
	NoRenames         bool
	UntrackedFilesArg string
}

GitStatus returns the file status of the repo

type GitVersion

type GitVersion struct {
	Major, Minor, Patch int
	Additional          string
}

func GetGitVersion

func GetGitVersion(osCommand *oscommands.OSCommand) (*GitVersion, error)

func ParseGitVersion

func ParseGitVersion(versionStr string) (*GitVersion, error)

func (*GitVersion) IsOlderThan

func (v *GitVersion) IsOlderThan(major, minor, patch int) bool

func (*GitVersion) IsOlderThanVersion

func (v *GitVersion) IsOlderThanVersion(version *GitVersion) bool

type IFileNode

type IFileNode interface {
	ForEachFile(cb func(*models.File) error) error
	GetFilePathsMatching(test func(*models.File) bool) []string
	GetPath() string
}

type MergeOpts

type MergeOpts struct {
	FastForwardOnly bool
}

type PatchCommands

type PatchCommands struct {
	*GitCommon

	PatchBuilder *patch.PatchBuilder
	// contains filtered or unexported fields
}

func NewPatchCommands

func NewPatchCommands(
	gitCommon *GitCommon,
	rebase *RebaseCommands,
	commit *CommitCommands,
	status *StatusCommands,
	stash *StashCommands,
	patchBuilder *patch.PatchBuilder,
) *PatchCommands

func (*PatchCommands) DeletePatchesFromCommit

func (self *PatchCommands) DeletePatchesFromCommit(commits []*models.Commit, commitIndex int) error

DeletePatchesFromCommit applies a patch in reverse for a commit

func (*PatchCommands) MovePatchIntoIndex

func (self *PatchCommands) MovePatchIntoIndex(commits []*models.Commit, commitIdx int, stash bool) error

func (*PatchCommands) MovePatchToSelectedCommit

func (self *PatchCommands) MovePatchToSelectedCommit(commits []*models.Commit, sourceCommitIdx int, destinationCommitIdx int) error

func (*PatchCommands) PullPatchIntoNewCommit

func (self *PatchCommands) PullPatchIntoNewCommit(commits []*models.Commit, commitIdx int) error

type PrepareInteractiveRebaseCommandOpts

type PrepareInteractiveRebaseCommandOpts struct {
	// contains filtered or unexported fields
}

type PullOptions

type PullOptions struct {
	RemoteName      string
	BranchName      string
	FastForwardOnly bool
}

type PushOpts

type PushOpts struct {
	Force          bool
	UpstreamRemote string
	UpstreamBranch string
	SetUpstream    bool
}

Push pushes to a branch

type RebaseCommands

type RebaseCommands struct {
	*GitCommon
	// contains filtered or unexported fields
}

func NewRebaseCommands

func NewRebaseCommands(
	gitCommon *GitCommon,
	commitCommands *CommitCommands,
	workingTreeCommands *WorkingTreeCommands,
) *RebaseCommands

func (*RebaseCommands) AbortRebase

func (self *RebaseCommands) AbortRebase() error

func (*RebaseCommands) AmendTo

func (self *RebaseCommands) AmendTo(commit *models.Commit) error

AmendTo amends the given commit with whatever files are staged

func (*RebaseCommands) BeginInteractiveRebaseForCommit

func (self *RebaseCommands) BeginInteractiveRebaseForCommit(commits []*models.Commit, commitIndex int) error

BeginInteractiveRebaseForCommit starts an interactive rebase to edit the current commit and pick all others. After this you'll want to call `self.ContinueRebase()

func (*RebaseCommands) BuildSingleActionTodo

func (self *RebaseCommands) BuildSingleActionTodo(commits []*models.Commit, actionIndex int, action string) ([]TodoLine, string, error)

produces TodoLines where every commit is picked (or dropped for merge commits) except for the commit at the given index, which will have the given action applied to it.

func (*RebaseCommands) BuildTodoLines

func (self *RebaseCommands) BuildTodoLines(commits []*models.Commit, f func(*models.Commit, int) string) []TodoLine

func (*RebaseCommands) BuildTodoLinesSingleAction

func (self *RebaseCommands) BuildTodoLinesSingleAction(commits []*models.Commit, action string) []TodoLine

func (*RebaseCommands) CherryPickCommits

func (self *RebaseCommands) CherryPickCommits(commits []*models.Commit) error

CherryPickCommits begins an interactive rebase with the given shas being cherry picked onto HEAD

func (*RebaseCommands) ContinueRebase

func (self *RebaseCommands) ContinueRebase() error

func (*RebaseCommands) DiscardOldFileChanges

func (self *RebaseCommands) DiscardOldFileChanges(commits []*models.Commit, commitIndex int, fileName string) error

DiscardOldFileChanges discards changes to a file from an old commit

func (*RebaseCommands) EditRebase

func (self *RebaseCommands) EditRebase(branchRef string) error

func (*RebaseCommands) EditRebaseTodo

func (self *RebaseCommands) EditRebaseTodo(commit *models.Commit, action todo.TodoCommand) error

EditRebaseTodo sets the action for a given rebase commit in the git-rebase-todo file

func (*RebaseCommands) GenericAmend

func (self *RebaseCommands) GenericAmend(commits []*models.Commit, index int, f func() error) error

func (*RebaseCommands) GenericMergeOrRebaseAction

func (self *RebaseCommands) GenericMergeOrRebaseAction(commandType string, command string) error

GenericMerge takes a commandType of "merge" or "rebase" and a command of "abort", "skip" or "continue" By default we skip the editor in the case where a commit will be made

func (*RebaseCommands) GenericMergeOrRebaseActionCmdObj

func (self *RebaseCommands) GenericMergeOrRebaseActionCmdObj(commandType string, command string) oscommands.ICmdObj

func (*RebaseCommands) InteractiveRebase

func (self *RebaseCommands) InteractiveRebase(commits []*models.Commit, index int, action string) error

func (*RebaseCommands) InteractiveRebaseBreakAfter

func (self *RebaseCommands) InteractiveRebaseBreakAfter(commits []*models.Commit, index int) error

func (*RebaseCommands) MoveCommitDown

func (self *RebaseCommands) MoveCommitDown(commits []*models.Commit, index int) error

func (*RebaseCommands) MoveTodoDown

func (self *RebaseCommands) MoveTodoDown(commit *models.Commit) error

MoveTodoDown moves a rebase todo item down by one position

func (*RebaseCommands) MoveTodoUp

func (self *RebaseCommands) MoveTodoUp(commit *models.Commit) error

MoveTodoDown moves a rebase todo item down by one position

func (*RebaseCommands) PrepareInteractiveRebaseCommand

func (self *RebaseCommands) PrepareInteractiveRebaseCommand(opts PrepareInteractiveRebaseCommandOpts) oscommands.ICmdObj

PrepareInteractiveRebaseCommand returns the cmd for an interactive rebase we tell git to run lazyaws to edit the todo list, and we pass the client lazyaws a todo string to write to the todo file

func (*RebaseCommands) RebaseBranch

func (self *RebaseCommands) RebaseBranch(branchName string) error

RebaseBranch interactive rebases onto a branch

func (*RebaseCommands) ResetCommitAuthor

func (self *RebaseCommands) ResetCommitAuthor(commits []*models.Commit, index int) error

func (*RebaseCommands) RewordCommit

func (self *RebaseCommands) RewordCommit(commits []*models.Commit, index int, message string) error

func (*RebaseCommands) RewordCommitInEditor

func (self *RebaseCommands) RewordCommitInEditor(commits []*models.Commit, index int) (oscommands.ICmdObj, error)

func (*RebaseCommands) SetCommitAuthor

func (self *RebaseCommands) SetCommitAuthor(commits []*models.Commit, index int, value string) error

func (*RebaseCommands) SquashAllAboveFixupCommits

func (self *RebaseCommands) SquashAllAboveFixupCommits(commit *models.Commit) error

SquashAllAboveFixupCommits squashes all fixup! commits above the given one

type ReflogCommitLoader

type ReflogCommitLoader struct {
	*common.Common
	// contains filtered or unexported fields
}

func NewReflogCommitLoader

func NewReflogCommitLoader(common *common.Common, cmd oscommands.ICmdObjBuilder) *ReflogCommitLoader

func (*ReflogCommitLoader) GetReflogCommits

func (self *ReflogCommitLoader) GetReflogCommits(lastReflogCommit *models.Commit, filterPath string) ([]*models.Commit, bool, error)

GetReflogCommits only returns the new reflog commits since the given lastReflogCommit if none is passed (i.e. it's value is nil) then we get all the reflog commits

type RemoteCommands

type RemoteCommands struct {
	*GitCommon
}

func NewRemoteCommands

func NewRemoteCommands(gitCommon *GitCommon) *RemoteCommands

func (*RemoteCommands) AddRemote

func (self *RemoteCommands) AddRemote(name string, url string) error

func (*RemoteCommands) CheckRemoteBranchExists

func (self *RemoteCommands) CheckRemoteBranchExists(branchName string) bool

CheckRemoteBranchExists Returns remote branch

func (*RemoteCommands) DeleteRemoteBranch

func (self *RemoteCommands) DeleteRemoteBranch(remoteName string, branchName string) error

func (*RemoteCommands) RemoveRemote

func (self *RemoteCommands) RemoveRemote(name string) error

func (*RemoteCommands) RenameRemote

func (self *RemoteCommands) RenameRemote(oldRemoteName string, newRemoteName string) error

func (*RemoteCommands) UpdateRemoteUrl

func (self *RemoteCommands) UpdateRemoteUrl(remoteName string, updatedUrl string) error

type RemoteLoader

type RemoteLoader struct {
	*common.Common
	// contains filtered or unexported fields
}

func NewRemoteLoader

func NewRemoteLoader(
	common *common.Common,
	cmd oscommands.ICmdObjBuilder,
	getGoGitRemotes func() ([]*gogit.Remote, error),
) *RemoteLoader

func (*RemoteLoader) GetRemotes

func (self *RemoteLoader) GetRemotes() ([]*models.Remote, error)

type StashCommands

type StashCommands struct {
	*GitCommon
	// contains filtered or unexported fields
}

func NewStashCommands

func NewStashCommands(
	gitCommon *GitCommon,
	fileLoader *FileLoader,
	workingTree *WorkingTreeCommands,
) *StashCommands

func (*StashCommands) Apply

func (self *StashCommands) Apply(index int) error

func (*StashCommands) Drop

func (self *StashCommands) Drop(index int) error

func (*StashCommands) DropNewest

func (self *StashCommands) DropNewest() error

func (*StashCommands) Pop

func (self *StashCommands) Pop(index int) error

func (*StashCommands) Rename

func (self *StashCommands) Rename(index int, message string) error

func (*StashCommands) Save

func (self *StashCommands) Save(message string) error

Save save stash

func (*StashCommands) SaveStagedChanges

func (self *StashCommands) SaveStagedChanges(message string) error

SaveStagedChanges stashes only the currently staged changes. This takes a few steps shoutouts to Joe on https://stackoverflow.com/questions/14759748/stashing-only-staged-changes-in-git-is-it-possible

func (*StashCommands) Sha

func (self *StashCommands) Sha(index int) (string, error)

func (*StashCommands) ShowStashEntryCmdObj

func (self *StashCommands) ShowStashEntryCmdObj(index int) oscommands.ICmdObj

func (*StashCommands) StashAndKeepIndex

func (self *StashCommands) StashAndKeepIndex(message string) error

func (*StashCommands) StashIncludeUntrackedChanges

func (self *StashCommands) StashIncludeUntrackedChanges(message string) error

func (*StashCommands) StashUnstagedChanges

func (self *StashCommands) StashUnstagedChanges(message string) error

func (*StashCommands) Store

func (self *StashCommands) Store(sha string, message string) error

type StashLoader

type StashLoader struct {
	*common.Common
	// contains filtered or unexported fields
}

func NewStashLoader

func NewStashLoader(
	common *common.Common,
	cmd oscommands.ICmdObjBuilder,
) *StashLoader

func (*StashLoader) GetStashEntries

func (self *StashLoader) GetStashEntries(filterPath string) []*models.StashEntry

type StatusCommands

type StatusCommands struct {
	*GitCommon
}

func NewStatusCommands

func NewStatusCommands(
	gitCommon *GitCommon,
) *StatusCommands

func (*StatusCommands) IsBareRepo

func (self *StatusCommands) IsBareRepo() (bool, error)

func (*StatusCommands) IsInMergeState

func (self *StatusCommands) IsInMergeState() (bool, error)

IsInMergeState states whether we are still mid-merge

func (*StatusCommands) RebaseMode

func (self *StatusCommands) RebaseMode() (enums.RebaseMode, error)

RebaseMode returns "" for non-rebase mode, "normal" for normal rebase and "interactive" for interactive rebase

func (*StatusCommands) WorkingTreeState

func (self *StatusCommands) WorkingTreeState() enums.RebaseMode

type SubmoduleCommands

type SubmoduleCommands struct {
	*GitCommon
}

func NewSubmoduleCommands

func NewSubmoduleCommands(gitCommon *GitCommon) *SubmoduleCommands

func (*SubmoduleCommands) Add

func (self *SubmoduleCommands) Add(name string, path string, url string) error

func (*SubmoduleCommands) BulkDeinitCmdObj

func (self *SubmoduleCommands) BulkDeinitCmdObj() oscommands.ICmdObj

func (*SubmoduleCommands) BulkInitCmdObj

func (self *SubmoduleCommands) BulkInitCmdObj() oscommands.ICmdObj

func (*SubmoduleCommands) BulkUpdateCmdObj

func (self *SubmoduleCommands) BulkUpdateCmdObj() oscommands.ICmdObj

func (*SubmoduleCommands) Delete

func (self *SubmoduleCommands) Delete(submodule *models.SubmoduleConfig) error

func (*SubmoduleCommands) ForceBulkUpdateCmdObj

func (self *SubmoduleCommands) ForceBulkUpdateCmdObj() oscommands.ICmdObj

func (*SubmoduleCommands) GetConfigs

func (self *SubmoduleCommands) GetConfigs() ([]*models.SubmoduleConfig, error)

func (*SubmoduleCommands) Init

func (self *SubmoduleCommands) Init(path string) error

func (*SubmoduleCommands) Reset

func (self *SubmoduleCommands) Reset(submodule *models.SubmoduleConfig) error

func (*SubmoduleCommands) ResetSubmodules

func (self *SubmoduleCommands) ResetSubmodules(submodules []*models.SubmoduleConfig) error

func (*SubmoduleCommands) Stash

func (self *SubmoduleCommands) Stash(submodule *models.SubmoduleConfig) error

func (*SubmoduleCommands) Update

func (self *SubmoduleCommands) Update(path string) error

func (*SubmoduleCommands) UpdateAll

func (self *SubmoduleCommands) UpdateAll() error

func (*SubmoduleCommands) UpdateUrl

func (self *SubmoduleCommands) UpdateUrl(name string, path string, newUrl string) error

type SyncCommands

type SyncCommands struct {
	*GitCommon
}

func NewSyncCommands

func NewSyncCommands(gitCommon *GitCommon) *SyncCommands

func (*SyncCommands) FastForward

func (self *SyncCommands) FastForward(branchName string, remoteName string, remoteBranchName string) error

func (*SyncCommands) Fetch

func (self *SyncCommands) Fetch(opts FetchOptions) error

Fetch fetch git repo

func (*SyncCommands) FetchRemote

func (self *SyncCommands) FetchRemote(remoteName string) error

func (*SyncCommands) Pull

func (self *SyncCommands) Pull(opts PullOptions) error

func (*SyncCommands) Push

func (self *SyncCommands) Push(opts PushOpts) error

func (*SyncCommands) PushCmdObj

func (self *SyncCommands) PushCmdObj(opts PushOpts) (oscommands.ICmdObj, error)

type TagCommands

type TagCommands struct {
	*GitCommon
}

func NewTagCommands

func NewTagCommands(gitCommon *GitCommon) *TagCommands

func (*TagCommands) CreateAnnotated

func (self *TagCommands) CreateAnnotated(tagName, ref, msg string) error

func (*TagCommands) CreateLightweight

func (self *TagCommands) CreateLightweight(tagName string, ref string) error

func (*TagCommands) Delete

func (self *TagCommands) Delete(tagName string) error

func (*TagCommands) Push

func (self *TagCommands) Push(remoteName string, tagName string) error

type TagLoader

type TagLoader struct {
	*common.Common
	// contains filtered or unexported fields
}

func NewTagLoader

func NewTagLoader(
	common *common.Common,
	cmd oscommands.ICmdObjBuilder,
) *TagLoader

func (*TagLoader) GetTags

func (self *TagLoader) GetTags() ([]*models.Tag, error)

type TodoLine

type TodoLine struct {
	Action string
	Commit *models.Commit
}

func (*TodoLine) ToString

func (self *TodoLine) ToString() string

type WorkingTreeCommands

type WorkingTreeCommands struct {
	*GitCommon
	// contains filtered or unexported fields
}

func NewWorkingTreeCommands

func NewWorkingTreeCommands(
	gitCommon *GitCommon,
	submodule *SubmoduleCommands,
	fileLoader *FileLoader,
) *WorkingTreeCommands

func (*WorkingTreeCommands) ApplyPatch

func (self *WorkingTreeCommands) ApplyPatch(patch string, flags ...string) error

func (*WorkingTreeCommands) ApplyPatchFile

func (self *WorkingTreeCommands) ApplyPatchFile(filepath string, flags ...string) error

func (*WorkingTreeCommands) BeforeAndAfterFileForRename

func (self *WorkingTreeCommands) BeforeAndAfterFileForRename(file *models.File) (*models.File, *models.File, error)

func (*WorkingTreeCommands) CheckoutFile

func (self *WorkingTreeCommands) CheckoutFile(commitSha, fileName string) error

CheckoutFile checks out the file for the given commit

func (*WorkingTreeCommands) DiscardAllDirChanges

func (self *WorkingTreeCommands) DiscardAllDirChanges(node IFileNode) error

func (*WorkingTreeCommands) DiscardAllFileChanges

func (self *WorkingTreeCommands) DiscardAllFileChanges(file *models.File) error

DiscardAllFileChanges directly

func (*WorkingTreeCommands) DiscardAnyUnstagedFileChanges

func (self *WorkingTreeCommands) DiscardAnyUnstagedFileChanges() error

DiscardAnyUnstagedFileChanges discards any unstages file changes via `git checkout -- .`

func (*WorkingTreeCommands) DiscardUnstagedDirChanges

func (self *WorkingTreeCommands) DiscardUnstagedDirChanges(node IFileNode) error

func (*WorkingTreeCommands) DiscardUnstagedFileChanges

func (self *WorkingTreeCommands) DiscardUnstagedFileChanges(file *models.File) error

DiscardUnstagedFileChanges directly

func (*WorkingTreeCommands) Exclude

func (self *WorkingTreeCommands) Exclude(filename string) error

Exclude adds a file to the .git/info/exclude for the repo

func (*WorkingTreeCommands) Ignore

func (self *WorkingTreeCommands) Ignore(filename string) error

Ignore adds a file to the gitignore for the repo

func (*WorkingTreeCommands) OpenMergeTool

func (self *WorkingTreeCommands) OpenMergeTool() error

func (*WorkingTreeCommands) OpenMergeToolCmdObj

func (self *WorkingTreeCommands) OpenMergeToolCmdObj() oscommands.ICmdObj

func (*WorkingTreeCommands) RemoveTrackedFiles

func (self *WorkingTreeCommands) RemoveTrackedFiles(name string) error

RemoveTrackedFiles will delete the given file(s) even if they are currently tracked

func (*WorkingTreeCommands) RemoveUntrackedDirFiles

func (self *WorkingTreeCommands) RemoveUntrackedDirFiles(node IFileNode) error

func (*WorkingTreeCommands) RemoveUntrackedFiles

func (self *WorkingTreeCommands) RemoveUntrackedFiles() error

RemoveUntrackedFiles runs `git clean -fd`

func (*WorkingTreeCommands) ResetAndClean

func (self *WorkingTreeCommands) ResetAndClean() error

ResetAndClean removes all unstaged changes and removes all untracked files

func (*WorkingTreeCommands) ResetHard

func (self *WorkingTreeCommands) ResetHard(ref string) error

ResetHardHead runs `git reset --hard`

func (*WorkingTreeCommands) ResetMixed

func (self *WorkingTreeCommands) ResetMixed(ref string) error

func (*WorkingTreeCommands) ResetSoft

func (self *WorkingTreeCommands) ResetSoft(ref string) error

ResetSoft runs `git reset --soft HEAD`

func (*WorkingTreeCommands) SaveTemporaryPatch

func (self *WorkingTreeCommands) SaveTemporaryPatch(patch string) (string, error)

func (*WorkingTreeCommands) ShowFileDiff

func (self *WorkingTreeCommands) ShowFileDiff(from string, to string, reverse bool, fileName string, plain bool,
	ignoreWhitespace bool,
) (string, error)

ShowFileDiff get the diff of specified from and to. Typically this will be used for a single commit so it'll be 123abc^..123abc but when we're in diff mode it could be any 'from' to any 'to'. The reverse flag is also here thanks to diff mode.

func (*WorkingTreeCommands) ShowFileDiffCmdObj

func (self *WorkingTreeCommands) ShowFileDiffCmdObj(from string, to string, reverse bool, fileName string, plain bool,
	ignoreWhitespace bool,
) oscommands.ICmdObj

func (*WorkingTreeCommands) StageAll

func (self *WorkingTreeCommands) StageAll() error

StageAll stages all files

func (*WorkingTreeCommands) StageFile

func (self *WorkingTreeCommands) StageFile(path string) error

StageFile stages a file

func (*WorkingTreeCommands) StageFiles

func (self *WorkingTreeCommands) StageFiles(paths []string) error

func (*WorkingTreeCommands) UnStageFile

func (self *WorkingTreeCommands) UnStageFile(fileNames []string, reset bool) error

UnStageFile unstages a file we accept an array of filenames for the cases where a file has been renamed i.e. we accept the current name and the previous name

func (*WorkingTreeCommands) UnstageAll

func (self *WorkingTreeCommands) UnstageAll() error

UnstageAll unstages all files

func (*WorkingTreeCommands) WorktreeFileDiff

func (self *WorkingTreeCommands) WorktreeFileDiff(file *models.File, plain bool, cached bool, ignoreWhitespace bool) string

WorktreeFileDiff returns the diff of a file

func (*WorkingTreeCommands) WorktreeFileDiffCmdObj

func (self *WorkingTreeCommands) WorktreeFileDiffCmdObj(node models.IFile, plain bool, cached bool, ignoreWhitespace bool) oscommands.ICmdObj

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL