-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathxconf_default.go
100 lines (70 loc) · 4.48 KB
/
xconf_default.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
package xconf
import (
"io"
"github.com/sandwich-go/xconf/kv"
"github.com/sandwich-go/xconf/xutil"
)
var xx *XConf
func init() {
xx = New()
}
// SaveVarToWriterAsYAML 将内置解析的数据解析到yaml,带comment
func SaveVarToWriterAsYAML(valPtr interface{}, writer io.Writer) error {
return xx.SaveVarToWriterAsYAML(valPtr, writer)
}
// Merge 合并配置
func Merge(opts ...Option) error { return xx.Merge(opts...) }
// Parse 解析配置到传入的参数中
func Parse(valPtr interface{}, opts ...Option) error { return xx.Parse(valPtr, opts...) }
// MustParse 解析配置到传入的参数中,如发生错误则直接panic
func MustParse(valPtr interface{}, opts ...Option) { xx.MustParse(valPtr, opts...) }
// HashStructure 返回指定配置的hash字符串
func HashStructure(v interface{}) (s string) { return xx.HashStructure(v) }
// Hash 返回当前最新数据的hash字符串
func Hash() (s string) { return xx.Hash() }
// Latest 将xconf内缓存的配置数据绑定到Parse时传入类型,逻辑层需要将返回的interface{}转换到相应的配置指针
func Latest() (interface{}, error) { return xx.Latest() }
// Usage usage info
func Usage() { xx.Usage() }
// DumpInfo debug数据
func DumpInfo() { xx.DumpInfo() }
// NotifyUpdate 底层配置更新,返回的是全量的数据指针
func NotifyUpdate() <-chan interface{} { return xx.NotifyUpdate() }
// WatchUpdate confPath不会自动绑定env value,如果需要watch的路径与环境变量相关,先通过ParseEnvValue自行解析替换处理错误
func WatchUpdate(confPath string, loader kv.Loader) { xx.WatchUpdate(confPath, loader) }
// UpdateWithFieldPathValues 根据字段FieldPath更新数据, 支持的字段类型依赖于xflag,通过NotifyUpdate异步通知更新或通过Latest同步获取
func UpdateWithFieldPathValues(kv ...string) (err error) { return xx.UpdateWithFieldPathValues(kv...) }
// UpdateWithFlagArgs 提供FlagSet合法参数更新数据,通过NotifyUpdate异步通知更新或通过Latest同步获取
func UpdateWithFlagArgs(flagArgs ...string) (err error) { return xx.UpdateWithFlagArgs(flagArgs...) }
// UpdateWithEnviron 提供环境变量合法配置更新数据,通过NotifyUpdate异步通知更新或通过Latest同步获取
func UpdateWithEnviron(environ ...string) (err error) { return xx.UpdateWithEnviron(environ...) }
// UpdateWithFiles 通过文件更新配置,通过NotifyUpdate异步通知更新或通过Latest同步获取
func UpdateWithFiles(files ...string) (err error) { return xx.UpdateWithFiles(files...) }
// UpdateWithReader 通过reader更新配置,通过NotifyUpdate异步通知更新或通过Latest同步获取
func UpdateWithReader(readers ...io.Reader) (err error) { return xx.UpdateWithReader(readers...) }
// WatchFieldPath 关注特定的字段变化
func WatchFieldPath(fieldPath string, changed OnFieldUpdated) { xx.WatchFieldPath(fieldPath, changed) }
// SaveToFile 将内置解析的数据dump到文件,根据文件后缀选择codec
func SaveToFile(fileName string) error { return xx.SaveToFile(fileName) }
// SaveToWriter 将内置解析的数据dump到writer,类型为ct
func SaveToWriter(ct ConfigType, writer io.Writer) error { return xx.SaveToWriter(ct, writer) }
// SaveVarToFile 将外部传入的valPtr,写入到fileName中,根据文件后缀选择codec
func SaveVarToFile(valPtr interface{}, fileName string) error {
return xx.SaveVarToFile(valPtr, fileName)
}
// SaveVarToWriter 将外部传入的valPtr,写入到writer中,类型为ct
func SaveVarToWriter(valPtr interface{}, ct ConfigType, writer io.Writer) error {
return xx.SaveVarToWriter(valPtr, ct, writer)
}
// MustSaveToFile 将内置解析的数据dump到文件,根据文件后缀选择codec,如发生错误会panic
func MustSaveToFile(f string) { xx.MustSaveToFile(f) }
// MustSaveToWriter 将内置解析的数据dump到writer,需指定ConfigType,如发生错误会panic
func MustSaveToWriter(ct ConfigType, writer io.Writer) { xx.MustSaveToWriter(ct, writer) }
// MustSaveVarToFile 将外部传入的valPtr,写入到fileName中,根据文件后缀选择codec
func MustSaveVarToFile(v interface{}, f string) { xx.MustSaveVarToFile(v, f) }
// MustSaveVarToWriter 将外部传入的valPtr,写入到writer中,类型为ct
func MustSaveVarToWriter(v interface{}, ct ConfigType, w io.Writer) {
xutil.PanicErr(xx.SaveVarToWriter(v, ct, w))
}
// MustSaveToBytes 将内置解析的数据以字节流返回,需指定ConfigType
func MustSaveToBytes(ct ConfigType) []byte { return xx.MustSaveToBytes(ct) }