libgit2 stores the lookup paths for gitconfig files in its global state.
This means that after a program changes its effective uid libgit2 will
still look for gitconfig files in the home directory of the original
uid. Expose a way to call C.git_libgit2_init so a user can reinitialize
the libgit2 global state.
(cherry picked from commit 3c5c580d78
)
Co-authored-by: Jesse Hathaway <jesse@mbuki-mvuki.org>
This commit is contained in:
parent
627f58d403
commit
a81a08606f
13
git.go
13
git.go
|
@ -118,6 +118,10 @@ var (
|
|||
var pointerHandles *HandleList
|
||||
|
||||
func init() {
|
||||
initLibGit2()
|
||||
}
|
||||
|
||||
func initLibGit2() {
|
||||
pointerHandles = NewHandleList()
|
||||
|
||||
C.git_libgit2_init()
|
||||
|
@ -149,6 +153,15 @@ func Shutdown() {
|
|||
C.git_libgit2_shutdown()
|
||||
}
|
||||
|
||||
// ReInit reinitializes the global state, this is useful if the effective user
|
||||
// id has changed and you want to update the stored search paths for gitconfig
|
||||
// files. This function frees any references to objects, so it should be called
|
||||
// before any other functions are called.
|
||||
func ReInit() {
|
||||
Shutdown()
|
||||
initLibGit2()
|
||||
}
|
||||
|
||||
// Oid represents the id for a Git object.
|
||||
type Oid [20]byte
|
||||
|
||||
|
|
Loading…
Reference in New Issue