[#12] Optimize field encoding a bit
No need to clone a map if it is empty. Signed-off-by: Evgenii Stratonikov <e.stratonikov@yadro.com>
This commit is contained in:
parent
f358e67c81
commit
2b6d84de9a
2 changed files with 19 additions and 13 deletions
12
encoder.go
12
encoder.go
|
@ -2,6 +2,7 @@ package zapjournald
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
|
"fmt"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"go.uber.org/zap/buffer"
|
"go.uber.org/zap/buffer"
|
||||||
|
@ -9,6 +10,17 @@ import (
|
||||||
|
|
||||||
var pool = buffer.NewPool()
|
var pool = buffer.NewPool()
|
||||||
|
|
||||||
|
func encodeJournaldField(buf *buffer.Buffer, key string, value any) {
|
||||||
|
switch v := value.(type) {
|
||||||
|
case string:
|
||||||
|
writeField(buf, key, v)
|
||||||
|
case []byte:
|
||||||
|
writeFieldBytes(buf, key, v)
|
||||||
|
default:
|
||||||
|
writeField(buf, key, fmt.Sprint(v))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func writeFieldBytes(buf *buffer.Buffer, name string, value []byte) {
|
func writeFieldBytes(buf *buffer.Buffer, name string, value []byte) {
|
||||||
buf.Write([]byte(name))
|
buf.Write([]byte(name))
|
||||||
if bytes.ContainsRune(value, '\n') {
|
if bytes.ContainsRune(value, '\n') {
|
||||||
|
|
|
@ -78,21 +78,15 @@ func (core *Core) Write(entry zapcore.Entry, fields []zapcore.Field) error {
|
||||||
|
|
||||||
writeField(b, "PRIORITY", strconv.Itoa(int(prio)))
|
writeField(b, "PRIORITY", strconv.Itoa(int(prio)))
|
||||||
|
|
||||||
structuredFields := maps.Clone(core.contextStructuredFields)
|
if len(core.contextStructuredFields) != 0 {
|
||||||
|
for k, v := range core.contextStructuredFields {
|
||||||
|
encodeJournaldField(b, k, v)
|
||||||
|
}
|
||||||
for _, field := range fields {
|
for _, field := range fields {
|
||||||
if _, isJournalField := core.storedFieldNames[field.Key]; isJournalField {
|
if _, isJournalField := core.storedFieldNames[field.Key]; isJournalField {
|
||||||
structuredFields[field.Key] = getFieldValue(field)
|
encodeJournaldField(b, field.Key, getFieldValue(field))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
for k, v := range structuredFields {
|
|
||||||
switch v := v.(type) {
|
|
||||||
case []byte:
|
|
||||||
writeFieldBytes(b, k, v)
|
|
||||||
case string:
|
|
||||||
writeField(b, k, v)
|
|
||||||
default:
|
|
||||||
writeField(b, k, fmt.Sprint(v))
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Generate the message.
|
// Generate the message.
|
||||||
|
|
Loading…
Reference in a new issue