mirror of
https://github.com/m1k1o/neko.git
synced 2024-07-24 14:40:50 +12:00
fix-races.
This commit is contained in:
@ -22,12 +22,14 @@ func NewImage(desktop types.DesktopManager) *ImageCtx {
|
||||
}
|
||||
|
||||
type ImageCtx struct {
|
||||
logger zerolog.Logger
|
||||
desktop types.DesktopManager
|
||||
emitMu sync.Mutex
|
||||
listeners map[uintptr]*func(entry *ImageEntry)
|
||||
cacheMu sync.Mutex
|
||||
logger zerolog.Logger
|
||||
desktop types.DesktopManager
|
||||
|
||||
listeners map[uintptr]*func(entry *ImageEntry)
|
||||
listenersMu sync.Mutex
|
||||
|
||||
cache map[uint64]*ImageEntry
|
||||
cacheMu sync.Mutex
|
||||
current *ImageEntry
|
||||
maxSerial uint64
|
||||
}
|
||||
@ -46,9 +48,12 @@ func (manager *ImageCtx) Start() {
|
||||
}
|
||||
|
||||
manager.current = entry
|
||||
|
||||
manager.listenersMu.Lock()
|
||||
for _, emit := range manager.listeners {
|
||||
(*emit)(entry)
|
||||
}
|
||||
manager.listenersMu.Unlock()
|
||||
})
|
||||
|
||||
manager.logger.Info().Msg("starting")
|
||||
@ -57,11 +62,11 @@ func (manager *ImageCtx) Start() {
|
||||
func (manager *ImageCtx) Shutdown() {
|
||||
manager.logger.Info().Msg("shutdown")
|
||||
|
||||
manager.emitMu.Lock()
|
||||
manager.listenersMu.Lock()
|
||||
for key := range manager.listeners {
|
||||
delete(manager.listeners, key)
|
||||
}
|
||||
manager.emitMu.Unlock()
|
||||
manager.listenersMu.Unlock()
|
||||
}
|
||||
|
||||
func (manager *ImageCtx) GetCached(serial uint64) (*ImageEntry, error) {
|
||||
@ -101,8 +106,8 @@ func (manager *ImageCtx) Get() (*ImageEntry, error) {
|
||||
}
|
||||
|
||||
func (manager *ImageCtx) AddListener(listener *func(entry *ImageEntry)) {
|
||||
manager.emitMu.Lock()
|
||||
defer manager.emitMu.Unlock()
|
||||
manager.listenersMu.Lock()
|
||||
defer manager.listenersMu.Unlock()
|
||||
|
||||
if listener != nil {
|
||||
ptr := reflect.ValueOf(listener).Pointer()
|
||||
@ -111,8 +116,8 @@ func (manager *ImageCtx) AddListener(listener *func(entry *ImageEntry)) {
|
||||
}
|
||||
|
||||
func (manager *ImageCtx) RemoveListener(listener *func(entry *ImageEntry)) {
|
||||
manager.emitMu.Lock()
|
||||
defer manager.emitMu.Unlock()
|
||||
manager.listenersMu.Lock()
|
||||
defer manager.listenersMu.Unlock()
|
||||
|
||||
if listener != nil {
|
||||
ptr := reflect.ValueOf(listener).Pointer()
|
||||
|
@ -16,30 +16,34 @@ func NewPosition() *PositionCtx {
|
||||
}
|
||||
|
||||
type PositionCtx struct {
|
||||
logger zerolog.Logger
|
||||
emitMu sync.Mutex
|
||||
listeners map[uintptr]*func(x, y int)
|
||||
logger zerolog.Logger
|
||||
|
||||
listeners map[uintptr]*func(x, y int)
|
||||
listenersMu sync.Mutex
|
||||
}
|
||||
|
||||
func (manager *PositionCtx) Shutdown() {
|
||||
manager.logger.Info().Msg("shutdown")
|
||||
|
||||
manager.emitMu.Lock()
|
||||
manager.listenersMu.Lock()
|
||||
for key := range manager.listeners {
|
||||
delete(manager.listeners, key)
|
||||
}
|
||||
manager.emitMu.Unlock()
|
||||
manager.listenersMu.Unlock()
|
||||
}
|
||||
|
||||
func (manager *PositionCtx) Set(x, y int) {
|
||||
manager.listenersMu.Lock()
|
||||
defer manager.listenersMu.Unlock()
|
||||
|
||||
for _, emit := range manager.listeners {
|
||||
(*emit)(x, y)
|
||||
}
|
||||
}
|
||||
|
||||
func (manager *PositionCtx) AddListener(listener *func(x, y int)) {
|
||||
manager.emitMu.Lock()
|
||||
defer manager.emitMu.Unlock()
|
||||
manager.listenersMu.Lock()
|
||||
defer manager.listenersMu.Unlock()
|
||||
|
||||
if listener != nil {
|
||||
ptr := reflect.ValueOf(listener).Pointer()
|
||||
@ -48,8 +52,8 @@ func (manager *PositionCtx) AddListener(listener *func(x, y int)) {
|
||||
}
|
||||
|
||||
func (manager *PositionCtx) RemoveListener(listener *func(x, y int)) {
|
||||
manager.emitMu.Lock()
|
||||
defer manager.emitMu.Unlock()
|
||||
manager.listenersMu.Lock()
|
||||
defer manager.listenersMu.Unlock()
|
||||
|
||||
if listener != nil {
|
||||
ptr := reflect.ValueOf(listener).Pointer()
|
||||
|
Reference in New Issue
Block a user