sleeping_clients.push_back(client);
}
+void Stream::add_data(const char *data, ssize_t bytes)
+{
+ size_t pos = bytes_received % backlog_size;
+ bytes_received += bytes;
+
+ if (pos + bytes > backlog_size) {
+ ssize_t to_copy = backlog_size - pos;
+ while (to_copy > 0) {
+ int ret = pwrite(data_fd, data, to_copy, pos);
+ if (ret == -1 && errno == EINTR) {
+ continue;
+ }
+ if (ret == -1) {
+ perror("pwrite");
+ // Dazed and confused, but trying to continue...
+ break;
+ }
+ pos += ret;
+ data += ret;
+ to_copy -= ret;
+ bytes -= ret;
+ }
+ pos = 0;
+ }
+
+ while (bytes > 0) {
+ int ret = pwrite(data_fd, data, bytes, pos);
+ if (ret == -1 && errno == EINTR) {
+ continue;
+ }
+ if (ret == -1) {
+ perror("pwrite");
+ // Dazed and confused, but trying to continue...
+ break;
+ }
+ pos += ret;
+ data += ret;
+ bytes -= ret;
+ }
+
+ wake_up_all_clients();
+}
+
void Stream::wake_up_all_clients()
{
if (to_process.empty()) {