vendor: Update github.com/zillode/notify (#4734)

This commit is contained in:
Simon Frei 2018-02-04 22:37:32 +01:00 committed by Jakob Borg
parent 98f2875b22
commit c7cf361a96
4 changed files with 9 additions and 29 deletions

View File

@ -26,9 +26,9 @@ import "C"
import ( import (
"errors" "errors"
"os" "os"
"runtime"
"sync" "sync"
"sync/atomic" "sync/atomic"
"time"
"unsafe" "unsafe"
) )
@ -48,7 +48,7 @@ var wg sync.WaitGroup // used to wait until the runloop starts
// started and is ready via the wg. It also serves purpose of a dummy source, // started and is ready via the wg. It also serves purpose of a dummy source,
// thanks to it the runloop does not return as it also has at least one source // thanks to it the runloop does not return as it also has at least one source
// registered. // registered.
var source = C.CFRunLoopSourceCreate(refZero, 0, &C.CFRunLoopSourceContext{ var source = C.CFRunLoopSourceCreate(nil, 0, &C.CFRunLoopSourceContext{
perform: (C.CFRunLoopPerformCallBack)(C.gosource), perform: (C.CFRunLoopPerformCallBack)(C.gosource),
}) })
@ -63,6 +63,10 @@ var (
func init() { func init() {
wg.Add(1) wg.Add(1)
go func() { go func() {
// There is exactly one run loop per thread. Lock this goroutine to its
// thread to ensure that it's not rescheduled on a different thread while
// setting up the run loop.
runtime.LockOSThread()
runloop = C.CFRunLoopGetCurrent() runloop = C.CFRunLoopGetCurrent()
C.CFRunLoopAddSource(runloop, source, C.kCFRunLoopDefaultMode) C.CFRunLoopAddSource(runloop, source, C.kCFRunLoopDefaultMode)
C.CFRunLoopRun() C.CFRunLoopRun()
@ -73,7 +77,6 @@ func init() {
//export gosource //export gosource
func gosource(unsafe.Pointer) { func gosource(unsafe.Pointer) {
time.Sleep(time.Second)
wg.Done() wg.Done()
} }
@ -159,8 +162,8 @@ func (s *stream) Start() error {
return nil return nil
} }
wg.Wait() wg.Wait()
p := C.CFStringCreateWithCStringNoCopy(refZero, C.CString(s.path), C.kCFStringEncodingUTF8, refZero) p := C.CFStringCreateWithCStringNoCopy(nil, C.CString(s.path), C.kCFStringEncodingUTF8, nil)
path := C.CFArrayCreate(refZero, (*unsafe.Pointer)(unsafe.Pointer(&p)), 1, nil) path := C.CFArrayCreate(nil, (*unsafe.Pointer)(unsafe.Pointer(&p)), 1, nil)
ctx := C.FSEventStreamContext{} ctx := C.FSEventStreamContext{}
ref := C.EventStreamCreate(&ctx, C.uintptr_t(s.info), path, C.FSEventStreamEventId(atomic.LoadUint64(&since)), latency, flags) ref := C.EventStreamCreate(&ctx, C.uintptr_t(s.info), path, C.FSEventStreamEventId(atomic.LoadUint64(&since)), latency, flags)
if ref == nilstream { if ref == nilstream {

View File

@ -1,9 +0,0 @@
// Copyright (c) 2017 The Notify Authors. All rights reserved.
// Use of this source code is governed by the MIT license that can be
// found in the LICENSE file.
// +build darwin,!kqueue,go1.10
package notify
const refZero = 0

View File

@ -1,14 +0,0 @@
// Copyright (c) 2017 The Notify Authors. All rights reserved.
// Use of this source code is governed by the MIT license that can be
// found in the LICENSE file.
// +build darwin,!kqueue,cgo,!go1.10
package notify
/*
#include <CoreServices/CoreServices.h>
*/
import "C"
var refZero = (*C.struct___CFAllocator)(nil)

2
vendor/manifest vendored
View File

@ -544,7 +544,7 @@
"importpath": "github.com/zillode/notify", "importpath": "github.com/zillode/notify",
"repository": "https://github.com/zillode/notify", "repository": "https://github.com/zillode/notify",
"vcs": "git", "vcs": "git",
"revision": "8fff849a2026ce7a59f67ed9747dd9c7adc8bd0b", "revision": "a8abcfb1ce88ee8d79a300ed65d94b8fb616ddb3",
"branch": "master", "branch": "master",
"notests": true "notests": true
}, },