♻️ Add tools.WriteValue
This commit is contained in:
parent
fd5d315164
commit
286ac4557d
4 changed files with 97 additions and 31 deletions
|
|
@ -2,12 +2,9 @@ package models
|
|||
|
||||
import (
|
||||
"bytes"
|
||||
"encoding/json"
|
||||
"errors"
|
||||
"fmt"
|
||||
"regexp"
|
||||
"strconv"
|
||||
"time"
|
||||
|
||||
"codeberg.org/danjones000/my-log/tools"
|
||||
)
|
||||
|
|
@ -25,33 +22,9 @@ func (m Meta) MarshalText() ([]byte, error) {
|
|||
buff.WriteRune('@')
|
||||
buff.WriteString(m.Key)
|
||||
buff.WriteRune(' ')
|
||||
switch v := m.Value.(type) {
|
||||
default:
|
||||
return nil, fmt.Errorf("Unknown type %T", v)
|
||||
case nil:
|
||||
return []byte{}, nil
|
||||
case string:
|
||||
buff.WriteString(v)
|
||||
case int:
|
||||
buff.WriteString(strconv.Itoa(v))
|
||||
case int64:
|
||||
buff.WriteString(strconv.FormatInt(v, 10))
|
||||
case float64:
|
||||
buff.WriteString(strconv.FormatFloat(v, 'f', -1, 64))
|
||||
case json.Number:
|
||||
buff.WriteString(v.String())
|
||||
case json.RawMessage:
|
||||
buff.Write(v)
|
||||
case []byte:
|
||||
buff.Write(v)
|
||||
case byte:
|
||||
buff.WriteByte(v)
|
||||
case rune:
|
||||
buff.WriteString(string(v))
|
||||
case bool:
|
||||
buff.WriteString(strconv.FormatBool(v))
|
||||
case time.Time:
|
||||
buff.WriteString(v.Format(time.RFC3339))
|
||||
n, err := tools.WriteValue(buff, m.Value)
|
||||
if n == 0 || err != nil {
|
||||
return []byte{}, err
|
||||
}
|
||||
|
||||
return buff.Bytes(), nil
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue