Skip to content

Commit

Permalink
fix: cmd/protoc-gen-gclient: factor out captureInput
Browse files Browse the repository at this point in the history
Move logic for captureInput to a separate function and document it.
  • Loading branch information
julieqiu committed Nov 4, 2024
1 parent 382af5f commit 1d6ec84
Show file tree
Hide file tree
Showing 2 changed files with 36 additions and 30 deletions.
63 changes: 34 additions & 29 deletions generator/cmd/protoc-gen-gclient/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ import (
"flag"
"fmt"
"io"
"log"
"log/slog"
"os"
"slices"
Expand All @@ -37,18 +38,19 @@ func main() {
templateDir := flag.String("template-dir", "templates/", "the path to the template directory")
flag.Parse()

if err := run(*inputPath, *outDir, *templateDir); err != nil {
slog.Error(err.Error())
os.Exit(1)
if err := run(os.Stdin, os.Stdout, *inputPath, *outDir, *templateDir); err != nil {
log.Fatal(err)
}
slog.Info("Generation Completed Successfully")
}

func run(inputPath, outDir, templateDir string) error {
var reqBytes []byte
var err error
func run(r io.Reader, w io.Writer, inputPath, outDir, templateDir string) error {
var (
reqBytes []byte
err error
)
if inputPath == "" {
reqBytes, err = io.ReadAll(os.Stdin)
reqBytes, err = io.ReadAll(r)
if err != nil {
return err
}
Expand All @@ -63,31 +65,24 @@ func run(inputPath, outDir, templateDir string) error {
if err := proto.Unmarshal(reqBytes, genReq); err != nil {
return err
}

opts, err := parseOpts(genReq.GetParameter())
if err != nil {
return err
}

if opts.CaptureInput {
// Remove capture-input param from the captured input
ss := slices.DeleteFunc(strings.Split(genReq.GetParameter(), ","), func(s string) bool {
return strings.Contains(s, "capture-input")
})
genReq.Parameter = proto.String(strings.Join(ss, ","))
reqBytes, err = proto.Marshal(genReq)
if err != nil {
return err
}
if err := os.WriteFile(fmt.Sprintf("sample-input-%s.bin", time.Now().Format(time.RFC3339)), reqBytes, 0644); err != nil {
// If capture-input is set, content pass to protoc will be written to a
// sample-input-{timestamp}.bin file, so that protoc does not need to be
// used on future iterations.
if opts.captureInput {
if err := captureInput(genReq); err != nil {
return err
}
}

req, err := protobuf.NewTranslator(&protobuf.Options{
Request: genReq,
OutDir: outDir,
Language: opts.Language,
Language: opts.language,
TemplateDir: templateDir,
}).Translate()
if err != nil {
Expand All @@ -99,16 +94,13 @@ func run(inputPath, outDir, templateDir string) error {
if err != nil {
return err
}
if _, err := os.Stdout.Write(outBytes); err != nil {
return err
}

return nil
_, err = w.Write(outBytes)
return err
}

type protobufOptions struct {
CaptureInput bool
Language string
captureInput bool
language string
}

func parseOpts(optStr string) (*protobufOptions, error) {
Expand All @@ -130,12 +122,25 @@ func parseOpts(optStr string) (*protobufOptions, error) {
slog.Error("invalid bool in option string, skipping", "option", s)
return nil, err
}
opts.CaptureInput = b
opts.captureInput = b
case "language":
opts.Language = strings.ToLower(strings.TrimSpace(sp[1]))
opts.language = strings.ToLower(strings.TrimSpace(sp[1]))
default:
slog.Warn("unknown option", "option", s)
}
}
return opts, nil
}

func captureInput(genReq *pluginpb.CodeGeneratorRequest) error {
// Remove capture-input param from the captured input
ss := slices.DeleteFunc(strings.Split(genReq.GetParameter(), ","), func(s string) bool {
return strings.Contains(s, "capture-input")
})
genReq.Parameter = proto.String(strings.Join(ss, ","))
reqBytes, err := proto.Marshal(genReq)
if err != nil {
return err
}
return os.WriteFile(fmt.Sprintf("sample-input-%s.bin", time.Now().Format(time.RFC3339)), reqBytes, 0644)
}
3 changes: 2 additions & 1 deletion generator/cmd/protoc-gen-gclient/main_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,8 @@ func TestMain(m *testing.M) {
}

func TestRun_Rust(t *testing.T) {
if err := run("testdata/rust/rust.bin", "testdata/rust/golden", "../../templates"); err != nil {
tDir := t.TempDir()
if err := run(os.Stdin, os.Stdout, "testdata/rust/rust.bin", tDir, "../../templates"); err != nil {
t.Fatal(err)
}
}

0 comments on commit 1d6ec84

Please sign in to comment.