2024-11-30 12:17:38 -06:00
|
|
|
package main
|
|
|
|
|
|
|
|
// auto run protoc with the correct args
|
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
2024-12-18 02:54:14 -06:00
|
|
|
"fmt"
|
2024-11-30 12:17:38 -06:00
|
|
|
"os"
|
2024-11-30 13:48:50 -06:00
|
|
|
"path/filepath"
|
2024-11-30 12:44:04 -06:00
|
|
|
"strings"
|
2024-11-30 12:17:38 -06:00
|
|
|
|
2024-12-18 02:54:14 -06:00
|
|
|
"github.com/go-cmd/cmd"
|
2024-11-30 12:17:38 -06:00
|
|
|
"go.wit.com/lib/gui/shell"
|
|
|
|
"go.wit.com/log"
|
|
|
|
)
|
|
|
|
|
|
|
|
// test.pb.go: test.proto
|
|
|
|
// cd ~/go/src && protoc --go_out=. --proto_path=go.wit.com/apps/autogenpb/testautogen \
|
|
|
|
// --go_opt=Mtest.proto=go.wit.com/apps/autogenpb/testautogen \
|
|
|
|
// test.proto
|
|
|
|
|
|
|
|
// forgeConfig.pb.go: forgeConfig.proto
|
|
|
|
// cd ~/go/src && protoc --go_out=. --proto_path=go.wit.com/apps/autogenpb/testautogen \
|
|
|
|
// --go_opt=MforgeConfig.proto=go.wit.com/apps/autogenpb/testautogen \
|
|
|
|
// forgeConfig.proto
|
|
|
|
|
|
|
|
func protocBuild(names map[string]string) error {
|
2024-11-30 13:48:50 -06:00
|
|
|
// read in the .proto file
|
|
|
|
data, err := os.ReadFile(names["protofile"])
|
|
|
|
if err != nil {
|
|
|
|
// log.Info("open config file :", err)
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2024-11-30 12:17:38 -06:00
|
|
|
log.Info("")
|
|
|
|
if shell.Exists(names["protoc"]) {
|
|
|
|
log.Info("protoc file already created", names["protoc"])
|
2024-11-30 13:48:50 -06:00
|
|
|
// return nil
|
2024-11-30 12:17:38 -06:00
|
|
|
}
|
|
|
|
log.Info("make protoc file:", names["protoc"])
|
2024-12-17 06:34:27 -06:00
|
|
|
// log.Info("go src", forge.GetGoSrc())
|
2024-11-30 12:44:04 -06:00
|
|
|
pwd, _ := os.Getwd()
|
|
|
|
log.Info("go.Getwd()", pwd)
|
2024-12-17 06:34:27 -06:00
|
|
|
if !strings.HasPrefix(pwd, argv.GoSrc) {
|
2025-01-08 19:45:48 -06:00
|
|
|
log.Info("are you building using a go.work file? If so,")
|
|
|
|
log.Info("your paths will not match because the default")
|
|
|
|
log.Info("is to use ~/go/src so you have to specify")
|
|
|
|
log.Info("where your path is with --go-src")
|
|
|
|
log.Info("todo: use forgepb to figure this out")
|
2024-11-30 12:44:04 -06:00
|
|
|
return errors.New("paths don't match")
|
|
|
|
}
|
2024-12-17 06:34:27 -06:00
|
|
|
gopath := strings.TrimPrefix(pwd, argv.GoSrc)
|
2024-11-30 13:48:50 -06:00
|
|
|
gopath = strings.Trim(gopath, "/")
|
2024-11-30 12:44:04 -06:00
|
|
|
log.Info("gopath", gopath)
|
2024-11-30 13:48:50 -06:00
|
|
|
cmd := []string{"protoc", "--go_out=."}
|
|
|
|
cmd = append(cmd, "--proto_path="+gopath)
|
|
|
|
cmd = append(cmd, "--go_opt=M"+names["protofile"]+"="+gopath)
|
2024-11-30 12:44:04 -06:00
|
|
|
|
2024-11-30 13:48:50 -06:00
|
|
|
// look for included proto files
|
2024-11-30 12:44:04 -06:00
|
|
|
lines := strings.Split(string(data), "\n")
|
|
|
|
for _, line := range lines {
|
|
|
|
// log.Info("line:", line)
|
2024-11-30 13:48:50 -06:00
|
|
|
if strings.HasPrefix(line, "import ") {
|
|
|
|
parts := strings.Split(line, "\"")
|
|
|
|
protofile := parts[1]
|
|
|
|
if shell.Exists(protofile) {
|
|
|
|
log.Info("adding import", protofile)
|
|
|
|
cmd = append(cmd, "--go_opt=M"+protofile+"="+gopath)
|
|
|
|
} else {
|
|
|
|
basepath, pname := filepath.Split(protofile)
|
|
|
|
if basepath == "" {
|
|
|
|
log.Warn("import line:", line, "missing proto file:", pname)
|
|
|
|
log.Warn("protoc will probably fail here")
|
|
|
|
} else {
|
|
|
|
log.Warn("need to check basepath here", basepath, pname)
|
|
|
|
}
|
|
|
|
}
|
2024-11-30 12:17:38 -06:00
|
|
|
}
|
2024-11-30 13:48:50 -06:00
|
|
|
/*
|
|
|
|
start := "type " + names["Bases"] + " struct {"
|
|
|
|
if strings.HasSuffix(line, start) {
|
|
|
|
found = true
|
|
|
|
log.Info("FOUND line:", line)
|
|
|
|
fmt.Fprintln(w, line)
|
|
|
|
fmt.Fprintln(w, "\tsync.RWMutex // auto-added by go.wit.com/apps/autogenpb")
|
|
|
|
fmt.Fprintln(w, "")
|
|
|
|
} else {
|
|
|
|
fmt.Fprintln(w, line)
|
|
|
|
}
|
|
|
|
*/
|
2024-11-30 12:44:04 -06:00
|
|
|
}
|
2024-11-30 13:48:50 -06:00
|
|
|
|
|
|
|
cmd = append(cmd, names["protofile"])
|
2024-12-17 06:34:27 -06:00
|
|
|
log.Info("\tpwd", argv.GoSrc)
|
2024-11-30 13:48:50 -06:00
|
|
|
for i, s := range cmd {
|
|
|
|
log.Info("\t", i, s)
|
2024-11-30 12:44:04 -06:00
|
|
|
}
|
2024-12-18 02:54:14 -06:00
|
|
|
return runprotoc(argv.GoSrc, cmd)
|
|
|
|
}
|
|
|
|
|
|
|
|
func runprotoc(pwd string, mycmd []string) error {
|
|
|
|
result := shell.PathRun(argv.GoSrc, mycmd)
|
|
|
|
if result.Error != nil {
|
|
|
|
return userNotes(result)
|
|
|
|
}
|
|
|
|
if result.Exit != 0 {
|
|
|
|
return userNotes(result)
|
|
|
|
}
|
2024-11-30 13:48:50 -06:00
|
|
|
return nil
|
|
|
|
}
|
2024-12-18 02:54:14 -06:00
|
|
|
|
|
|
|
func userNotes(result cmd.Status) error {
|
|
|
|
log.Info("protoc failed", result.Cmd, "with", result.Exit)
|
|
|
|
for _, line := range result.Stdout {
|
|
|
|
log.Info("STDOUT:", line)
|
|
|
|
}
|
|
|
|
for _, line := range result.Stderr {
|
|
|
|
log.Info("STDERR:", line)
|
|
|
|
}
|
|
|
|
log.Info("This is likely because you don't have protoc and protoc-gen-go installed")
|
|
|
|
log.Info("")
|
|
|
|
log.Info("On debian, you can:")
|
|
|
|
log.Info(" apt install protobuf-compiler # for protoc")
|
|
|
|
log.Info(" apt install protoc-gen-go # for protoc-gen-go")
|
|
|
|
log.Info("")
|
|
|
|
return fmt.Errorf("protoc failed with %d %v", result.Exit, result.Error)
|
|
|
|
}
|