diff options
| author | Vicent Martà <[email protected]> | 2013-03-05 16:59:40 -0800 |
|---|---|---|
| committer | Vicent Martà <[email protected]> | 2013-03-05 16:59:40 -0800 |
| commit | 9b6d570748ae51bf38e3192f9a5de45bc68b23c6 (patch) | |
| tree | d4494ed38a76fa9c69f4fc00513340ff0096f980 /repository.go | |
| parent | 2885e3fe0cc403514d0ade13bae5f430b2e9252e (diff) | |
| parent | d43561fbf711896f5ce33f409c6000946416a82b (diff) | |
Merge pull request #3 from carlosmn/finalizers
Free Git objects via finalizers or manually
Diffstat (limited to 'repository.go')
| -rw-r--r-- | repository.go | 16 |
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 } |
