forked from go-git/go-git
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.go
45 lines (36 loc) · 1.22 KB
/
main.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
package main
import (
"os"
"github.com/go-git/go-git/v5"
. "github.com/go-git/go-git/v5/_examples"
"github.com/go-git/go-git/v5/plumbing"
)
// An example of how to create and remove branches or any other kind of reference.
func main() {
CheckArgs("<url>", "<directory>")
url, directory := os.Args[1], os.Args[2]
// Clone the given repository to the given directory
Info("git clone %s %s", url, directory)
r, err := git.PlainClone(directory, false, &git.CloneOptions{
URL: url,
})
CheckIfError(err)
// Create a new branch to the current HEAD
Info("git branch my-branch")
headRef, err := r.Head()
CheckIfError(err)
// Create a new plumbing.HashReference object with the name of the branch
// and the hash from the HEAD. The reference name should be a full reference
// name and not an abbreviated one, as is used on the git cli.
//
// For tags we should use `refs/tags/%s` instead of `refs/heads/%s` used
// for branches.
ref := plumbing.NewHashReference("refs/heads/my-branch", headRef.Hash())
// The created reference is saved in the storage.
err = r.Storer.SetReference(ref)
CheckIfError(err)
// Or deleted from it.
Info("git branch -D my-branch")
err = r.Storer.RemoveReference(ref.Name())
CheckIfError(err)
}