2021-11-14 10:55:09 +08:00
|
|
|
// Copyright 2021 Liuxiangchao iwind.liu@gmail.com. All rights reserved.
|
|
|
|
|
|
|
|
|
|
package trackers
|
|
|
|
|
|
|
|
|
|
import "time"
|
|
|
|
|
|
|
|
|
|
type tracker struct {
|
|
|
|
|
label string
|
|
|
|
|
startTime time.Time
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func Begin(label string) *tracker {
|
|
|
|
|
return &tracker{label: label, startTime: time.Now()}
|
|
|
|
|
}
|
|
|
|
|
|
2021-11-14 16:15:07 +08:00
|
|
|
func Run(label string, f func()) {
|
|
|
|
|
var tr = Begin(label)
|
|
|
|
|
f()
|
|
|
|
|
tr.End()
|
|
|
|
|
}
|
|
|
|
|
|
2021-11-14 10:55:09 +08:00
|
|
|
func (this *tracker) End() {
|
|
|
|
|
SharedManager.Add(this.label, time.Since(this.startTime).Seconds()*1000)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (this *tracker) Begin(subLabel string) *tracker {
|
|
|
|
|
return Begin(this.label + ":" + subLabel)
|
|
|
|
|
}
|
2024-04-02 19:54:04 +08:00
|
|
|
|
|
|
|
|
func (this *tracker) Add(duration time.Duration) {
|
|
|
|
|
this.startTime = this.startTime.Add(-duration)
|
|
|
|
|
}
|