From fbe23d045022aac8ff3ae691052af25968680944 Mon Sep 17 00:00:00 2001 From: Tom Clegg Date: Mon, 3 Aug 2015 00:36:46 -0400 Subject: [PATCH] 5824: Use fmt "%+q" instead of custom escaping. --- sdk/go/httpserver/log.go | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/sdk/go/httpserver/log.go b/sdk/go/httpserver/log.go index 7bee88742c..cdfc595e67 100644 --- a/sdk/go/httpserver/log.go +++ b/sdk/go/httpserver/log.go @@ -1,20 +1,21 @@ package httpserver import ( + "fmt" "log" - "strings" ) -var escaper = strings.NewReplacer("\"", "\\\"", "\\", "\\\\", "\n", "\\n") - // Log calls log.Println but first transforms strings so they are // safer to write in logs (e.g., 'foo"bar' becomes -// '"foo\"bar"'). Non-string args are left alone. +// '"foo\"bar"'). Arguments that aren't strings and don't have a +// (String() string) method are left alone. func Log(args ...interface{}) { newargs := make([]interface{}, len(args)) for i, arg := range args { if s, ok := arg.(string); ok { - newargs[i] = "\"" + escaper.Replace(s) + "\"" + newargs[i] = fmt.Sprintf("%+q", s) + } else if s, ok := arg.(fmt.Stringer); ok { + newargs[i] = fmt.Sprintf("%+q", s.String()) } else { newargs[i] = arg } -- 2.30.2