From d0a69e92f6bdce74c7acdd59fdca57cca2a9587e Mon Sep 17 00:00:00 2001 From: Keegan Carruthers-Smith Date: Sun, 9 Sep 2018 21:00:22 +0400 Subject: [PATCH] gocode: Replace usages of fmt.Print* with log.Print* We should never write to stdout, only stderr. Otherwise programs which use stdout/stdin communication will break. Ran the following from the gocode directory: codemod --extensions go fmt.P log.P goimports -w * Fixes #313 --- langserver/internal/gocode/decl.go | 2 +- langserver/internal/gocode/utils.go | 7 ++++--- 2 files changed, 5 insertions(+), 4 deletions(-) diff --git a/langserver/internal/gocode/decl.go b/langserver/internal/gocode/decl.go index 988f0627..3e6b8189 100644 --- a/langserver/internal/gocode/decl.go +++ b/langserver/internal/gocode/decl.go @@ -937,7 +937,7 @@ func infer_type(v ast.Expr, scope *scope, index int) (ast.Expr, *scope, bool) { return t, scope, true default: _ = reflect.TypeOf(v) - //fmt.Println(ty) + //log.Println(ty) } return nil, nil, false } diff --git a/langserver/internal/gocode/utils.go b/langserver/internal/gocode/utils.go index afee81eb..29e133f1 100644 --- a/langserver/internal/gocode/utils.go +++ b/langserver/internal/gocode/utils.go @@ -5,6 +5,7 @@ import ( "fmt" "go/build" "io/ioutil" + "log" "os" "path/filepath" "runtime" @@ -184,7 +185,7 @@ var g_backtrace_mutex sync.Mutex func print_backtrace(err interface{}) { g_backtrace_mutex.Lock() defer g_backtrace_mutex.Unlock() - fmt.Printf("panic: %v\n", err) + log.Printf("panic: %v\n", err) i := 2 for { pc, file, line, ok := runtime.Caller(i) @@ -192,10 +193,10 @@ func print_backtrace(err interface{}) { break } f := runtime.FuncForPC(pc) - fmt.Printf("%d(%s): %s:%d\n", i-1, f.Name(), file, line) + log.Printf("%d(%s): %s:%d\n", i-1, f.Name(), file, line) i++ } - fmt.Println("") + log.Println("") } //-------------------------------------------------------------------------