summaryrefslogtreecommitdiff
path: root/repository.go
diff options
context:
space:
mode:
authorVicent Martí <[email protected]>2013-03-05 16:59:40 -0800
committerVicent Martí <[email protected]>2013-03-05 16:59:40 -0800
commit9b6d570748ae51bf38e3192f9a5de45bc68b23c6 (patch)
treed4494ed38a76fa9c69f4fc00513340ff0096f980 /repository.go
parent2885e3fe0cc403514d0ade13bae5f430b2e9252e (diff)
parentd43561fbf711896f5ce33f409c6000946416a82b (diff)
Merge pull request #3 from carlosmn/finalizers
Free Git objects via finalizers or manually
Diffstat (limited to 'repository.go')
-rw-r--r--repository.go16
1 files changed, 9 insertions, 7 deletions
diff --git a/repository.go b/repository.go
index 755926e..bfbfebd 100644
--- a/repository.go
+++ b/repository.go
@@ -27,7 +27,7 @@ func Open(path string) (*Repository, error) {
return nil, LastError()
}
- runtime.SetFinalizer(repo, freeRepository)
+ runtime.SetFinalizer(repo, (*Repository).Free)
return repo, nil
}
@@ -42,12 +42,13 @@ func Init(path string, isbare bool) (*Repository, error) {
return nil, LastError()
}
- runtime.SetFinalizer(repo, freeRepository)
+ runtime.SetFinalizer(repo, (*Repository).Free)
return repo, nil
}
-func freeRepository(repo *Repository) {
- C.git_repository_free(repo.ptr)
+func (v *Repository) Free() {
+ runtime.SetFinalizer(v, nil)
+ C.git_repository_free(v.ptr)
}
func (v *Repository) Config() (*Config, error) {
@@ -127,8 +128,9 @@ func (v *Repository) Commit(
}
*/
-func freeOdb(odb *Odb) {
- C.git_odb_free(odb.ptr)
+func (v *Odb) Free() {
+ runtime.SetFinalizer(v, nil)
+ C.git_odb_free(v.ptr)
}
func (v *Repository) Odb() (odb *Odb, err error) {
@@ -137,7 +139,7 @@ func (v *Repository) Odb() (odb *Odb, err error) {
return nil, LastError()
}
- runtime.SetFinalizer(odb, freeOdb)
+ runtime.SetFinalizer(odb, (*Odb).Free)
return
}