Merge pull request '新增序列化能力' (#2) from feature/support_toml_ini into master
Reviewed-on: #2
This commit is contained in:
commit
135850ee8a
67
ini.go
Normal file
67
ini.go
Normal file
@ -0,0 +1,67 @@
|
|||||||
|
// Package serialize ...
|
||||||
|
//
|
||||||
|
// Description : serialize ...
|
||||||
|
//
|
||||||
|
// Author : go_developer@163.com<白茶清欢>
|
||||||
|
//
|
||||||
|
// Date : 2025-04-28 11:32
|
||||||
|
package serialize
|
||||||
|
|
||||||
|
import (
|
||||||
|
"errors"
|
||||||
|
"github.com/go-ini/ini"
|
||||||
|
"io"
|
||||||
|
)
|
||||||
|
|
||||||
|
var (
|
||||||
|
Ini = &ownIni{}
|
||||||
|
)
|
||||||
|
|
||||||
|
type ownIni struct {
|
||||||
|
}
|
||||||
|
|
||||||
|
func (o *ownIni) UnmarshalWithNumber(byteData []byte, receiver any) error {
|
||||||
|
if nil == receiver {
|
||||||
|
return errors.New("receiver is nil")
|
||||||
|
}
|
||||||
|
return ini.MapTo(receiver, byteData)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (o *ownIni) UnmarshalWithNumberIgnoreError(byteData []byte, receiver any) {
|
||||||
|
_ = o.UnmarshalWithNumber(byteData, receiver)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (o *ownIni) UnmarshalWithNumberForIOReader(ioReader io.ReadCloser, receiver any) error {
|
||||||
|
if nil == receiver {
|
||||||
|
return errors.New("receiver is nil")
|
||||||
|
}
|
||||||
|
return ini.MapTo(receiver, ioReader)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (o *ownIni) UnmarshalWithNumberForIOReaderIgnoreError(ioReader io.ReadCloser, receiver any) {
|
||||||
|
_ = o.UnmarshalWithNumberForIOReader(ioReader, receiver)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (o *ownIni) UnmarshalWithNumberForString(input string, receiver any) error {
|
||||||
|
return o.UnmarshalWithNumber([]byte(input), receiver)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (o *ownIni) UnmarshalWithNumberForStringIgnoreError(input string, receiver any) {
|
||||||
|
_ = o.UnmarshalWithNumberForString(input, receiver)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (o *ownIni) MarshalForByte(input any) ([]byte, error) {
|
||||||
|
return JSON.MarshalForByte(input)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (o *ownIni) MarshalForByteIgnoreError(input any) []byte {
|
||||||
|
return JSON.MarshalForByteIgnoreError(input)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (o *ownIni) MarshalForString(input any) (string, error) {
|
||||||
|
return JSON.MarshalForString(input)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (o *ownIni) MarshalForStringIgnoreError(input any) string {
|
||||||
|
return JSON.MarshalForStringIgnoreError(input)
|
||||||
|
}
|
93
toml.go
Normal file
93
toml.go
Normal file
@ -0,0 +1,93 @@
|
|||||||
|
// Package serialize ...
|
||||||
|
//
|
||||||
|
// Description : serialize ...
|
||||||
|
//
|
||||||
|
// Author : go_developer@163.com<白茶清欢>
|
||||||
|
//
|
||||||
|
// Date : 2025-04-28 10:57
|
||||||
|
package serialize
|
||||||
|
|
||||||
|
import (
|
||||||
|
"bytes"
|
||||||
|
"errors"
|
||||||
|
"github.com/BurntSushi/toml"
|
||||||
|
"io"
|
||||||
|
)
|
||||||
|
|
||||||
|
var (
|
||||||
|
Toml = &ownToml{}
|
||||||
|
)
|
||||||
|
|
||||||
|
type ownToml struct {
|
||||||
|
}
|
||||||
|
|
||||||
|
func (o *ownToml) Parse(byteData []byte, receiver any) (*toml.MetaData, error) {
|
||||||
|
if nil == receiver {
|
||||||
|
return nil, errors.New("receiver is nil")
|
||||||
|
}
|
||||||
|
decoder := toml.NewDecoder(bytes.NewReader(byteData))
|
||||||
|
if res, err := decoder.Decode(receiver); nil != err {
|
||||||
|
return nil, err
|
||||||
|
} else {
|
||||||
|
return &res, nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (o *ownToml) UnmarshalWithNumber(byteData []byte, receiver any) error {
|
||||||
|
if _, err := o.Parse(byteData, receiver); nil != err {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (o *ownToml) UnmarshalWithNumberIgnoreError(byteData []byte, receiver any) {
|
||||||
|
_ = o.UnmarshalWithNumber(byteData, receiver)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (o *ownToml) UnmarshalWithNumberForIOReader(ioReader io.ReadCloser, receiver any) error {
|
||||||
|
decoder := toml.NewDecoder(ioReader)
|
||||||
|
if _, err := decoder.Decode(receiver); nil != err {
|
||||||
|
return err
|
||||||
|
} else {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (o *ownToml) UnmarshalWithNumberForIOReaderIgnoreError(ioReader io.ReadCloser, receiver any) {
|
||||||
|
_ = o.UnmarshalWithNumberForIOReader(ioReader, receiver)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (o *ownToml) UnmarshalWithNumberForString(input string, receiver any) error {
|
||||||
|
return o.UnmarshalWithNumber([]byte(input), receiver)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (o *ownToml) UnmarshalWithNumberForStringIgnoreError(input string, receiver any) {
|
||||||
|
o.UnmarshalWithNumberIgnoreError([]byte(input), receiver)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (o *ownToml) MarshalForByte(input any) ([]byte, error) {
|
||||||
|
b := &bytes.Buffer{}
|
||||||
|
encoder := toml.NewEncoder(b)
|
||||||
|
if err := encoder.Encode(input); nil != err {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return b.Bytes(), nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (o *ownToml) MarshalForByteIgnoreError(input any) []byte {
|
||||||
|
res, _ := o.MarshalForByte(input)
|
||||||
|
return res
|
||||||
|
}
|
||||||
|
|
||||||
|
func (o *ownToml) MarshalForString(input any) (string, error) {
|
||||||
|
res, err := o.MarshalForByte(input)
|
||||||
|
if nil != err {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
return string(res), nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (o *ownToml) MarshalForStringIgnoreError(input any) string {
|
||||||
|
res, _ := o.MarshalForString(input)
|
||||||
|
return res
|
||||||
|
}
|
76
wrapper.go
Normal file
76
wrapper.go
Normal file
@ -0,0 +1,76 @@
|
|||||||
|
// Package serialize ...
|
||||||
|
//
|
||||||
|
// Description : serialize ...
|
||||||
|
//
|
||||||
|
// Author : go_developer@163.com<白茶清欢>
|
||||||
|
//
|
||||||
|
// Date : 2025-04-28 11:58
|
||||||
|
package serialize
|
||||||
|
|
||||||
|
import (
|
||||||
|
"errors"
|
||||||
|
"git.zhangdeman.cn/zhangdeman/serialize/abstract"
|
||||||
|
"sync"
|
||||||
|
)
|
||||||
|
|
||||||
|
var (
|
||||||
|
Wrapper = &wrapper{
|
||||||
|
serializableTable: map[string]abstract.Serializable{
|
||||||
|
"xml": Xml,
|
||||||
|
"yml": Yml,
|
||||||
|
"yaml": Yml,
|
||||||
|
"toml": Toml,
|
||||||
|
"ini": Ini,
|
||||||
|
"json": JSON,
|
||||||
|
},
|
||||||
|
l: &sync.RWMutex{},
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
type wrapper struct {
|
||||||
|
serializableTable map[string]abstract.Serializable
|
||||||
|
l *sync.RWMutex
|
||||||
|
}
|
||||||
|
|
||||||
|
// GetSerializable ...
|
||||||
|
func (w *wrapper) GetSerializable(t string) (abstract.Serializable, error) {
|
||||||
|
w.l.RLock()
|
||||||
|
if _, exist := w.serializableTable[t]; !exist {
|
||||||
|
w.l.RUnlock()
|
||||||
|
return nil, errors.New(t + ": is not support")
|
||||||
|
}
|
||||||
|
serializable := w.serializableTable[t]
|
||||||
|
w.l.RUnlock()
|
||||||
|
if nil == serializable {
|
||||||
|
return nil, errors.New("serializable is nil")
|
||||||
|
}
|
||||||
|
return serializable, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// SetSerializable 设置序列化实现, 已存在会覆盖
|
||||||
|
func (w *wrapper) SetSerializable(t string, serializable abstract.Serializable) {
|
||||||
|
if nil == serializable {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
w.l.Lock()
|
||||||
|
defer w.l.Unlock()
|
||||||
|
w.serializableTable[t] = serializable
|
||||||
|
}
|
||||||
|
|
||||||
|
// Marshal 序列化
|
||||||
|
func (w *wrapper) Marshal(marshalType string, input any) ([]byte, error) {
|
||||||
|
serializable, err := w.GetSerializable(marshalType)
|
||||||
|
if nil != err {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return serializable.MarshalForByte(input)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Unmarshal 反序列化
|
||||||
|
func (w *wrapper) Unmarshal(unmarshalType string, input []byte, receiver any) error {
|
||||||
|
serializable, err := w.GetSerializable(unmarshalType)
|
||||||
|
if nil != err {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
return serializable.UnmarshalWithNumber(input, receiver)
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user