]> Cypherpunks repositories - gostls13.git/commitdiff
go/types: don't use user string as format string
authorRobert Griesemer <gri@golang.org>
Tue, 30 May 2023 15:38:56 +0000 (08:38 -0700)
committerGopher Robot <gobot@golang.org>
Tue, 30 May 2023 15:53:36 +0000 (15:53 +0000)
Fixes #60500.

Change-Id: I272c71071f239d5c9472e19ae25461001e7f6a8f
Reviewed-on: https://go-review.googlesource.com/c/go/+/499275
Reviewed-by: Robert Griesemer <gri@google.com>
Run-TryBot: Robert Griesemer <gri@google.com>
Auto-Submit: Robert Griesemer <gri@google.com>
TryBot-Result: Gopher Robot <gobot@golang.org>
Reviewed-by: Robert Findley <rfindley@google.com>
src/go/types/errors.go
src/internal/types/testdata/fixedbugs/issue60500.go [new file with mode: 0644]

index 5cef8032cf3ebedf1621647cecdf36a167988513..14d0383e37248fb99fa910bdd14d89a70b26c8c7 100644 (file)
@@ -303,7 +303,7 @@ func newErrorf(at positioner, code Code, format string, args ...any) *error_ {
 }
 
 func (check *Checker) error(at positioner, code Code, msg string) {
-       check.report(newErrorf(at, code, msg))
+       check.report(newErrorf(at, code, "%s", msg))
 }
 
 func (check *Checker) errorf(at positioner, code Code, format string, args ...any) {
diff --git a/src/internal/types/testdata/fixedbugs/issue60500.go b/src/internal/types/testdata/fixedbugs/issue60500.go
new file mode 100644 (file)
index 0000000..be8ccaf
--- /dev/null
@@ -0,0 +1,11 @@
+// Copyright 2023 The Go Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style
+// license that can be found in the LICENSE file.
+
+package p
+
+func _() {
+       log("This is a test %v" /* ERROR "cannot use \"This is a test %v\" (untyped string constant) as bool value in argument to log" */, "foo")
+}
+
+func log(enabled bool, format string, args ...any)