Build Output File Select
This commit is contained in:
parent
aff454c277
commit
853fda9814
39
main.go
39
main.go
@ -2,6 +2,8 @@ package main
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
|
"flag"
|
||||||
|
"fmt"
|
||||||
"log"
|
"log"
|
||||||
"os"
|
"os"
|
||||||
|
|
||||||
@ -14,7 +16,12 @@ import (
|
|||||||
var appConfig = koanf.New(".")
|
var appConfig = koanf.New(".")
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
if err := appConfig.Load(file.Provider("testdata/conf.yaml"), yaml.Parser()); err != nil {
|
confPath := flag.String("c", "testdata/conf.yaml", "Config File")
|
||||||
|
outFileName := flag.String("o", "", "Name of the Output File")
|
||||||
|
|
||||||
|
flag.Parse()
|
||||||
|
|
||||||
|
if err := appConfig.Load(file.Provider(*confPath), yaml.Parser()); err != nil {
|
||||||
log.Printf("error loading config: %v", err)
|
log.Printf("error loading config: %v", err)
|
||||||
} else {
|
} else {
|
||||||
log.Printf("CONF: %v", appConfig)
|
log.Printf("CONF: %v", appConfig)
|
||||||
@ -24,17 +31,43 @@ func main() {
|
|||||||
var cfg proto.Proto
|
var cfg proto.Proto
|
||||||
json.Unmarshal(file, &cfg)
|
json.Unmarshal(file, &cfg)
|
||||||
|
|
||||||
|
// if outFileName is set use it, if is not set set it to default value
|
||||||
|
if *outFileName != "" {
|
||||||
|
cfg.FileName = *outFileName
|
||||||
|
} else {
|
||||||
|
*outFileName = "proto"
|
||||||
|
}
|
||||||
|
|
||||||
|
// If filename not set in json take it from cli or default
|
||||||
|
if cfg.FileName != "" {
|
||||||
|
cfg.FileName = *outFileName
|
||||||
|
}
|
||||||
|
|
||||||
proto.InitTemplates()
|
proto.InitTemplates()
|
||||||
|
|
||||||
header, err := proto.CreateCStyleHeader(&cfg)
|
header, err := proto.CreateCStyleHeader(&cfg)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Printf("ERROR: %v", err)
|
log.Printf("ERROR: %v", err)
|
||||||
}
|
}
|
||||||
log.Printf("TEMPLATE HEADER: \n%v", header)
|
err = os.MkdirAll("build", 0755)
|
||||||
|
if err != nil {
|
||||||
|
log.Printf("ERROR: %v", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
err = os.WriteFile(fmt.Sprintf("build/%s.h", *outFileName), []byte(header), 0666)
|
||||||
|
if err != nil {
|
||||||
|
log.Printf("ERROR: %v", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
source, err := proto.CreateCStyleSource(&cfg)
|
source, err := proto.CreateCStyleSource(&cfg)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Printf("ERROR: %v", err)
|
log.Printf("ERROR: %v", err)
|
||||||
}
|
}
|
||||||
log.Printf("TEMPLATE SOURCE: \n%v", source)
|
err = os.WriteFile(fmt.Sprintf("build/%s.c", *outFileName), []byte(source), 0666)
|
||||||
|
if err != nil {
|
||||||
|
log.Printf("ERROR: %v", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -34,6 +34,7 @@ type Proto struct {
|
|||||||
ProtocolHeader ProtocolHeader `json:"protocol"`
|
ProtocolHeader ProtocolHeader `json:"protocol"`
|
||||||
ESP_TO_PC []ProtoMessage `json:"messages_esp_to_pc"`
|
ESP_TO_PC []ProtoMessage `json:"messages_esp_to_pc"`
|
||||||
PC_TO_ESP []ProtoMessage `json:"messages_pc_to_esp"`
|
PC_TO_ESP []ProtoMessage `json:"messages_pc_to_esp"`
|
||||||
|
FileName string `json:"filename,omitempty"`
|
||||||
}
|
}
|
||||||
|
|
||||||
func (h *HexByte) UnmarshalJSON(data []byte) error {
|
func (h *HexByte) UnmarshalJSON(data []byte) error {
|
||||||
@ -62,6 +63,7 @@ type PayloadStruct struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
type CStyleData struct {
|
type CStyleData struct {
|
||||||
|
FileName string
|
||||||
CenumPCTOESP Cenum
|
CenumPCTOESP Cenum
|
||||||
CenumESPTOPC Cenum
|
CenumESPTOPC Cenum
|
||||||
PayloadStructs []PayloadStruct
|
PayloadStructs []PayloadStruct
|
||||||
@ -105,6 +107,7 @@ func CreateCStyleHeader(proto *Proto) (string, error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
var data = CStyleData{
|
var data = CStyleData{
|
||||||
|
FileName: proto.FileName,
|
||||||
CenumPCTOESP: Cenum{
|
CenumPCTOESP: Cenum{
|
||||||
EnumName: "PC_TO_ESP_MESSAGE_IDS",
|
EnumName: "PC_TO_ESP_MESSAGE_IDS",
|
||||||
Entries: proto.PC_TO_ESP,
|
Entries: proto.PC_TO_ESP,
|
||||||
@ -148,6 +151,7 @@ func CreateCStyleSource(proto *Proto) (string, error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
var data = CStyleData{
|
var data = CStyleData{
|
||||||
|
FileName: proto.FileName,
|
||||||
CenumPCTOESP: Cenum{
|
CenumPCTOESP: Cenum{
|
||||||
EnumName: "PC_TO_ESP_MESSAGE_IDS",
|
EnumName: "PC_TO_ESP_MESSAGE_IDS",
|
||||||
Entries: proto.PC_TO_ESP,
|
Entries: proto.PC_TO_ESP,
|
||||||
|
|||||||
@ -1,7 +1,7 @@
|
|||||||
{{- define "cpartSource" -}}
|
{{- define "cpartSource" -}}
|
||||||
// AUTO GENERATED DO NOT EDIT!!!
|
// AUTO GENERATED DO NOT EDIT!!!
|
||||||
|
|
||||||
#include "uart_prot.h"
|
#include "{{.FileName}}.h"
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
// Message Dispatcher
|
// Message Dispatcher
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user