naiveproxy/base/mac/dispatch_source_mach.cc

49 lines
1.8 KiB
C++
Raw Normal View History

2018-01-28 21:32:06 +03:00
// Copyright 2014 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "base/mac/dispatch_source_mach.h"
namespace base {
DispatchSourceMach::DispatchSourceMach(const char* name,
mach_port_t port,
void (^event_handler)())
// TODO(rsesek): Specify DISPATCH_QUEUE_SERIAL, in the 10.7 SDK. NULL
// means the same thing but is not symbolically clear.
: DispatchSourceMach(dispatch_queue_create(name, NULL),
port,
event_handler) {
// Since the queue was created above in the delegated constructor, and it was
// subsequently retained, release it here.
dispatch_release(queue_);
}
DispatchSourceMach::DispatchSourceMach(dispatch_queue_t queue,
mach_port_t port,
void (^event_handler)())
: queue_(queue, base::scoped_policy::RETAIN),
source_(dispatch_source_create(DISPATCH_SOURCE_TYPE_MACH_RECV,
port, 0, queue_)),
source_canceled_(dispatch_semaphore_create(0)) {
dispatch_source_set_event_handler(source_, event_handler);
dispatch_source_set_cancel_handler(source_, ^{
dispatch_semaphore_signal(source_canceled_);
});
}
DispatchSourceMach::~DispatchSourceMach() {
// Cancel the source and wait for the semaphore to be signaled. This will
// ensure the source managed by this class is not used after it is freed.
dispatch_source_cancel(source_);
source_.reset();
dispatch_semaphore_wait(source_canceled_, DISPATCH_TIME_FOREVER);
}
void DispatchSourceMach::Resume() {
dispatch_resume(source_);
}
} // namespace base