You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

67 lines
963 B

  1. package arbo
  2. import "fmt"
  3. // dbgStats is for debug purposes
  4. type dbgStats struct {
  5. hash int
  6. dbGet int
  7. dbPut int
  8. }
  9. func (t *Tree) dbgInit() {
  10. t.dbg = newDbgStats()
  11. }
  12. func newDbgStats() *dbgStats {
  13. return &dbgStats{
  14. hash: 0,
  15. dbGet: 0,
  16. dbPut: 0,
  17. }
  18. }
  19. func (d *dbgStats) incHash() {
  20. if d == nil {
  21. return
  22. }
  23. d.hash++
  24. }
  25. func (d *dbgStats) incDbGet() {
  26. if d == nil {
  27. return
  28. }
  29. d.dbGet++
  30. }
  31. func (d *dbgStats) incDbPut() {
  32. if d == nil {
  33. return
  34. }
  35. d.dbPut++
  36. }
  37. func (d *dbgStats) add(d2 *dbgStats) {
  38. if d == nil || d2 == nil {
  39. return
  40. }
  41. d.hash += d2.hash
  42. d.dbGet += d2.dbGet
  43. d.dbPut += d2.dbPut
  44. }
  45. func (d *dbgStats) print(prefix string) {
  46. if d == nil {
  47. return
  48. }
  49. fmt.Printf("%sdbgStats(hash: %s, dbGet: %s, dbPut: %s)\n",
  50. prefix, formatK(d.hash), formatK(d.dbGet), formatK(d.dbPut))
  51. }
  52. func formatK(v int) string {
  53. if v/1000 > 0 {
  54. return fmt.Sprintf("%.3fk", float64(v)/1000) //nolint:gomnd
  55. }
  56. return fmt.Sprintf("%d", v)
  57. }