X-Git-Url: https://git.sesse.net/?p=cubemap;a=blobdiff_plain;f=httpinput.h;h=4ee5ede87542866182133f23b40b2bb12b8735c7;hp=0e29453fb4bdab7aabcc6f7f092940bcf7d8b353;hb=d5f3f941faaf113936113fc2105bf59913e9125e;hpb=b05c2965d3d5bfc4f24f17a27716a69ddf03a3cc diff --git a/httpinput.h b/httpinput.h index 0e29453..4ee5ede 100644 --- a/httpinput.h +++ b/httpinput.h @@ -1,13 +1,14 @@ #ifndef _HTTPINPUT_H #define _HTTPINPUT_H 1 -#include #include +#include #include #include #include "input.h" #include "metacube2.h" +#include "stream.h" class InputProto; @@ -87,27 +88,33 @@ private: // If starts with a Metacube header, // this is true. - bool has_metacube_header; + bool has_metacube_header = false; // The socket we are downloading on (or -1). - int sock; + int sock = -1; // Mutex protecting . - mutable pthread_mutex_t stats_mutex; + mutable std::mutex stats_mutex; // The current statistics for this connection. Protected by . InputStats stats; // Number of (started) connection attempts since last data byte was successfully read. - unsigned num_connection_attempts; + unsigned num_connection_attempts = 0; // If set, don't log anything related to connections. // (Only set if we've had enough unsuccessful connection attempts.) - bool suppress_logging; + bool suppress_logging = false; // Last time we made a connection with logging enabled. // (Initially at some point before the epoch.) - timespec last_verbose_connection; + timespec last_verbose_connection { -3600, 0 }; + + // If we've received a Metacube2 PTS metadata block, it belongs to the + // next regular block we receive, and is stored here in the meantime. + // If we haven't received one yet (or we've already received the + // corresponding data block), this is empty, ie., timebase_num == 0. + RationalPTS next_block_pts; }; #endif // !defined(_HTTPINPUT_H)