#define BACKLOG_SIZE 1048576
#define EPOLL_MAX_EVENTS 8192
#define EPOLL_TIMEOUT_MS 20
#define BACKLOG_SIZE 1048576
#define EPOLL_MAX_EVENTS 8192
#define EPOLL_TIMEOUT_MS 20
// Put client to sleep, since there is no more data for it; we will on
// longer listen on POLLOUT until we get more data. Also, it will be put
// in the list of clients to wake up when we do.
// Put client to sleep, since there is no more data for it; we will on
// longer listen on POLLOUT until we get more data. Also, it will be put
// in the list of clients to wake up when we do.
// Get the list of all currently connected clients.
std::vector<ClientStats> get_client_stats() const;
// Set header (both HTTP header and any stream headers) for the given stream.
void set_header(const std::string &stream_id, const std::string &header);
// Get the list of all currently connected clients.
std::vector<ClientStats> get_client_stats() const;
// Set header (both HTTP header and any stream headers) for the given stream.
void set_header(const std::string &stream_id, const std::string &header);
// These will be deferred until the next time an iteration in do_work() happens,
// and the order between them are undefined.
// XXX: header should ideally be ordered with respect to data.
// These will be deferred until the next time an iteration in do_work() happens,
// and the order between them are undefined.
// XXX: header should ideally be ordered with respect to data.
// Mutex protecting queued_data only. Note that if you want to hold both this
// and <mutex> below, you will need to take <mutex> before this one.
mutable pthread_mutex_t queued_data_mutex;
// Mutex protecting queued_data only. Note that if you want to hold both this
// and <mutex> below, you will need to take <mutex> before this one.
mutable pthread_mutex_t queued_data_mutex;
// Map from stream ID to stream.
std::map<std::string, Stream *> streams;
// Map from stream ID to stream.
std::map<std::string, Stream *> streams;
// Process a client; read and write data as far as we can.
// After this call, one of these four is true:
// Process a client; read and write data as far as we can.
// After this call, one of these four is true: