model

package
v2.3.0+incompatible Latest Latest
Warning

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

Go to latest
Published: Sep 12, 2018 License: MIT Imports: 17 Imported by: 0

Documentation

Overview

Package model provides the model of repository and commit. As long as another model that will be use in gitgo command.

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type Branch

type Branch struct {
	Repository *git.Repository
	Worktree   *git.Worktree
	HEAD       *plumbing.Reference
	Reference  *plumbing.Reference
	KeyList    *List
}

func (*Branch) AskCreate

func (b *Branch) AskCreate(requireDesc, requireIter, requireIssue, issueHashtag bool) *Branch

func (*Branch) Checkout

func (b *Branch) Checkout(ref *plumbing.Reference)

func (*Branch) CheckoutD

func (b *Branch) CheckoutD()

func (*Branch) Create

func (b *Branch) Create(name string) *Branch

func (*Branch) CurrentBranch

func (b *Branch) CurrentBranch() plumbing.ReferenceName

func (*Branch) Exist

func (b *Branch) Exist(name string) bool

func (*Branch) List

func (b *Branch) List(all bool, fn func(title string, i int, r *plumbing.Reference))

type BranchName

type BranchName struct {
	Iter  string
	Key   string
	Title string
	Desc  string
	Issue string
}

BranchName is the object the create branch name.

func (*BranchName) GetKey

func (b *BranchName) GetKey() string

GetKey will try to format the key to right way. Otherwise, return normal Key

func (*BranchName) Name

func (b *BranchName) Name() string

type Commit

type Commit struct {
	KeyList *List
	// contains filtered or unexported fields
}

Commit is Commit object of deal with commit things.

func (*Commit) Commit

func (c *Commit) Commit(add, hasMessage bool, key string)

Commit is action for ask the message from user and call CustomCommit.

func (*Commit) CustomCommit

func (c *Commit) CustomCommit(add bool, answers CommitMessage)

CustomCommit will run git commit -m "<message>" with the default format.

type CommitMessage

type CommitMessage struct {
	Key     string
	Title   string
	Message string
}

CommitMessage is the commit message for save in commit.

func (*CommitMessage) GetKey

func (c *CommitMessage) GetKey() string

GetKey will try to format the key to right way. Otherwise, return normal Key

func (*CommitMessage) GetMessage

func (c *CommitMessage) GetMessage() string

type GitCommand

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

GitCommand is git-cli command with custom stdout and custom stderr

func Git

func Git() *GitCommand

Git will return singleton GitCommand

func (*GitCommand) Exec

func (g *GitCommand) Exec(args ...string) *manager.ErrManager

Exec will run git cli in command line

func (*GitCommand) SetErrWriter

func (g *GitCommand) SetErrWriter(err io.Writer) *GitCommand

SetErrWriter will set err writer

func (*GitCommand) SetOutWriter

func (g *GitCommand) SetOutWriter(out io.Writer) *GitCommand

SetOutWriter will set out writer

func (*GitCommand) SetReader

func (g *GitCommand) SetReader(in io.Reader) *GitCommand

SetReader will set reader

type Header struct {
	Key   string
	Value string
}

Header is struct of Key and Value, using in list.yaml.

func (*Header) Format

func (h *Header) Format() string

Format will return format of string.

func (*Header) String

func (h *Header) String() string

String will return string that show what is it.

type List

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

func (*List) IsContain

func (l *List) IsContain() bool

IsContain check is list have element

func (*List) Load

func (l *List) Load(vp *viper.Viper) *List

func (*List) MakeList

func (l *List) MakeList() []string

MakeList will return header list

func (*List) Merge

func (l *List) Merge(vp *viper.Viper) *List

func (*List) Setup

func (l *List) Setup(key string) *List

type Repo

type Repo struct {
	Manager *manager.ResultManager
	// contains filtered or unexported fields
}

Repo is git repository object for gitgo.

func CustomRepo

func CustomRepo(path string) *Repo

CustomRepo will return repo of custom path

func NewRepo

func NewRepo() *Repo

NewRepo will return new repository with current path. you must call setup for load git repository to memory.

func (*Repo) Add

func (r *Repo) Add(filepath []string) *manager.Throwable

Add get array of filepath, and return ErrManager. anyway, It's will run os.Exit with code 10 if any error occurred.

func (*Repo) AddAll

func (r *Repo) AddAll() *manager.Throwable

AddAll will run git add -A command in cli.

func (*Repo) GetBranch

func (r *Repo) GetBranch() *Branch

func (*Repo) GetCommit

func (r *Repo) GetCommit() *Commit

GetCommit will return Commit object.

func (*Repo) GetGitRepository

func (r *Repo) GetGitRepository() *manager.ResultWrapper

GetGitRepository will return git.Repository of this Repo

func (*Repo) GetRawGitRepository

func (r *Repo) GetRawGitRepository() *git.Repository

GetRawGitRepository will return git.Repository of this Repo, can be nil

func (*Repo) GetRawWorktree

func (r *Repo) GetRawWorktree() *git.Worktree

GetRawWorktree is getter to get worktree, this method can return nil value

func (*Repo) GetWorktree

func (r *Repo) GetWorktree() *manager.ResultWrapper

GetWorktree is getter method, which get git.Worktree from git.Repository.

func (*Repo) Setup

func (r *Repo) Setup()

Setup will load git repository to memory. If any error occurred, exit with code 5.

func (*Repo) Status

func (r *Repo) Status() *manager.ResultWrapper

Status will return *git.Status.

type YAML

type YAML struct{}

YAML is object of config yaml

func GeneratorYAML

func GeneratorYAML() *YAML

GeneratorYAML will return YAML Object

func (*YAML) ChgLogConfig

func (y *YAML) ChgLogConfig(style, repoUrl string) string

func (*YAML) ChgLogTpl

func (y *YAML) ChgLogTpl() string

func (*YAML) GDefaultConfig

func (y *YAML) GDefaultConfig() string

GDefaultConfig is global default config.yaml

func (*YAML) GDefaultList

func (y *YAML) GDefaultList() string

GDefaultList is global default list.yaml

func (*YAML) LEmptyList

func (y *YAML) LEmptyList() string

LEmptyList is empty list.yaml

Jump to

Keyboard shortcuts

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