Move PollFlags to separate header.
GitOrigin-RevId: 5c97229d6c29fb281c6c1100530b14bcc1aaa827
This commit is contained in:
parent
5260fa4ef9
commit
943fc13900
@ -37,6 +37,7 @@ set(TDUTILS_SOURCE
|
|||||||
td/utils/port/FileFd.cpp
|
td/utils/port/FileFd.cpp
|
||||||
td/utils/port/IPAddress.cpp
|
td/utils/port/IPAddress.cpp
|
||||||
td/utils/port/path.cpp
|
td/utils/port/path.cpp
|
||||||
|
td/utils/port/PollFlags.cpp
|
||||||
td/utils/port/ServerSocketFd.cpp
|
td/utils/port/ServerSocketFd.cpp
|
||||||
td/utils/port/signals.cpp
|
td/utils/port/signals.cpp
|
||||||
td/utils/port/sleep.cpp
|
td/utils/port/sleep.cpp
|
||||||
@ -54,7 +55,6 @@ set(TDUTILS_SOURCE
|
|||||||
td/utils/port/detail/KQueue.cpp
|
td/utils/port/detail/KQueue.cpp
|
||||||
td/utils/port/detail/NativeFd.cpp
|
td/utils/port/detail/NativeFd.cpp
|
||||||
td/utils/port/detail/Poll.cpp
|
td/utils/port/detail/Poll.cpp
|
||||||
td/utils/port/detail/PollableFd.cpp
|
|
||||||
td/utils/port/detail/Select.cpp
|
td/utils/port/detail/Select.cpp
|
||||||
td/utils/port/detail/ThreadIdGuard.cpp
|
td/utils/port/detail/ThreadIdGuard.cpp
|
||||||
td/utils/port/detail/WineventPoll.cpp
|
td/utils/port/detail/WineventPoll.cpp
|
||||||
@ -100,6 +100,7 @@ set(TDUTILS_SOURCE
|
|||||||
td/utils/port/platform.h
|
td/utils/port/platform.h
|
||||||
td/utils/port/Poll.h
|
td/utils/port/Poll.h
|
||||||
td/utils/port/PollBase.h
|
td/utils/port/PollBase.h
|
||||||
|
td/utils/port/PollFlags.h
|
||||||
td/utils/port/RwMutex.h
|
td/utils/port/RwMutex.h
|
||||||
td/utils/port/ServerSocketFd.h
|
td/utils/port/ServerSocketFd.h
|
||||||
td/utils/port/signals.h
|
td/utils/port/signals.h
|
||||||
|
@ -4,13 +4,10 @@
|
|||||||
// Distributed under the Boost Software License, Version 1.0. (See accompanying
|
// Distributed under the Boost Software License, Version 1.0. (See accompanying
|
||||||
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
||||||
//
|
//
|
||||||
#include "td/utils/port/detail/PollableFd.h"
|
#include "td/utils/port/PollFlags.h"
|
||||||
|
|
||||||
#if TD_POSIX_PORT
|
|
||||||
#include <unistd.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
namespace td {
|
namespace td {
|
||||||
|
|
||||||
bool PollFlagsSet::write_flags(PollFlags flags) {
|
bool PollFlagsSet::write_flags(PollFlags flags) {
|
||||||
if (flags.empty()) {
|
if (flags.empty()) {
|
||||||
return false;
|
return false;
|
||||||
@ -18,9 +15,11 @@ bool PollFlagsSet::write_flags(PollFlags flags) {
|
|||||||
auto old_flags = to_write_.fetch_or(flags.raw(), std::memory_order_relaxed);
|
auto old_flags = to_write_.fetch_or(flags.raw(), std::memory_order_relaxed);
|
||||||
return (flags.raw() & ~old_flags) != 0;
|
return (flags.raw() & ~old_flags) != 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool PollFlagsSet::write_flags_local(PollFlags flags) {
|
bool PollFlagsSet::write_flags_local(PollFlags flags) {
|
||||||
return flags_.add_flags(flags);
|
return flags_.add_flags(flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool PollFlagsSet::flush() const {
|
bool PollFlagsSet::flush() const {
|
||||||
if (to_write_.load(std::memory_order_relaxed) == 0) {
|
if (to_write_.load(std::memory_order_relaxed) == 0) {
|
||||||
return false;
|
return false;
|
||||||
@ -33,19 +32,40 @@ bool PollFlagsSet::flush() const {
|
|||||||
}
|
}
|
||||||
return flags_ != old_flags;
|
return flags_ != old_flags;
|
||||||
}
|
}
|
||||||
|
|
||||||
PollFlags PollFlagsSet::read_flags() const {
|
PollFlags PollFlagsSet::read_flags() const {
|
||||||
flush();
|
flush();
|
||||||
return flags_;
|
return flags_;
|
||||||
}
|
}
|
||||||
|
|
||||||
PollFlags PollFlagsSet::read_flags_local() const {
|
PollFlags PollFlagsSet::read_flags_local() const {
|
||||||
return flags_;
|
return flags_;
|
||||||
}
|
}
|
||||||
|
|
||||||
void PollFlagsSet::clear_flags(PollFlags flags) {
|
void PollFlagsSet::clear_flags(PollFlags flags) {
|
||||||
flags_.remove_flags(flags);
|
flags_.remove_flags(flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
void PollFlagsSet::clear() {
|
void PollFlagsSet::clear() {
|
||||||
to_write_ = 0;
|
to_write_ = 0;
|
||||||
flags_ = {};
|
flags_ = {};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
StringBuilder &operator<<(StringBuilder &sb, PollFlags flags) {
|
||||||
|
sb << "[";
|
||||||
|
if (flags.can_read()) {
|
||||||
|
sb << "R";
|
||||||
|
}
|
||||||
|
if (flags.can_write()) {
|
||||||
|
sb << "W";
|
||||||
|
}
|
||||||
|
if (flags.can_close()) {
|
||||||
|
sb << "C";
|
||||||
|
}
|
||||||
|
if (flags.has_pending_error()) {
|
||||||
|
sb << "E";
|
||||||
|
}
|
||||||
|
return sb << "]";
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace td
|
} // namespace td
|
122
tdutils/td/utils/port/PollFlags.h
Normal file
122
tdutils/td/utils/port/PollFlags.h
Normal file
@ -0,0 +1,122 @@
|
|||||||
|
//
|
||||||
|
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2018
|
||||||
|
//
|
||||||
|
// Distributed under the Boost Software License, Version 1.0. (See accompanying
|
||||||
|
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
||||||
|
//
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include "td/utils/StringBuilder.h"
|
||||||
|
|
||||||
|
#include <atomic>
|
||||||
|
|
||||||
|
namespace td {
|
||||||
|
|
||||||
|
class PollFlags {
|
||||||
|
public:
|
||||||
|
using Raw = int32;
|
||||||
|
bool can_read() const {
|
||||||
|
return has_flags(Read());
|
||||||
|
}
|
||||||
|
bool can_write() const {
|
||||||
|
return has_flags(Write());
|
||||||
|
}
|
||||||
|
bool can_close() const {
|
||||||
|
return has_flags(Close());
|
||||||
|
}
|
||||||
|
bool has_pending_error() const {
|
||||||
|
return has_flags(Error());
|
||||||
|
}
|
||||||
|
void remove_flags(PollFlags flags) {
|
||||||
|
remove_flags(flags.raw());
|
||||||
|
}
|
||||||
|
bool add_flags(PollFlags flags) {
|
||||||
|
auto old_flags = flags_;
|
||||||
|
add_flags(flags.raw());
|
||||||
|
return old_flags != flags_;
|
||||||
|
}
|
||||||
|
bool has_flags(PollFlags flags) const {
|
||||||
|
return has_flags(flags.raw());
|
||||||
|
}
|
||||||
|
|
||||||
|
bool empty() const {
|
||||||
|
return flags_ == 0;
|
||||||
|
}
|
||||||
|
Raw raw() const {
|
||||||
|
return flags_;
|
||||||
|
}
|
||||||
|
static PollFlags from_raw(Raw raw) {
|
||||||
|
return PollFlags(raw);
|
||||||
|
}
|
||||||
|
PollFlags() = default;
|
||||||
|
|
||||||
|
bool operator==(const PollFlags &other) const {
|
||||||
|
return flags_ == other.flags_;
|
||||||
|
}
|
||||||
|
bool operator!=(const PollFlags &other) const {
|
||||||
|
return !(*this == other);
|
||||||
|
}
|
||||||
|
PollFlags operator|(const PollFlags other) const {
|
||||||
|
return from_raw(raw() | other.raw());
|
||||||
|
}
|
||||||
|
|
||||||
|
static PollFlags Write() {
|
||||||
|
return PollFlags(Flag::Write);
|
||||||
|
}
|
||||||
|
static PollFlags Error() {
|
||||||
|
return PollFlags(Flag::Error);
|
||||||
|
}
|
||||||
|
static PollFlags Close() {
|
||||||
|
return PollFlags(Flag::Close);
|
||||||
|
}
|
||||||
|
static PollFlags Read() {
|
||||||
|
return PollFlags(Flag::Read);
|
||||||
|
}
|
||||||
|
static PollFlags ReadWrite() {
|
||||||
|
return Read() | Write();
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
enum class Flag : Raw { Write = 0x001, Read = 0x002, Close = 0x004, Error = 0x008, None = 0 };
|
||||||
|
Raw flags_{static_cast<Raw>(Flag::None)};
|
||||||
|
|
||||||
|
explicit PollFlags(Raw raw) : flags_(raw) {
|
||||||
|
}
|
||||||
|
explicit PollFlags(Flag flag) : PollFlags(static_cast<Raw>(flag)) {
|
||||||
|
}
|
||||||
|
|
||||||
|
PollFlags &add_flags(Raw flags) {
|
||||||
|
flags_ |= flags;
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
PollFlags &remove_flags(Raw flags) {
|
||||||
|
flags_ &= ~flags;
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
bool has_flags(Raw flags) const {
|
||||||
|
return (flags_ & flags) == flags;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
StringBuilder &operator<<(StringBuilder &sb, PollFlags flags);
|
||||||
|
|
||||||
|
class PollFlagsSet {
|
||||||
|
public:
|
||||||
|
// write flags from any thread
|
||||||
|
// this is the only function that should be called from other threads
|
||||||
|
bool write_flags(PollFlags flags);
|
||||||
|
|
||||||
|
bool write_flags_local(PollFlags flags);
|
||||||
|
bool flush() const;
|
||||||
|
|
||||||
|
PollFlags read_flags() const;
|
||||||
|
PollFlags read_flags_local() const;
|
||||||
|
void clear_flags(PollFlags flags);
|
||||||
|
void clear();
|
||||||
|
|
||||||
|
private:
|
||||||
|
mutable std::atomic<PollFlags::Raw> to_write_{0};
|
||||||
|
mutable PollFlags flags_;
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace td
|
@ -8,138 +8,14 @@
|
|||||||
|
|
||||||
#include "td/utils/format.h"
|
#include "td/utils/format.h"
|
||||||
#include "td/utils/List.h"
|
#include "td/utils/List.h"
|
||||||
#include "td/utils/MovableValue.h"
|
|
||||||
#include "td/utils/Observer.h"
|
#include "td/utils/Observer.h"
|
||||||
#include "td/utils/port/detail/NativeFd.h"
|
#include "td/utils/port/detail/NativeFd.h"
|
||||||
|
#include "td/utils/port/PollFlags.h"
|
||||||
#include "td/utils/SpinLock.h"
|
#include "td/utils/SpinLock.h"
|
||||||
#include "td/utils/Status.h"
|
|
||||||
|
|
||||||
#include <atomic>
|
#include <atomic>
|
||||||
|
|
||||||
namespace td {
|
namespace td {
|
||||||
class ObserverBase;
|
|
||||||
|
|
||||||
class PollFlags {
|
|
||||||
public:
|
|
||||||
using Raw = int32;
|
|
||||||
bool can_read() const {
|
|
||||||
return has_flags(Read());
|
|
||||||
}
|
|
||||||
bool can_write() const {
|
|
||||||
return has_flags(Write());
|
|
||||||
}
|
|
||||||
bool can_close() const {
|
|
||||||
return has_flags(Close());
|
|
||||||
}
|
|
||||||
bool has_pending_error() const {
|
|
||||||
return has_flags(Error());
|
|
||||||
}
|
|
||||||
void remove_flags(PollFlags flags) {
|
|
||||||
remove_flags(flags.raw());
|
|
||||||
}
|
|
||||||
bool add_flags(PollFlags flags) {
|
|
||||||
auto old_flags = flags_;
|
|
||||||
add_flags(flags.raw());
|
|
||||||
return old_flags != flags_;
|
|
||||||
}
|
|
||||||
bool has_flags(PollFlags flags) const {
|
|
||||||
return has_flags(flags.raw());
|
|
||||||
}
|
|
||||||
|
|
||||||
bool empty() const {
|
|
||||||
return flags_ == 0;
|
|
||||||
}
|
|
||||||
Raw raw() const {
|
|
||||||
return flags_;
|
|
||||||
}
|
|
||||||
static PollFlags from_raw(Raw raw) {
|
|
||||||
return PollFlags(raw);
|
|
||||||
}
|
|
||||||
PollFlags() = default;
|
|
||||||
|
|
||||||
bool operator==(const PollFlags &other) const {
|
|
||||||
return flags_ == other.flags_;
|
|
||||||
}
|
|
||||||
bool operator!=(const PollFlags &other) const {
|
|
||||||
return !(*this == other);
|
|
||||||
}
|
|
||||||
PollFlags operator|(const PollFlags other) const {
|
|
||||||
return from_raw(raw() | other.raw());
|
|
||||||
}
|
|
||||||
|
|
||||||
static PollFlags Write() {
|
|
||||||
return PollFlags(Flag::Write);
|
|
||||||
}
|
|
||||||
static PollFlags Error() {
|
|
||||||
return PollFlags(Flag::Error);
|
|
||||||
}
|
|
||||||
static PollFlags Close() {
|
|
||||||
return PollFlags(Flag::Close);
|
|
||||||
}
|
|
||||||
static PollFlags Read() {
|
|
||||||
return PollFlags(Flag::Read);
|
|
||||||
}
|
|
||||||
static PollFlags ReadWrite() {
|
|
||||||
return Read() | Write();
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
enum class Flag : Raw { Write = 0x001, Read = 0x002, Close = 0x004, Error = 0x008, None = 0 };
|
|
||||||
Raw flags_{static_cast<Raw>(Flag::None)};
|
|
||||||
|
|
||||||
explicit PollFlags(Raw raw) : flags_(raw) {
|
|
||||||
}
|
|
||||||
explicit PollFlags(Flag flag) : PollFlags(static_cast<Raw>(flag)) {
|
|
||||||
}
|
|
||||||
|
|
||||||
PollFlags &add_flags(Raw flags) {
|
|
||||||
flags_ |= flags;
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
PollFlags &remove_flags(Raw flags) {
|
|
||||||
flags_ &= ~flags;
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
bool has_flags(Raw flags) const {
|
|
||||||
return (flags_ & flags) == flags;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
inline StringBuilder &operator<<(StringBuilder &sb, PollFlags flags) {
|
|
||||||
sb << "[";
|
|
||||||
if (flags.can_read()) {
|
|
||||||
sb << "R";
|
|
||||||
}
|
|
||||||
if (flags.can_write()) {
|
|
||||||
sb << "W";
|
|
||||||
}
|
|
||||||
if (flags.can_close()) {
|
|
||||||
sb << "C";
|
|
||||||
}
|
|
||||||
if (flags.has_pending_error()) {
|
|
||||||
sb << "E";
|
|
||||||
}
|
|
||||||
return sb << "]";
|
|
||||||
}
|
|
||||||
|
|
||||||
class PollFlagsSet {
|
|
||||||
public:
|
|
||||||
// write flags from any thread
|
|
||||||
// this is the only function that should be called from other threads
|
|
||||||
bool write_flags(PollFlags flags);
|
|
||||||
|
|
||||||
bool write_flags_local(PollFlags flags);
|
|
||||||
bool flush() const;
|
|
||||||
|
|
||||||
PollFlags read_flags() const;
|
|
||||||
PollFlags read_flags_local() const;
|
|
||||||
void clear_flags(PollFlags flags);
|
|
||||||
void clear();
|
|
||||||
|
|
||||||
private:
|
|
||||||
mutable std::atomic<PollFlags::Raw> to_write_{0};
|
|
||||||
mutable PollFlags flags_;
|
|
||||||
};
|
|
||||||
|
|
||||||
class PollableFdInfo;
|
class PollableFdInfo;
|
||||||
class PollableFdInfoUnlock {
|
class PollableFdInfoUnlock {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user