X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=httpd.h;h=73410fd427e642cb178f83ba5095318216223ba0;hb=b987f5b45720dcaf6582d1b9f9f7c18537df47ab;hp=21d8746172adc5231820a8c6a676d6bf08ef8ff0;hpb=8348925c4cb0d7a73b07db03c6bc6d55fa0631b8;p=nageru diff --git a/httpd.h b/httpd.h index 21d8746..73410fd 100644 --- a/httpd.h +++ b/httpd.h @@ -15,10 +15,12 @@ #include struct MHD_Connection; +struct MHD_Daemon; class HTTPD { public: HTTPD(); + ~HTTPD(); // Should be called before start(). void set_header(const std::string &data) { @@ -41,13 +43,15 @@ private: static void free_stream(void *cls); - static void request_completed_thunk(void *cls, struct MHD_Connection *connection, void **con_cls, enum MHD_RequestTerminationCode toe); - - void request_completed(struct MHD_Connection *connection, void **con_cls, enum MHD_RequestTerminationCode toe); - class Stream { public: + enum Framing { + FRAMING_RAW, + FRAMING_METACUBE + }; + Stream(HTTPD *parent, Framing framing) : parent(parent), framing(framing) {} + static ssize_t reader_callback_thunk(void *cls, uint64_t pos, char *buf, size_t max); ssize_t reader_callback(uint64_t pos, char *buf, size_t max); @@ -57,15 +61,22 @@ private: DATA_TYPE_OTHER }; void add_data(const char *buf, size_t size, DataType data_type); + void stop(); + HTTPD *get_parent() const { return parent; } private: + HTTPD *parent; + Framing framing; + std::mutex buffer_mutex; + bool should_quit = false; // Under . std::condition_variable has_buffered_data; - std::deque buffered_data; // Protected by . + std::deque buffered_data; // Protected by . size_t used_of_buffered_data = 0; // How many bytes of the first element of that is already used. Protected by . size_t seen_keyframe = false; }; + MHD_Daemon *mhd = nullptr; std::mutex streams_mutex; std::set streams; // Not owned. std::string header;