mirror of
https://github.com/m1k1o/neko.git
synced 2024-07-24 14:40:50 +12:00
fix-races.
This commit is contained in:
parent
89ba775a71
commit
f32e7e7075
@ -26,6 +26,7 @@ type ScreencastManagerCtx struct {
|
|||||||
pipelineMu sync.Mutex
|
pipelineMu sync.Mutex
|
||||||
|
|
||||||
image types.Sample
|
image types.Sample
|
||||||
|
imageMu sync.Mutex
|
||||||
tickerStop chan struct{}
|
tickerStop chan struct{}
|
||||||
|
|
||||||
enabled bool
|
enabled bool
|
||||||
@ -101,6 +102,9 @@ func (manager *ScreencastManagerCtx) Image() ([]byte, error) {
|
|||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
manager.imageMu.Lock()
|
||||||
|
defer manager.imageMu.Unlock()
|
||||||
|
|
||||||
if manager.image.Data == nil {
|
if manager.image.Data == nil {
|
||||||
return nil, errors.New("image data not found")
|
return nil, errors.New("image data not found")
|
||||||
}
|
}
|
||||||
@ -156,30 +160,36 @@ func (manager *ScreencastManagerCtx) createPipeline() error {
|
|||||||
manager.pipeline.Play()
|
manager.pipeline.Play()
|
||||||
|
|
||||||
// get first image
|
// get first image
|
||||||
var ok bool
|
|
||||||
select {
|
select {
|
||||||
case manager.image, ok = <-manager.pipeline.Sample:
|
case image, ok := <-manager.pipeline.Sample:
|
||||||
if !ok {
|
if !ok {
|
||||||
return errors.New("unable to get first image")
|
return errors.New("unable to get first image")
|
||||||
|
} else {
|
||||||
|
manager.imageMu.Lock()
|
||||||
|
manager.image = image
|
||||||
|
manager.imageMu.Unlock()
|
||||||
}
|
}
|
||||||
case <-time.After(1 * time.Second):
|
case <-time.After(1 * time.Second):
|
||||||
return errors.New("timeouted while waiting for first image")
|
return errors.New("timeouted while waiting for first image")
|
||||||
}
|
}
|
||||||
|
|
||||||
manager.wg.Add(1)
|
manager.wg.Add(1)
|
||||||
|
pipeline := manager.pipeline
|
||||||
|
|
||||||
go func() {
|
go func() {
|
||||||
manager.logger.Debug().Msg("started receiving images")
|
manager.logger.Debug().Msg("started receiving images")
|
||||||
defer manager.wg.Done()
|
defer manager.wg.Done()
|
||||||
|
|
||||||
for {
|
for {
|
||||||
image, ok := <-manager.pipeline.Sample
|
image, ok := <-pipeline.Sample
|
||||||
if !ok {
|
if !ok {
|
||||||
manager.logger.Debug().Msg("stopped receiving images")
|
manager.logger.Debug().Msg("stopped receiving images")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
manager.imageMu.Lock()
|
||||||
manager.image = image
|
manager.image = image
|
||||||
|
manager.imageMu.Unlock()
|
||||||
}
|
}
|
||||||
}()
|
}()
|
||||||
|
|
||||||
|
@ -219,13 +219,14 @@ func (manager *StreamSinkManagerCtx) createPipeline() error {
|
|||||||
manager.pipeline.Play()
|
manager.pipeline.Play()
|
||||||
|
|
||||||
manager.wg.Add(1)
|
manager.wg.Add(1)
|
||||||
|
pipeline := manager.pipeline
|
||||||
|
|
||||||
go func() {
|
go func() {
|
||||||
manager.logger.Debug().Msg("started emitting samples")
|
manager.logger.Debug().Msg("started emitting samples")
|
||||||
defer manager.wg.Done()
|
defer manager.wg.Done()
|
||||||
|
|
||||||
for {
|
for {
|
||||||
sample, ok := <-manager.pipeline.Sample
|
sample, ok := <-pipeline.Sample
|
||||||
if !ok {
|
if !ok {
|
||||||
manager.logger.Debug().Msg("stopped emitting samples")
|
manager.logger.Debug().Msg("stopped emitting samples")
|
||||||
return
|
return
|
||||||
|
@ -24,10 +24,12 @@ func NewImage(desktop types.DesktopManager) *ImageCtx {
|
|||||||
type ImageCtx struct {
|
type ImageCtx struct {
|
||||||
logger zerolog.Logger
|
logger zerolog.Logger
|
||||||
desktop types.DesktopManager
|
desktop types.DesktopManager
|
||||||
emitMu sync.Mutex
|
|
||||||
listeners map[uintptr]*func(entry *ImageEntry)
|
listeners map[uintptr]*func(entry *ImageEntry)
|
||||||
cacheMu sync.Mutex
|
listenersMu sync.Mutex
|
||||||
|
|
||||||
cache map[uint64]*ImageEntry
|
cache map[uint64]*ImageEntry
|
||||||
|
cacheMu sync.Mutex
|
||||||
current *ImageEntry
|
current *ImageEntry
|
||||||
maxSerial uint64
|
maxSerial uint64
|
||||||
}
|
}
|
||||||
@ -46,9 +48,12 @@ func (manager *ImageCtx) Start() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
manager.current = entry
|
manager.current = entry
|
||||||
|
|
||||||
|
manager.listenersMu.Lock()
|
||||||
for _, emit := range manager.listeners {
|
for _, emit := range manager.listeners {
|
||||||
(*emit)(entry)
|
(*emit)(entry)
|
||||||
}
|
}
|
||||||
|
manager.listenersMu.Unlock()
|
||||||
})
|
})
|
||||||
|
|
||||||
manager.logger.Info().Msg("starting")
|
manager.logger.Info().Msg("starting")
|
||||||
@ -57,11 +62,11 @@ func (manager *ImageCtx) Start() {
|
|||||||
func (manager *ImageCtx) Shutdown() {
|
func (manager *ImageCtx) Shutdown() {
|
||||||
manager.logger.Info().Msg("shutdown")
|
manager.logger.Info().Msg("shutdown")
|
||||||
|
|
||||||
manager.emitMu.Lock()
|
manager.listenersMu.Lock()
|
||||||
for key := range manager.listeners {
|
for key := range manager.listeners {
|
||||||
delete(manager.listeners, key)
|
delete(manager.listeners, key)
|
||||||
}
|
}
|
||||||
manager.emitMu.Unlock()
|
manager.listenersMu.Unlock()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (manager *ImageCtx) GetCached(serial uint64) (*ImageEntry, error) {
|
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)) {
|
func (manager *ImageCtx) AddListener(listener *func(entry *ImageEntry)) {
|
||||||
manager.emitMu.Lock()
|
manager.listenersMu.Lock()
|
||||||
defer manager.emitMu.Unlock()
|
defer manager.listenersMu.Unlock()
|
||||||
|
|
||||||
if listener != nil {
|
if listener != nil {
|
||||||
ptr := reflect.ValueOf(listener).Pointer()
|
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)) {
|
func (manager *ImageCtx) RemoveListener(listener *func(entry *ImageEntry)) {
|
||||||
manager.emitMu.Lock()
|
manager.listenersMu.Lock()
|
||||||
defer manager.emitMu.Unlock()
|
defer manager.listenersMu.Unlock()
|
||||||
|
|
||||||
if listener != nil {
|
if listener != nil {
|
||||||
ptr := reflect.ValueOf(listener).Pointer()
|
ptr := reflect.ValueOf(listener).Pointer()
|
||||||
|
@ -17,29 +17,33 @@ func NewPosition() *PositionCtx {
|
|||||||
|
|
||||||
type PositionCtx struct {
|
type PositionCtx struct {
|
||||||
logger zerolog.Logger
|
logger zerolog.Logger
|
||||||
emitMu sync.Mutex
|
|
||||||
listeners map[uintptr]*func(x, y int)
|
listeners map[uintptr]*func(x, y int)
|
||||||
|
listenersMu sync.Mutex
|
||||||
}
|
}
|
||||||
|
|
||||||
func (manager *PositionCtx) Shutdown() {
|
func (manager *PositionCtx) Shutdown() {
|
||||||
manager.logger.Info().Msg("shutdown")
|
manager.logger.Info().Msg("shutdown")
|
||||||
|
|
||||||
manager.emitMu.Lock()
|
manager.listenersMu.Lock()
|
||||||
for key := range manager.listeners {
|
for key := range manager.listeners {
|
||||||
delete(manager.listeners, key)
|
delete(manager.listeners, key)
|
||||||
}
|
}
|
||||||
manager.emitMu.Unlock()
|
manager.listenersMu.Unlock()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (manager *PositionCtx) Set(x, y int) {
|
func (manager *PositionCtx) Set(x, y int) {
|
||||||
|
manager.listenersMu.Lock()
|
||||||
|
defer manager.listenersMu.Unlock()
|
||||||
|
|
||||||
for _, emit := range manager.listeners {
|
for _, emit := range manager.listeners {
|
||||||
(*emit)(x, y)
|
(*emit)(x, y)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (manager *PositionCtx) AddListener(listener *func(x, y int)) {
|
func (manager *PositionCtx) AddListener(listener *func(x, y int)) {
|
||||||
manager.emitMu.Lock()
|
manager.listenersMu.Lock()
|
||||||
defer manager.emitMu.Unlock()
|
defer manager.listenersMu.Unlock()
|
||||||
|
|
||||||
if listener != nil {
|
if listener != nil {
|
||||||
ptr := reflect.ValueOf(listener).Pointer()
|
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)) {
|
func (manager *PositionCtx) RemoveListener(listener *func(x, y int)) {
|
||||||
manager.emitMu.Lock()
|
manager.listenersMu.Lock()
|
||||||
defer manager.emitMu.Unlock()
|
defer manager.listenersMu.Unlock()
|
||||||
|
|
||||||
if listener != nil {
|
if listener != nil {
|
||||||
ptr := reflect.ValueOf(listener).Pointer()
|
ptr := reflect.ValueOf(listener).Pointer()
|
||||||
|
Loading…
Reference in New Issue
Block a user