From 9c277ebfdc8160ff35874276eb4ec567efe893bc Mon Sep 17 00:00:00 2001 From: Nick Snyder Date: Fri, 15 Dec 2023 18:39:31 -0800 Subject: [PATCH] Fix incorrect example in string formatting docs. (#873) %s is defined to support "all numerical types (int, uint, and double)." but later the docs also say: "Passing an incorrect type (an integer to `%s`) is considered an error" The example in the parenthetical contradicts the definition of %s. This change replaces the parenthetical example with one that is accurate and verified by an existing test case. This change also adds an explicit test case to verify that it is valid to pass an in to %s. --- ext/strings.go | 2 +- ext/strings_test.go | 8 ++++++++ 2 files changed, 9 insertions(+), 1 deletion(-) diff --git a/ext/strings.go b/ext/strings.go index 1faa6ed7..2e20f1e4 100644 --- a/ext/strings.go +++ b/ext/strings.go @@ -96,7 +96,7 @@ const ( // "a map inside a list: %s".format([[1, 2, 3, {"a": "x", "b": "y", "c": "z"}]]) // returns "a map inside a list: [1, 2, 3, {"a":"x", "b":"y", "c":"d"}]" // "true bool: %s - false bool: %s\nbinary bool: %b".format([true, false, true]) // returns "true bool: true - false bool: false\nbinary bool: 1" // -// Passing an incorrect type (an integer to `%s`) is considered an error, as well as attempting +// Passing an incorrect type (a string to `%b`) is considered an error, as well as attempting // to use more formatting clauses than there are arguments (`%d %d %d` while passing two ints, for instance). // If compile-time checking is enabled, and the formatting string is a constant, and the argument list is a literal, // then letting any arguments go unused/unformatted is also considered an error. diff --git a/ext/strings_test.go b/ext/strings_test.go index fc0ade11..564fd10e 100644 --- a/ext/strings_test.go +++ b/ext/strings_test.go @@ -713,6 +713,14 @@ func TestStringFormat(t *testing.T) { expectedRuntimeCost: 11, expectedEstimatedCost: checker.CostEstimate{Min: 11, Max: 11}, }, + { + name: "int support for string", + format: "%s", + formatArgs: `999999999999`, + expectedOutput: "999999999999", + expectedRuntimeCost: 11, + expectedEstimatedCost: checker.CostEstimate{Min: 11, Max: 11}, + }, { name: "bytes support for string", format: "some bytes: %s",