本站源代码
Du kannst nicht mehr als 25 Themen auswählen Themen müssen entweder mit einem Buchstaben oder einer Ziffer beginnen. Sie können Bindestriche („-“) enthalten und bis zu 35 Zeichen lang sein.
Antoine GIRARD bb22e3a1e1 update gopkg.in/src-d/go-git.v4 to v4.13.1 (#7705) vor 5 Jahren
..
config Update src-d/go-git to v4.13.0 (#7688) vor 5 Jahren
internal [mod]: Bump gopkg.in/src-d/go-git.v4 from 4.8.0 to 4.10.0 (#6662) vor 5 Jahren
plumbing Update src-d/go-git to v4.13.0 (#7688) vor 5 Jahren
storage Update src-d/go-git to v4.13.0 (#7688) vor 5 Jahren
utils update go-git to v4.12.0 - fixes #7248 (#7249) vor 5 Jahren
.gitignore Use Go1.11 module (#5743) vor 5 Jahren
.travis.yml update go git from v4.10.0 to v4.11.0 (#7096) vor 5 Jahren
CODE_OF_CONDUCT.md Use Go1.11 module (#5743) vor 5 Jahren
COMPATIBILITY.md update go-git to v4.12.0 - fixes #7248 (#7249) vor 5 Jahren
CONTRIBUTING.md Use Go1.11 module (#5743) vor 5 Jahren
DCO Use Go1.11 module (#5743) vor 5 Jahren
LICENSE Implement git refs API for listing references (branches, tags and other) (#5354) vor 6 Jahren
MAINTAINERS Use Go1.11 module (#5743) vor 5 Jahren
Makefile Use Go1.11 module (#5743) vor 5 Jahren
README.md Use Go1.11 module (#5743) vor 5 Jahren
appveyor.yml Use Go1.11 module (#5743) vor 5 Jahren
blame.go Update src-d/go-git to v4.13.0 (#7688) vor 5 Jahren
common.go Implement git refs API for listing references (branches, tags and other) (#5354) vor 6 Jahren
doc.go Implement git refs API for listing references (branches, tags and other) (#5354) vor 6 Jahren
go.mod Update src-d/go-git to v4.13.0 (#7688) vor 5 Jahren
go.sum Update src-d/go-git to v4.13.0 (#7688) vor 5 Jahren
object_walker.go Implement git refs API for listing references (branches, tags and other) (#5354) vor 6 Jahren
options.go Update src-d/go-git to v4.13.0 (#7688) vor 5 Jahren
prune.go Implement git refs API for listing references (branches, tags and other) (#5354) vor 6 Jahren
references.go Implement git refs API for listing references (branches, tags and other) (#5354) vor 6 Jahren
remote.go Update src-d/go-git to v4.13.0 (#7688) vor 5 Jahren
repository.go update go-git to v4.12.0 - fixes #7248 (#7249) vor 5 Jahren
status.go Implement git refs API for listing references (branches, tags and other) (#5354) vor 6 Jahren
submodule.go Implement git refs API for listing references (branches, tags and other) (#5354) vor 6 Jahren
worktree.go Update src-d/go-git to v4.13.0 (#7688) vor 5 Jahren
worktree_bsd.go Implement git refs API for listing references (branches, tags and other) (#5354) vor 6 Jahren
worktree_commit.go Implement git refs API for listing references (branches, tags and other) (#5354) vor 6 Jahren
worktree_linux.go update gopkg.in/src-d/go-git.v4 to v4.13.1 (#7705) vor 5 Jahren
worktree_status.go update go git from v4.10.0 to v4.11.0 (#7096) vor 5 Jahren
worktree_unix_other.go Implement git refs API for listing references (branches, tags and other) (#5354) vor 6 Jahren
worktree_windows.go Implement git refs API for listing references (branches, tags and other) (#5354) vor 6 Jahren

README.md

go-git logo GoDoc Build Status Build status codecov.io Go Report Card

go-git is a highly extensible git implementation library written in pure Go.

It can be used to manipulate git repositories at low level (plumbing) or high level (porcelain), through an idiomatic Go API. It also supports several types of storage, such as in-memory filesystems, or custom implementations thanks to the Storer interface.

It’s being actively developed since 2015 and is being used extensively by source{d} and Keybase, and by many other libraries and tools.

Comparison with git

go-git aims to be fully compatible with git, all the porcelain operations are implemented to work exactly as git does.

git is a humongous project with years of development by thousands of contributors, making it challenging for go-git to implement all the features. You can find a comparison of go-git vs git in the compatibility documentation.

Installation

The recommended way to install go-git is:

go get -u gopkg.in/src-d/go-git.v4/...

We use gopkg.in to version the API, this means that when go get clones the package, it’s the latest tag matching v4.* that is cloned and not the master branch.

Examples

Please note that the CheckIfError and Info functions used in the examples are from the examples package just to be used in the examples.

Basic example

A basic example that mimics the standard git clone command

// Clone the given repository to the given directory
Info("git clone https://github.com/src-d/go-git")

_, err := git.PlainClone("/tmp/foo", false, &git.CloneOptions{
    URL:      "https://github.com/src-d/go-git",
    Progress: os.Stdout,
})

CheckIfError(err)

Outputs:

Counting objects: 4924, done.
Compressing objects: 100% (1333/1333), done.
Total 4924 (delta 530), reused 6 (delta 6), pack-reused 3533

In-memory example

Cloning a repository into memory and printing the history of HEAD, just like git log does

// Clones the given repository in memory, creating the remote, the local
// branches and fetching the objects, exactly as:
Info("git clone https://github.com/src-d/go-siva")

r, err := git.Clone(memory.NewStorage(), nil, &git.CloneOptions{
    URL: "https://github.com/src-d/go-siva",
})

CheckIfError(err)

// Gets the HEAD history from HEAD, just like this command:
Info("git log")

// ... retrieves the branch pointed by HEAD
ref, err := r.Head()
CheckIfError(err)


// ... retrieves the commit history
cIter, err := r.Log(&git.LogOptions{From: ref.Hash()})
CheckIfError(err)

// ... just iterates over the commits, printing it
err = cIter.ForEach(func(c *object.Commit) error {
	fmt.Println(c)
	return nil
})
CheckIfError(err)

Outputs:

commit ded8054fd0c3994453e9c8aacaf48d118d42991e
Author: Santiago M. Mola <santi@mola.io>
Date:   Sat Nov 12 21:18:41 2016 +0100

    index: ReadFrom/WriteTo returns IndexReadError/IndexWriteError. (#9)

commit df707095626f384ce2dc1a83b30f9a21d69b9dfc
Author: Santiago M. Mola <santi@mola.io>
Date:   Fri Nov 11 13:23:22 2016 +0100

    readwriter: fix bug when writing index. (#10)

    When using ReadWriter on an existing siva file, absolute offset for
    index entries was not being calculated correctly.
...

You can find this example and many others in the examples folder.

Contribute

Contributions are more than welcome, if you are interested please take a look to our Contributing Guidelines.

License

Apache License Version 2.0, see LICENSE

上海开阖软件有限公司 沪ICP备12045867号-1