Skip to content

Commit a06f4a0

Browse files
committed
Adjust to Go tip changes
It does not like breaking aliasing rules, so let's keep a casted pointer for when libgit2 wants that.
1 parent 286ff62 commit a06f4a0

File tree

6 files changed

+43
-31
lines changed

6 files changed

+43
-31
lines changed

blob.go

Lines changed: 4 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -20,15 +20,16 @@ import (
2020

2121
type Blob struct {
2222
gitObject
23+
cast_ptr *C.git_blob
2324
}
2425

2526
func (v *Blob) Size() int64 {
26-
return int64(C.git_blob_rawsize(v.ptr))
27+
return int64(C.git_blob_rawsize(v.cast_ptr))
2728
}
2829

2930
func (v *Blob) Contents() []byte {
30-
size := C.int(C.git_blob_rawsize(v.ptr))
31-
buffer := unsafe.Pointer(C.git_blob_rawcontent(v.ptr))
31+
size := C.int(C.git_blob_rawsize(v.cast_ptr))
32+
buffer := unsafe.Pointer(C.git_blob_rawcontent(v.cast_ptr))
3233
return C.GoBytes(buffer, size)
3334
}
3435

branch.go

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -43,7 +43,7 @@ func (repo *Repository) CreateBranch(branchName string, target *Commit, force bo
4343
runtime.LockOSThread()
4444
defer runtime.UnlockOSThread()
4545

46-
ret := C.git_branch_create(&ref.ptr, repo.ptr, cBranchName, target.ptr, cForce, cSignature, cmsg)
46+
ret := C.git_branch_create(&ref.ptr, repo.ptr, cBranchName, target.cast_ptr, cForce, cSignature, cmsg)
4747
if ret < 0 {
4848
return nil, MakeGitError(ret)
4949
}

commit.go

Lines changed: 15 additions & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -17,56 +17,57 @@ import (
1717
// Commit
1818
type Commit struct {
1919
gitObject
20+
cast_ptr *C.git_commit
2021
}
2122

2223
func (c Commit) Message() string {
23-
return C.GoString(C.git_commit_message(c.ptr))
24+
return C.GoString(C.git_commit_message(c.cast_ptr))
2425
}
2526

2627
func (c Commit) Tree() (*Tree, error) {
27-
var ptr *C.git_object
28+
var ptr *C.git_tree
2829

2930
runtime.LockOSThread()
3031
defer runtime.UnlockOSThread()
3132

32-
err := C.git_commit_tree(&ptr, c.ptr)
33+
err := C.git_commit_tree(&ptr, c.cast_ptr)
3334
if err < 0 {
3435
return nil, MakeGitError(err)
3536
}
3637

37-
return allocObject(ptr).(*Tree), nil
38+
return allocObject((*C.git_object)(ptr)).(*Tree), nil
3839
}
3940

4041
func (c Commit) TreeId() *Oid {
41-
return newOidFromC(C.git_commit_tree_id(c.ptr))
42+
return newOidFromC(C.git_commit_tree_id(c.cast_ptr))
4243
}
4344

4445
func (c Commit) Author() *Signature {
45-
ptr := C.git_commit_author(c.ptr)
46-
return newSignatureFromC(ptr)
46+
cast_ptr := C.git_commit_author(c.cast_ptr)
47+
return newSignatureFromC(cast_ptr)
4748
}
4849

4950
func (c Commit) Committer() *Signature {
50-
ptr := C.git_commit_committer(c.ptr)
51-
return newSignatureFromC(ptr)
51+
cast_ptr := C.git_commit_committer(c.cast_ptr)
52+
return newSignatureFromC(cast_ptr)
5253
}
5354

5455
func (c *Commit) Parent(n uint) *Commit {
55-
var cobj *C.git_object
56-
ret := C.git_commit_parent(&cobj, c.ptr, C.uint(n))
56+
var cobj *C.git_commit
57+
ret := C.git_commit_parent(&cobj, c.cast_ptr, C.uint(n))
5758
if ret != 0 {
5859
return nil
5960
}
6061

61-
return allocObject(cobj).(*Commit)
62+
return allocObject((*C.git_object)(cobj)).(*Commit)
6263
}
6364

6465
func (c *Commit) ParentId(n uint) *Oid {
65-
return newOidFromC(C.git_commit_parent_id(c.ptr, C.uint(n)))
66+
return newOidFromC(C.git_commit_parent_id(c.cast_ptr, C.uint(n)))
6667
}
6768

6869
func (c *Commit) ParentCount() uint {
69-
return uint(C.git_commit_parentcount(c.ptr))
70+
return uint(C.git_commit_parentcount(c.cast_ptr))
7071
}
7172

7273
// Signature

object.go

Lines changed: 14 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -48,7 +48,7 @@ func (t ObjectType) String() (string) {
4848
}
4949

5050
func (o gitObject) Id() *Oid {
51-
return newOidFromC(C.git_commit_id(o.ptr))
51+
return newOidFromC(C.git_object_id(o.ptr))
5252
}
5353

5454
func (o gitObject) Type() ObjectType {
@@ -57,24 +57,33 @@ func (o gitObject) Type() ObjectType {
5757

5858
func (o *gitObject) Free() {
5959
runtime.SetFinalizer(o, nil)
60-
C.git_commit_free(o.ptr)
60+
C.git_object_free(o.ptr)
6161
}
6262

6363
func allocObject(cobj *C.git_object) Object {
6464

6565
switch ObjectType(C.git_object_type(cobj)) {
6666
case ObjectCommit:
67-
commit := &Commit{gitObject{cobj}}
67+
commit := &Commit{
68+
gitObject: gitObject{cobj},
69+
cast_ptr: (*C.git_commit)(cobj),
70+
}
6871
runtime.SetFinalizer(commit, (*Commit).Free)
6972
return commit
7073

7174
case ObjectTree:
72-
tree := &Tree{gitObject{cobj}}
75+
tree := &Tree{
76+
gitObject: gitObject{cobj},
77+
cast_ptr: (*C.git_tree)(cobj),
78+
}
7379
runtime.SetFinalizer(tree, (*Tree).Free)
7480
return tree
7581

7682
case ObjectBlob:
77-
blob := &Blob{gitObject{cobj}}
83+
blob := &Blob{
84+
gitObject: gitObject{cobj},
85+
cast_ptr: (*C.git_blob)(cobj),
86+
}
7887
runtime.SetFinalizer(blob, (*Blob).Free)
7988
return blob
8089
}

repository.go

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -239,7 +239,7 @@ func (v *Repository) CreateCommit(
239239
if nparents > 0 {
240240
cparents = make([]*C.git_commit, nparents)
241241
for i, v := range parents {
242-
cparents[i] = v.ptr
242+
cparents[i] = v.cast_ptr
243243
}
244244
parentsarg = &cparents[0]
245245
}
@@ -256,7 +256,7 @@ func (v *Repository) CreateCommit(
256256
ret := C.git_commit_create(
257257
oid.toC(), v.ptr, cref,
258258
authorSig, committerSig,
259-
nil, cmsg, tree.ptr, C.size_t(nparents), parentsarg)
259+
nil, cmsg, tree.cast_ptr, C.size_t(nparents), parentsarg)
260260

261261
if ret < 0 {
262262
return nil, MakeGitError(ret)
@@ -331,7 +331,7 @@ func (v *Repository) TreeBuilderFromTree(tree *Tree) (*TreeBuilder, error) {
331331
runtime.LockOSThread()
332332
defer runtime.UnlockOSThread()
333333

334-
if ret := C.git_treebuilder_create(&bld.ptr, tree.ptr); ret < 0 {
334+
if ret := C.git_treebuilder_create(&bld.ptr, tree.cast_ptr); ret < 0 {
335335
return nil, MakeGitError(ret)
336336
}
337337
runtime.SetFinalizer(bld, (*TreeBuilder).Free)

tree.go

Lines changed: 6 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -26,6 +26,7 @@ const (
2626

2727
type Tree struct {
2828
gitObject
29+
cast_ptr *C.git_tree
2930
}
3031

3132
type TreeEntry struct {
@@ -48,7 +49,7 @@ func (t Tree) EntryByName(filename string) *TreeEntry {
4849
cname := C.CString(filename)
4950
defer C.free(unsafe.Pointer(cname))
5051

51-
entry := C.git_tree_entry_byname(t.ptr, cname)
52+
entry := C.git_tree_entry_byname(t.cast_ptr, cname)
5253
if entry == nil {
5354
return nil
5455
}
@@ -66,7 +67,7 @@ func (t Tree) EntryByPath(path string) (*TreeEntry, error) {
6667
runtime.LockOSThread()
6768
defer runtime.UnlockOSThread()
6869

69-
ret := C.git_tree_entry_bypath(&entry, t.ptr, cpath)
70+
ret := C.git_tree_entry_bypath(&entry, t.cast_ptr, cpath)
7071
if ret < 0 {
7172
return nil, MakeGitError(ret)
7273
}
@@ -75,7 +76,7 @@ func (t Tree) EntryByPath(path string) (*TreeEntry, error) {
7576
}
7677

7778
func (t Tree) EntryByIndex(index uint64) *TreeEntry {
78-
entry := C.git_tree_entry_byindex(t.ptr, C.size_t(index))
79+
entry := C.git_tree_entry_byindex(t.cast_ptr, C.size_t(index))
7980
if entry == nil {
8081
return nil
8182
}
@@ -84,7 +85,7 @@ func (t Tree) EntryByIndex(index uint64) *TreeEntry {
8485
}
8586

8687
func (t Tree) EntryCount() uint64 {
87-
num := C.git_tree_entrycount(t.ptr)
88+
num := C.git_tree_entrycount(t.cast_ptr)
8889
return uint64(num)
8990
}
9091

@@ -104,7 +105,7 @@ func (t Tree) Walk(callback TreeWalkCallback) error {
104105
defer runtime.UnlockOSThread()
105106

106107
err := C._go_git_treewalk(
107-
t.ptr,
108+
t.cast_ptr,
108109
C.GIT_TREEWALK_PRE,
109110
unsafe.Pointer(&callback),
110111
)

0 commit comments

Comments
 (0)