Commit 1e3089ff authored by Max Kellermann's avatar Max Kellermann Committed by Max Kellermann

curl/Request: move struct Pause to class CurlResponseHandler

parent 5d7ff150
......@@ -309,7 +309,7 @@ CurlInputStream::OnData(ConstBuffer<void> data)
if (data.size > GetBufferSpace()) {
AsyncInputStream::Pause();
throw CurlRequest::Pause();
throw CurlResponseHandler::Pause{};
}
AppendToBuffer(data.data, data.size);
......
......@@ -44,6 +44,13 @@
class CurlResponseHandler {
public:
/**
* OnData() shall throw this to pause the stream. Call
* CurlEasy::Unpause() or CurlRequest::Resume() to resume the
* transfer.
*/
struct Pause {};
/**
* Status line and headers have been received.
*/
virtual void OnHeaders(unsigned status,
......@@ -51,6 +58,8 @@ public:
/**
* Response body data has been received.
*
* May throw #Pause.
*/
virtual void OnData(ConstBuffer<void> data) = 0;
......
......@@ -241,7 +241,7 @@ CurlRequest::DataReceived(const void *ptr, size_t received_size) noexcept
FinishHeaders();
handler.OnData({ptr, received_size});
return received_size;
} catch (Pause) {
} catch (CurlResponseHandler::Pause) {
return CURL_WRITEFUNC_PAUSE;
} catch (...) {
state = State::CLOSED;
......
......@@ -146,12 +146,6 @@ public:
easy.SetRequestBody(data, size);
}
/**
* CurlResponseHandler::OnData() shall throw this to pause the
* stream. Call Resume() to resume the transfer.
*/
struct Pause {};
void Resume() noexcept;
/**
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment