Config#LookupString uses git_buf to load value
This commit is contained in:
parent
1c855246ca
commit
80cf533fe4
|
@ -115,18 +115,20 @@ func (c *Config) LookupInt64(name string) (int64, error) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *Config) LookupString(name string) (string, error) {
|
func (c *Config) LookupString(name string) (string, error) {
|
||||||
var ptr *C.char
|
|
||||||
cname := C.CString(name)
|
cname := C.CString(name)
|
||||||
defer C.free(unsafe.Pointer(cname))
|
defer C.free(unsafe.Pointer(cname))
|
||||||
|
|
||||||
|
valBuf := C.git_buf{}
|
||||||
|
|
||||||
runtime.LockOSThread()
|
runtime.LockOSThread()
|
||||||
defer runtime.UnlockOSThread()
|
defer runtime.UnlockOSThread()
|
||||||
|
|
||||||
if ret := C.git_config_get_string(&ptr, c.ptr, cname); ret < 0 {
|
if ret := C.git_config_get_string_buf(&valBuf, c.ptr, cname); ret < 0 {
|
||||||
return "", MakeGitError(ret)
|
return "", MakeGitError(ret)
|
||||||
}
|
}
|
||||||
|
defer C.git_buf_free(&valBuf)
|
||||||
|
|
||||||
return C.GoString(ptr), nil
|
return C.GoString(valBuf.ptr), nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *Config) LookupBool(name string) (bool, error) {
|
func (c *Config) LookupBool(name string) (bool, error) {
|
||||||
|
|
|
@ -0,0 +1,58 @@
|
||||||
|
package git
|
||||||
|
|
||||||
|
import (
|
||||||
|
"os"
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
|
func setupConfig() (*Config, error) {
|
||||||
|
var (
|
||||||
|
c *Config
|
||||||
|
err error
|
||||||
|
p string
|
||||||
|
)
|
||||||
|
|
||||||
|
p, err = ConfigFindGlobal()
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
c, err = OpenOndisk(nil, p)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
c.SetString("foo.bar", "baz")
|
||||||
|
|
||||||
|
return c, err
|
||||||
|
}
|
||||||
|
|
||||||
|
func cleanupConfig() {
|
||||||
|
os.Remove(tempConfig)
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestConfigLookupString(t *testing.T) {
|
||||||
|
var (
|
||||||
|
err error
|
||||||
|
val string
|
||||||
|
c *Config
|
||||||
|
)
|
||||||
|
|
||||||
|
c, err = setupConfig()
|
||||||
|
defer cleanupConfig()
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("Setup error: '%v'. Expected none\n", err)
|
||||||
|
t.FailNow()
|
||||||
|
}
|
||||||
|
defer c.Free()
|
||||||
|
|
||||||
|
val, err = c.LookupString("foo.bar")
|
||||||
|
if err != nil {
|
||||||
|
t.Errorf("Got error: '%v', expected none\n", err)
|
||||||
|
t.FailNow()
|
||||||
|
}
|
||||||
|
|
||||||
|
if val != "baz" {
|
||||||
|
t.Errorf("Got '%s', expected 'bar'\n", val)
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue