forked from SoftwareAG/adabas-go-api
-
Notifications
You must be signed in to change notification settings - Fork 0
/
tracker.go
35 lines (28 loc) · 774 Bytes
/
tracker.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
package adabas
import (
"time"
"github.com/tknie/adabas-go-api/adatypes"
)
// Tracker tracker function containing the function to call
type Tracker struct {
TrackFunc func(start time.Duration, adabas *Adabas)
}
var adabasTracker *Tracker
// RegisterTracker register tracker for analysis Adabas calls
func RegisterTracker(tracker *Tracker) {
adabasTracker = tracker
}
// ClearTracker clear tracker for analysis Adabas calls
func ClearTracker() {
adabasTracker = nil
}
// TrackAdabas track Adabas calls (internally)
func TrackAdabas(start time.Time, adabas *Adabas) {
elapsed := time.Since(start)
if adabasTracker != nil {
if adatypes.Central.IsDebugLevel() {
adatypes.Central.Log.Debugf("Tracking call")
}
adabasTracker.TrackFunc(elapsed, adabas)
}
}