also save JSON files since protoTEXT() is unstable still

This commit is contained in:
Jeff Carr 2025-09-11 07:54:03 -05:00
parent 68f0c43da6
commit d158e4cb11
2 changed files with 90 additions and 5 deletions

63
load.go
View File

@ -7,8 +7,10 @@ import (
"errors"
"os"
"path/filepath"
"strings"
"go.wit.com/log"
"google.golang.org/protobuf/encoding/protojson"
"google.golang.org/protobuf/encoding/prototext"
"google.golang.org/protobuf/proto"
)
@ -26,15 +28,35 @@ var ErrEmpty error = log.Errorf("file was empty")
// - []byte : the contents of the file
// - error on read
func ConfigLoad(pb proto.Message, argname string, protoname string) error {
var data []byte
var fullname string
homeDir, err := os.UserHomeDir()
if err != nil {
log.Warn("ConfigLoad() UserHomeDir() err", err)
return err
}
fullname = filepath.Join(homeDir, ".config", argname, protoname+".text")
if err := loadTEXT(pb, fullname); err == nil {
return nil
}
if strings.HasSuffix(fullname, ".text") {
fullname = strings.TrimSuffix(fullname, ".text")
fullname += ".json"
if err := loadJSON(pb, fullname); err != nil {
return err
}
return nil
}
log.Info("Config file load failed:", fullname)
return log.Errorf("could not load config file")
}
func loadTEXT(pb proto.Message, fullname string) error {
var data []byte
var err error
if data, err = loadFile(fullname); err != nil {
log.Warn("config file failed to load", err)
// set pb.Filename that was attempted
@ -44,11 +66,50 @@ func ConfigLoad(pb proto.Message, argname string, protoname string) error {
// don't even bother with Marshal()
if data == nil {
log.Warn("ConfigLoad() config file was empty", fullname)
return ErrEmpty // file is empty
}
// Unmarshal()
if err = prototext.Unmarshal(data, pb); err != nil {
log.Warn("ConfigLoad() file", fullname)
log.Warn("ConfigLoad() Unmarshal() err", err)
return err
}
if fn, ok := GetFilename(pb); ok {
if fn != fullname {
log.Info("config.ConfigLoad() new filename:", fullname)
SetFilename(pb, fullname)
}
}
if os.Getenv("CONFIG_VERBOSE") == "true" {
log.Infof("ConfigLoad() %s len()=%d\n", fullname, len(data))
}
return nil
}
func loadJSON(pb proto.Message, fullname string) error {
var data []byte
var err error
if data, err = loadFile(fullname); err != nil {
log.Warn("config file failed to load", err)
// set pb.Filename that was attempted
SetFilename(pb, fullname)
return err
}
// don't even bother with Marshal()
if data == nil {
log.Warn("ConfigLoad() config file was empty", fullname)
return ErrEmpty // file is empty
}
// Unmarshal()
if err = protojson.Unmarshal(data, pb); err != nil {
log.Warn("ConfigLoad() file", fullname)
log.Warn("ConfigLoad() Unmarshal() err", err)
return err
}

32
save.go
View File

@ -4,8 +4,10 @@ import (
"fmt"
"os"
"path/filepath"
"strings"
"go.wit.com/log"
"google.golang.org/protobuf/encoding/protojson"
"google.golang.org/protobuf/encoding/prototext"
"google.golang.org/protobuf/proto"
)
@ -41,21 +43,43 @@ func ConfigSaveWithHeader(pb proto.Message, header string) error {
return ErrProtoFilename
}
s := prototext.Format(pb)
dir, name := filepath.Split(fullname)
if name == "" {
return fmt.Errorf("filename was blank")
}
err := os.MkdirAll(dir, os.ModePerm)
if err != nil {
if err := os.MkdirAll(dir, os.ModePerm); err != nil {
return err
}
var final error
if err := configTEXT(fullname, pb, header); err != nil {
final = err
}
if strings.HasSuffix(fullname, ".text") {
fullname = strings.TrimSuffix(fullname, ".text")
fullname += ".json"
if err := configJSON(fullname, pb); err != nil {
final = err
}
}
return final
}
func configTEXT(fullname string, pb proto.Message, header string) error {
s := prototext.Format(pb)
log.Infof("ConfigSave() filename=%s %d\n", fullname, len(s))
return configWrite(fullname, []byte(header+s))
}
func configJSON(fullname string, pb proto.Message) error {
data := protojson.Format(pb)
log.Infof("ConfigSave() filename=%s %d\n", fullname, len(data))
return configWrite(fullname, []byte(data))
}
func configWrite(fullname string, data []byte) error {
cfgfile, err := os.OpenFile(fullname, os.O_RDWR|os.O_CREATE|os.O_TRUNC, 0644)