From d7b8b5ebe4093e36bff42bdb13d209e54bef984e Mon Sep 17 00:00:00 2001 From: Stephen Kitt Date: Mon, 9 Oct 2023 06:14:14 -0400 Subject: [PATCH] Provide a flag to control generation of the invocation comment The invocation comment stores the complete details of all provided arguments, which may include paths to files. These aren't always consistent, which results in unwanted changes in the generated files (especially for CI checking for unexpected changes...). Since the invocation isn't always useful, provide a flag to control whether the comment is generated. To preserve current behaviour this defaults to true (enabled). Signed-off-by: Stephen Kitt --- mockgen/mockgen.go | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) diff --git a/mockgen/mockgen.go b/mockgen/mockgen.go index feb747f..02c5bc5 100644 --- a/mockgen/mockgen.go +++ b/mockgen/mockgen.go @@ -59,6 +59,7 @@ var ( packageOut = flag.String("package", "", "Package of the generated code; defaults to the package of the input with a 'mock_' prefix.") selfPackage = flag.String("self_package", "", "The full package import path for the generated code. The purpose of this flag is to prevent import cycles in the generated code by trying to include its own package. This can happen if the mock's package is set to one of its inputs (usually the main one) and the output is stdio so mockgen cannot detect the final output package. Setting this flag will then tell mockgen which import to exclude.") writePkgComment = flag.Bool("write_package_comment", true, "Writes package documentation comment (godoc) if true.") + writeInvocationComment = flag.Bool("write_invocation_comment", true, "Writes the invocation used to generate the file in a comment if true.") writeSourceComment = flag.Bool("write_source_comment", true, "Writes original file (source mode) or interface names (reflect mode) comment if true.") writeGenerateDirective = flag.Bool("write_generate_directive", false, "Add //go:generate directive to regenerate the mock") copyrightFile = flag.String("copyright_file", "", "Copyright file used to add copyright header") @@ -312,10 +313,12 @@ func (g *generator) Generate(pkg *model.Package, outputPkgName string, outputPac g.p("// Source: %v (interfaces: %v)", g.srcPackage, g.srcInterfaces) } } - g.p("//") - g.p("// Generated by this command:") - // only log the name of the executable, not the full path - g.p("// %v", strings.Join(append([]string{filepath.Base(os.Args[0])}, os.Args[1:]...), " ")) + if *writeInvocationComment { + g.p("//") + g.p("// Generated by this command:") + // only log the name of the executable, not the full path + g.p("// %v", strings.Join(append([]string{filepath.Base(os.Args[0])}, os.Args[1:]...), " ")) + } // Get all required imports, and generate unique names for them all. im := pkg.Imports()