summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorVicent Martí <[email protected]>2013-05-16 14:11:10 -0700
committerVicent Martí <[email protected]>2013-05-16 14:11:10 -0700
commita1743f75b2132546d41f0eea486a4961dcf8b435 (patch)
tree543e39b33e53779f9648d002385a1b80cbe9094f
parentc9adbf05d77d17e9b6de0b9c674e2c1e61744bcc (diff)
parent3a1bbbdf9dcdf88c909ea9df127f32b126d38547 (diff)
Merge pull request #21 from Merovius/packbuilder
Implement Packbuilder-Support
-rw-r--r--packbuilder.go111
-rw-r--r--wrapper.c6
2 files changed, 117 insertions, 0 deletions
diff --git a/packbuilder.go b/packbuilder.go
new file mode 100644
index 0000000..8cc03bd
--- /dev/null
+++ b/packbuilder.go
@@ -0,0 +1,111 @@
+package git
+
+/*
+#cgo pkg-config: libgit2
+#include <git2.h>
+#include <git2/errors.h>
+#include <git2/pack.h>
+#include <stdlib.h>
+
+extern int _go_git_packbuilder_foreach(git_packbuilder *pb, void *payload);
+*/
+import "C"
+import (
+ "runtime"
+ "unsafe"
+ "io"
+)
+
+type Packbuilder struct {
+ ptr *C.git_packbuilder
+}
+
+func (repo *Repository) NewPackbuilder() (*Packbuilder, error) {
+ builder := &Packbuilder{}
+ ret := C.git_packbuilder_new(&builder.ptr, repo.ptr)
+ if ret != 0 {
+ return nil, LastError()
+ }
+ runtime.SetFinalizer(builder, (*Packbuilder).Free)
+ return builder, nil
+}
+
+func (pb *Packbuilder) Free() {
+ runtime.SetFinalizer(pb, nil)
+ C.git_packbuilder_free(pb.ptr)
+}
+
+func (pb *Packbuilder) Insert(id *Oid, name string) error {
+ cname := C.CString(name)
+ defer C.free(unsafe.Pointer(cname))
+ ret := C.git_packbuilder_insert(pb.ptr, id.toC(), cname)
+ if ret != 0 {
+ return LastError()
+ }
+ return nil
+}
+
+func (pb *Packbuilder) InsertCommit(id *Oid) error {
+ ret := C.git_packbuilder_insert_commit(pb.ptr, id.toC())
+ if ret != 0 {
+ return LastError()
+ }
+ return nil
+}
+
+func (pb *Packbuilder) InsertTree(id *Oid) error {
+ ret := C.git_packbuilder_insert_tree(pb.ptr, id.toC())
+ if ret != 0 {
+ return LastError()
+ }
+ return nil
+}
+
+func (pb *Packbuilder) ObjectCount() uint32 {
+ return uint32(C.git_packbuilder_object_count(pb.ptr))
+}
+
+func (pb *Packbuilder) WriteToFile(name string) error {
+ cname := C.CString(name)
+ defer C.free(unsafe.Pointer(cname))
+ ret := C.git_packbuilder_write(pb.ptr, cname)
+ if ret != 0 {
+ return LastError()
+ }
+ return nil
+}
+
+func (pb *Packbuilder) Write(w io.Writer) error {
+ ch := pb.ForEach()
+ for slice := range ch {
+ _, err := w.Write(slice)
+ if err != nil {
+ return err
+ }
+ }
+ return nil
+}
+
+func (pb *Packbuilder) Written() uint32 {
+ return uint32(C.git_packbuilder_written(pb.ptr))
+}
+
+//export packbuilderForEachCb
+func packbuilderForEachCb(buf unsafe.Pointer, size C.size_t, payload unsafe.Pointer) int {
+ ch := *(*chan []byte)(payload)
+
+ slice := C.GoBytes(buf, C.int(size))
+ ch <- slice
+ return 0
+}
+
+func (pb *Packbuilder) forEachWrap(ch chan []byte) {
+ C._go_git_packbuilder_foreach(pb.ptr, unsafe.Pointer(&ch))
+ close(ch)
+}
+
+func (pb *Packbuilder) ForEach() chan []byte {
+ ch := make(chan []byte, 0)
+ go pb.forEachWrap(ch)
+ return ch
+}
diff --git a/wrapper.c b/wrapper.c
index 13478cb..67f34fd 100644
--- a/wrapper.c
+++ b/wrapper.c
@@ -1,6 +1,7 @@
#include "_cgo_export.h"
#include "git2.h"
#include "git2/submodule.h"
+#include "git2/pack.h"
typedef int (*gogit_submodule_cbk)(git_submodule *sm, const char *name, void *payload);
@@ -14,4 +15,9 @@ int _go_git_treewalk(git_tree *tree, git_treewalk_mode mode, void *ptr)
return git_tree_walk(tree, mode, (git_treewalk_cb)&CallbackGitTreeWalk, ptr);
}
+int _go_git_packbuilder_foreach(git_packbuilder *pb, void *payload)
+{
+ return git_packbuilder_foreach(pb, (git_packbuilder_foreach_cb)&packbuilderForEachCb, payload);
+}
+
/* EOF */