format.go 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. // Copyright 2016 The go-ethereum Authors
  2. // This file is part of the go-ethereum library.
  3. //
  4. // The go-ethereum library is free software: you can redistribute it and/or modify
  5. // it under the terms of the GNU Lesser General Public License as published by
  6. // the Free Software Foundation, either version 3 of the License, or
  7. // (at your option) any later version.
  8. //
  9. // The go-ethereum library is distributed in the hope that it will be useful,
  10. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. // GNU Lesser General Public License for more details.
  13. //
  14. // You should have received a copy of the GNU Lesser General Public License
  15. // along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>.
  16. package common
  17. import (
  18. "fmt"
  19. "regexp"
  20. "strings"
  21. "time"
  22. )
  23. // PrettyDuration is a pretty printed version of a time.Duration value that cuts
  24. // the unnecessary precision off from the formatted textual representation.
  25. type PrettyDuration time.Duration
  26. var prettyDurationRe = regexp.MustCompile(`\.[0-9]+`)
  27. // String implements the Stringer interface, allowing pretty printing of duration
  28. // values rounded to three decimals.
  29. func (d PrettyDuration) String() string {
  30. label := fmt.Sprintf("%v", time.Duration(d))
  31. if match := prettyDurationRe.FindString(label); len(match) > 4 {
  32. label = strings.Replace(label, match, match[:4], 1)
  33. }
  34. return label
  35. }
  36. // PrettyAge is a pretty printed version of a time.Duration value that rounds
  37. // the values up to a single most significant unit, days/weeks/years included.
  38. type PrettyAge time.Time
  39. // ageUnits is a list of units the age pretty printing uses.
  40. var ageUnits = []struct {
  41. Size time.Duration
  42. Symbol string
  43. }{
  44. {12 * 30 * 24 * time.Hour, "y"},
  45. {30 * 24 * time.Hour, "mo"},
  46. {7 * 24 * time.Hour, "w"},
  47. {24 * time.Hour, "d"},
  48. {time.Hour, "h"},
  49. {time.Minute, "m"},
  50. {time.Second, "s"},
  51. }
  52. // String implements the Stringer interface, allowing pretty printing of duration
  53. // values rounded to the most significant time unit.
  54. func (t PrettyAge) String() string {
  55. // Calculate the time difference and handle the 0 cornercase
  56. diff := time.Since(time.Time(t))
  57. if diff < time.Second {
  58. return "0"
  59. }
  60. // Accumulate a precision of 3 components before returning
  61. result, prec := "", 0
  62. for _, unit := range ageUnits {
  63. if diff > unit.Size {
  64. result = fmt.Sprintf("%s%d%s", result, diff/unit.Size, unit.Symbol)
  65. diff %= unit.Size
  66. if prec += 1; prec >= 3 {
  67. break
  68. }
  69. }
  70. }
  71. return result
  72. }