writer.go 709 B

12345678910111213141516171819202122232425262728293031323334353637
  1. // Copyright 2020 The Gogs Authors. All rights reserved.
  2. // Use of this source code is governed by a MIT-style
  3. // license that can be found in the LICENSE file.
  4. package dbutil
  5. import (
  6. "fmt"
  7. "io"
  8. )
  9. // Writer is a wrapper of io.Writer for the gorm.logger.
  10. type Writer struct {
  11. io.Writer
  12. }
  13. func (w *Writer) Print(v ...interface{}) {
  14. if len(v) == 0 {
  15. return
  16. }
  17. if len(v) == 1 {
  18. fmt.Fprint(w.Writer, v[0])
  19. return
  20. }
  21. switch v[0] {
  22. case "sql":
  23. fmt.Fprintf(w.Writer, "[sql] [%s] [%s] %s %v (%d rows affected)", v[1:]...)
  24. case "log":
  25. fmt.Fprintf(w.Writer, "[log] [%s] %s", v[1:]...)
  26. case "error":
  27. fmt.Fprintf(w.Writer, "[err] [%s] %s", v[1:]...)
  28. default:
  29. fmt.Fprint(w.Writer, v...)
  30. }
  31. }