X-Git-Url: https://git.sesse.net/?p=cubemap;a=blobdiff_plain;f=httpinput.cpp;h=9412e785b6b15fa41f889a6a6e6acc8fbde8dd86;hp=5fb55b378610e846f2d74f6074f82f1f95ee58b7;hb=924cf08c048e851227143c3f311bc17eb64a6319;hpb=6544fa0ec3f3a501bcb89ea977756911bd7f3ebd diff --git a/httpinput.cpp b/httpinput.cpp index 5fb55b3..9412e78 100644 --- a/httpinput.cpp +++ b/httpinput.cpp @@ -30,6 +30,19 @@ using namespace std; +namespace { + +string host_header(const string &host, const string &port) +{ + if (atoi(port.c_str()) == 80) { + return host; + } else { + return host + ":" + port; + } +} + +} // namespace + extern ServerPool *servers; HTTPInput::HTTPInput(const string &url, Input::Encoding encoding) @@ -339,7 +352,7 @@ void HTTPInput::do_work() state = CLOSING_SOCKET; } else { state = SENDING_REQUEST; - request = "GET " + path + " HTTP/1.0\r\nUser-Agent: cubemap\r\n\r\n"; + request = "GET " + path + " HTTP/1.0\r\nHost: " + host_header(host, port) + "\r\nUser-Agent: cubemap\r\n\r\n"; request_bytes_sent = 0; } @@ -490,7 +503,7 @@ void HTTPInput::process_data(char *ptr, size_t bytes) if (encoding == Input::INPUT_ENCODING_RAW) { for (size_t i = 0; i < stream_indices.size(); ++i) { - servers->add_data(stream_indices[i], ptr, bytes, SUITABLE_FOR_STREAM_START); + servers->add_data(stream_indices[i], ptr, bytes, /*metacube_flags=*/0); } return; } @@ -568,16 +581,9 @@ void HTTPInput::process_data(char *ptr, size_t bytes) for (size_t i = 0; i < stream_indices.size(); ++i) { servers->set_header(stream_indices[i], http_header, stream_header); } - } else { - StreamStartSuitability suitable_for_stream_start; - if (flags & METACUBE_FLAGS_NOT_SUITABLE_FOR_STREAM_START) { - suitable_for_stream_start = NOT_SUITABLE_FOR_STREAM_START; - } else { - suitable_for_stream_start = SUITABLE_FOR_STREAM_START; - } - for (size_t i = 0; i < stream_indices.size(); ++i) { - servers->add_data(stream_indices[i], inner_data, size, suitable_for_stream_start); - } + } + for (size_t i = 0; i < stream_indices.size(); ++i) { + servers->add_data(stream_indices[i], inner_data, size, flags); } // Consume the block. This isn't the most efficient way of dealing with things