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" "errors"
"os" "os"
"path/filepath" "path/filepath"
"strings"
"go.wit.com/log" "go.wit.com/log"
"google.golang.org/protobuf/encoding/protojson"
"google.golang.org/protobuf/encoding/prototext" "google.golang.org/protobuf/encoding/prototext"
"google.golang.org/protobuf/proto" "google.golang.org/protobuf/proto"
) )
@ -26,15 +28,35 @@ var ErrEmpty error = log.Errorf("file was empty")
// - []byte : the contents of the file // - []byte : the contents of the file
// - error on read // - error on read
func ConfigLoad(pb proto.Message, argname string, protoname string) error { func ConfigLoad(pb proto.Message, argname string, protoname string) error {
var data []byte
var fullname string var fullname string
homeDir, err := os.UserHomeDir() homeDir, err := os.UserHomeDir()
if err != nil { if err != nil {
log.Warn("ConfigLoad() UserHomeDir() err", err)
return err return err
} }
fullname = filepath.Join(homeDir, ".config", argname, protoname+".text") 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 { if data, err = loadFile(fullname); err != nil {
log.Warn("config file failed to load", err) log.Warn("config file failed to load", err)
// set pb.Filename that was attempted // 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() // don't even bother with Marshal()
if data == nil { if data == nil {
log.Warn("ConfigLoad() config file was empty", fullname)
return ErrEmpty // file is empty return ErrEmpty // file is empty
} }
// Unmarshal() // Unmarshal()
if err = prototext.Unmarshal(data, pb); err != nil { 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 return err
} }

32
save.go
View File

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