| OLD | NEW | 
|---|
|  | (Empty) | 
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. |  | 
| 2 // Use of this source code is governed by a BSD-style license that can be |  | 
| 3 // found in the LICENSE file. |  | 
| 4 |  | 
| 5 package gologger |  | 
| 6 |  | 
| 7 import ( |  | 
| 8         "golang.org/x/net/context" |  | 
| 9         "os" |  | 
| 10 |  | 
| 11         gol "github.com/op/go-logging" |  | 
| 12 |  | 
| 13         "infra/libs/logging" |  | 
| 14 ) |  | 
| 15 |  | 
| 16 const fmt string = "%{color}" + |  | 
| 17         "[P%{pid} %{time:15:04:05.000} %{shortfile} %{level:.4s} %{id:03x}]" + |  | 
| 18         "%{color:reset} %{message}" |  | 
| 19 |  | 
| 20 type loggerImpl struct { |  | 
| 21         l *gol.Logger |  | 
| 22 } |  | 
| 23 |  | 
| 24 func (l *loggerImpl) Infof(format string, args ...interface{})    { l.l.Info(for
    mat, args...) } |  | 
| 25 func (l *loggerImpl) Warningf(format string, args ...interface{}) { l.l.Warning(
    format, args...) } |  | 
| 26 func (l *loggerImpl) Errorf(format string, args ...interface{})   { l.l.Error(fo
    rmat, args...) } |  | 
| 27 |  | 
| 28 // UseFile adds a go-logging logger to the context which writes to the provided |  | 
| 29 // file. Caller is still responsible for closing the file when no longer needed. |  | 
| 30 func UseFile(c context.Context, f *os.File) context.Context { |  | 
| 31         backend := gol.NewLogBackend(f, "", 0) |  | 
| 32         formatted := gol.NewBackendFormatter(backend, gol.MustStringFormatter(fm
    t)) |  | 
| 33         gol.SetBackend(formatted) |  | 
| 34         log := &loggerImpl{gol.MustGetLogger("")} |  | 
| 35         log.l.ExtraCalldepth = 1 // one layer of wrapping in loggerImpl struct a
    bove |  | 
| 36         return logging.Set(c, func(context.Context) logging.Logger { return log 
    }) |  | 
| 37 } |  | 
| 38 |  | 
| 39 // Use adds a go-logging logger to the context which writes to os.Stdout. |  | 
| 40 func Use(c context.Context) context.Context { |  | 
| 41         return UseFile(c, os.Stdout) |  | 
| 42 } |  | 
| 43 |  | 
| 44 // Get returns default go-logging based logger. |  | 
| 45 func Get() logging.Logger { |  | 
| 46         return logging.Get(Use(context.Background())) |  | 
| 47 } |  | 
| OLD | NEW | 
|---|