From: Shenghou Ma Date: Mon, 25 Feb 2013 22:33:59 +0000 (+0800) Subject: strconv, fmt: clarify behavior of CanBackquote and "%#q". X-Git-Tag: go1.1rc2~850 X-Git-Url: http://www.git.cypherpunks.su/?a=commitdiff_plain;h=4692711d7f172ab69a9576ffbe753314755f780a;p=gostls13.git strconv, fmt: clarify behavior of CanBackquote and "%#q". Fixes #4858. R=golang-dev, bradfitz, r, rsc CC=golang-dev https://golang.org/cl/7387044 --- diff --git a/src/pkg/fmt/doc.go b/src/pkg/fmt/doc.go index 2c925a4228..3cd02d7ede 100644 --- a/src/pkg/fmt/doc.go +++ b/src/pkg/fmt/doc.go @@ -74,7 +74,8 @@ - pad with spaces on the right rather than the left (left-justify the field) # alternate format: add leading 0 for octal (%#o), 0x for hex (%#x); 0X for hex (%#X); suppress 0x for %p (%#p); - print a raw (backquoted) string if possible for %q (%#q); + for %q, print a raw (backquoted) string if strconv.CanBackquote + returns true; write e.g. U+0078 'x' if the character is printable for %U (%#U). ' ' (space) leave a space for elided sign in numbers (% d); put spaces between bytes printing strings or slices in hex (% x, % X) diff --git a/src/pkg/strconv/quote.go b/src/pkg/strconv/quote.go index 8a73f9d3b2..8cbef88b51 100644 --- a/src/pkg/strconv/quote.go +++ b/src/pkg/strconv/quote.go @@ -139,8 +139,9 @@ func AppendQuoteRuneToASCII(dst []byte, r rune) []byte { return append(dst, QuoteRuneToASCII(r)...) } -// CanBackquote returns whether the string s would be -// a valid Go string literal if enclosed in backquotes. +// CanBackquote reports whether the string s can be represented +// unchanged as a single-line backquoted string without control +// characters other than space and tab. func CanBackquote(s string) bool { for i := 0; i < len(s); i++ { if (s[i] < ' ' && s[i] != '\t') || s[i] == '`' {