1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586 |
- /*
- * Copyright 2004 The WebRTC Project Authors. All rights reserved.
- *
- * Use of this source code is governed by a BSD-style license
- * that can be found in the LICENSE file in the root of the source
- * tree. An additional intellectual property rights grant can be found
- * in the file PATENTS. All contributing project authors may
- * be found in the AUTHORS file in the root of the source tree.
- */
- #ifndef RTC_BASE_EVENT_H_
- #define RTC_BASE_EVENT_H_
- #if defined(WEBRTC_WIN)
- #include <windows.h>
- #elif defined(WEBRTC_POSIX)
- #include <pthread.h>
- #else
- #error "Must define either WEBRTC_WIN or WEBRTC_POSIX."
- #endif
- namespace rtc {
- class Event {
- public:
- static const int kForever = -1;
- Event();
- Event(bool manual_reset, bool initially_signaled);
- Event(const Event&) = delete;
- Event& operator=(const Event&) = delete;
- ~Event();
- void Set();
- void Reset();
- // Waits for the event to become signaled, but logs a warning if it takes more
- // than `warn_after_ms` milliseconds, and gives up completely if it takes more
- // than `give_up_after_ms` milliseconds. (If `warn_after_ms >=
- // give_up_after_ms`, no warning will be logged.) Either or both may be
- // `kForever`, which means wait indefinitely.
- //
- // Returns true if the event was signaled, false if there was a timeout or
- // some other error.
- bool Wait(int give_up_after_ms, int warn_after_ms);
- // Waits with the given timeout and a reasonable default warning timeout.
- bool Wait(int give_up_after_ms) {
- return Wait(give_up_after_ms,
- give_up_after_ms == kForever ? 3000 : kForever);
- }
- private:
- #if defined(WEBRTC_WIN)
- HANDLE event_handle_;
- #elif defined(WEBRTC_POSIX)
- pthread_mutex_t event_mutex_;
- pthread_cond_t event_cond_;
- const bool is_manual_reset_;
- bool event_status_;
- #endif
- };
- // These classes are provided for compatibility with Chromium.
- // The rtc::Event implementation is overriden inside of Chromium for the
- // purposes of detecting when threads are blocked that shouldn't be as well as
- // to use the more accurate event implementation that's there than is provided
- // by default on some platforms (e.g. Windows).
- // When building with standalone WebRTC, this class is a noop.
- // For further information, please see the
- // ScopedAllowBaseSyncPrimitives(ForTesting) classes in Chromium.
- class ScopedAllowBaseSyncPrimitives {
- public:
- ScopedAllowBaseSyncPrimitives() {}
- ~ScopedAllowBaseSyncPrimitives() {}
- };
- class ScopedAllowBaseSyncPrimitivesForTesting {
- public:
- ScopedAllowBaseSyncPrimitivesForTesting() {}
- ~ScopedAllowBaseSyncPrimitivesForTesting() {}
- };
- } // namespace rtc
- #endif // RTC_BASE_EVENT_H_
|