lots of fixes in gitpb

This commit is contained in:
Jeff Carr 2024-12-17 06:34:27 -06:00
parent 50cafc8517
commit 84c25d74da
3 changed files with 18 additions and 18 deletions

View File

@ -19,6 +19,8 @@ type args struct {
NoSort bool `arg:"--no-sort" help:"do not make a sort.pb.go file"`
Mutex bool `arg:"--mutex" help:"try mutex hack (breaks proto.Marshal()"`
DryRun bool `arg:"--dry-run" help:"show what would be run"`
GoSrc string `arg:"--go-src" help:"default is ~/go/src. could be set to your go.work path"`
GoPath string `arg:"--gopath" help:"the gopath of this repo"`
}
func (a args) Description() string {

24
main.go
View File

@ -11,7 +11,6 @@ import (
"github.com/alexflint/go-arg"
"github.com/go-cmd/cmd"
"go.wit.com/lib/gui/shell"
"go.wit.com/lib/protobuf/forgepb"
"go.wit.com/log"
"golang.org/x/text/cases"
"golang.org/x/text/language"
@ -22,7 +21,6 @@ var VERSION string
var BUILDTIME string
var sortmap map[string]string
var forge *forgepb.Forge // forgepb figures out how to run protoc correctly if it's needed
var marshalKeys []string
var uniqueKeys []string
@ -53,18 +51,17 @@ func main() {
os.Exit(-1)
}
// have to figure out how to run protoc so initialize forge
forge = forgepb.Init()
gosrc := forge.GetGoSrc()
pwd, _ := os.Getwd()
if strings.HasPrefix(pwd, gosrc) {
log.Info("does match", pwd, "vs", gosrc)
} else {
log.Info("does not match. should exit(-1) here", pwd, "vs", gosrc)
if argv.GoSrc == "" {
argv.GoSrc = "/home/jcarr/go/src"
}
if argv.GoPath == "" {
pwd, _ := os.Getwd()
argv.GoPath = strings.TrimPrefix(pwd, argv.GoSrc)
argv.GoPath = strings.Trim(argv.GoPath, "/")
}
log.Info(argv.GoSrc, argv.GoPath)
if !shell.Exists("go.sum") {
shell.RunQuiet([]string{"go", "mod", "init"})
shell.RunQuiet([]string{"go", "mod", "tidy"})
@ -73,7 +70,8 @@ func main() {
var result cmd.Status
var cmd []string
if forge.IsGoWork() {
// if forge.IsGoWork() {
if false {
cmd = []string{"go", "work", "use"}
result = shell.Run(cmd)
log.Info(strings.Join(result.Stdout, "\n"))

View File

@ -36,13 +36,13 @@ func protocBuild(names map[string]string) error {
// return nil
}
log.Info("make protoc file:", names["protoc"])
log.Info("go src", forge.GetGoSrc())
// log.Info("go src", forge.GetGoSrc())
pwd, _ := os.Getwd()
log.Info("go.Getwd()", pwd)
if !strings.HasPrefix(pwd, forge.GetGoSrc()) {
if !strings.HasPrefix(pwd, argv.GoSrc) {
return errors.New("paths don't match")
}
gopath := strings.TrimPrefix(pwd, forge.GetGoSrc())
gopath := strings.TrimPrefix(pwd, argv.GoSrc)
gopath = strings.Trim(gopath, "/")
log.Info("gopath", gopath)
cmd := []string{"protoc", "--go_out=."}
@ -84,10 +84,10 @@ func protocBuild(names map[string]string) error {
}
cmd = append(cmd, names["protofile"])
log.Info("\tpwd", forge.GetGoSrc())
log.Info("\tpwd", argv.GoSrc)
for i, s := range cmd {
log.Info("\t", i, s)
}
shell.PathRun(forge.GetGoSrc(), cmd)
shell.PathRun(argv.GoSrc, cmd)
return nil
}