From 0bbe77b80300f6b34135f39b95a0e32d69d4c679 Mon Sep 17 00:00:00 2001 From: Uwe Dauernheim Date: Wed, 12 Oct 2022 19:51:58 +0200 Subject: [PATCH] Only generate moq when interface file is newer than output file --- main.go | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/main.go b/main.go index 37c3937..942e5c1 100644 --- a/main.go +++ b/main.go @@ -23,6 +23,7 @@ type userFlags struct { stubImpl bool skipEnsure bool remove bool + force bool args []string } @@ -37,6 +38,7 @@ func main() { flag.BoolVar(&flags.skipEnsure, "skip-ensure", false, "suppress mock implementation check, avoid import cycle if mocks generated outside of the tested package") flag.BoolVar(&flags.remove, "rm", false, "first remove output file, if it exists") + flag.BoolVar(&flags.force, "force", false, "force generation, otherwise check if go generate file is newer than output file") flag.Usage = func() { fmt.Println(`moq [flags] source-dir interface [interface2 [interface3 [...]]]`) @@ -65,6 +67,17 @@ func run(flags userFlags) error { return errors.New("not enough arguments") } + if !flags.force && flags.outFile != "" { + inFile := os.Getenv("GOFILE") + if inStat, err := os.Stat(inFile); err != nil { + fmt.Fprintln(os.Stderr, err) + } else if outStat, err := os.Stat(flags.outFile); err != nil && !errors.Is(err, os.ErrNotExist) { + fmt.Fprintln(os.Stderr, err) + } else if !inStat.ModTime().After(outStat.ModTime()) { + return nil // Assume no changes thus no need to regenerate. + } + } + if flags.remove && flags.outFile != "" { if err := os.Remove(flags.outFile); err != nil { if !errors.Is(err, os.ErrNotExist) {