| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495 |
- // +build !confonly
- package stats
- //go:generate errorgen
- import (
- "context"
- "sync"
- "sync/atomic"
- "v2ray.com/core/features/stats"
- )
- // Counter is an implementation of stats.Counter.
- type Counter struct {
- value int64
- }
- // Value implements stats.Counter.
- func (c *Counter) Value() int64 {
- return atomic.LoadInt64(&c.value)
- }
- // Set implements stats.Counter.
- func (c *Counter) Set(newValue int64) int64 {
- return atomic.SwapInt64(&c.value, newValue)
- }
- // Add implements stats.Counter.
- func (c *Counter) Add(delta int64) int64 {
- return atomic.AddInt64(&c.value, delta)
- }
- // Manager is an implementation of stats.Manager.
- type Manager struct {
- access sync.RWMutex
- counters map[string]*Counter
- }
- func NewManager(ctx context.Context, config *Config) (*Manager, error) {
- m := &Manager{
- counters: make(map[string]*Counter),
- }
- return m, nil
- }
- func (*Manager) Type() interface{} {
- return stats.ManagerType()
- }
- func (m *Manager) RegisterCounter(name string) (stats.Counter, error) {
- m.access.Lock()
- defer m.access.Unlock()
- if _, found := m.counters[name]; found {
- return nil, newError("Counter ", name, " already registered.")
- }
- newError("create new counter ", name).AtDebug().WriteToLog()
- c := new(Counter)
- m.counters[name] = c
- return c, nil
- }
- func (m *Manager) GetCounter(name string) stats.Counter {
- m.access.RLock()
- defer m.access.RUnlock()
- if c, found := m.counters[name]; found {
- return c
- }
- return nil
- }
- func (m *Manager) Visit(visitor func(string, stats.Counter) bool) {
- m.access.RLock()
- defer m.access.RUnlock()
- for name, c := range m.counters {
- if !visitor(name, c) {
- break
- }
- }
- }
- // Start implements common.Runnable.
- func (m *Manager) Start() error {
- return nil
- }
- // Close implement common.Closable.
- func (m *Manager) Close() error {
- return nil
- }
|