nghttp2_submit_data2
Synopsis
#include <nghttp2/nghttp2.h>
-
int nghttp2_submit_data2(nghttp2_session *session, uint8_t flags, int32_t stream_id, const nghttp2_data_provider2 *data_prd)
Submits one or more DATA frames to the stream stream_id. The data to be sent are provided by data_prd. If flags contains
nghttp2_flag.NGHTTP2_FLAG_END_STREAM
, the last DATA frame has END_STREAM flag set.This function does not take ownership of the data_prd. The function copies the members of the data_prd.
This function returns 0 if it succeeds, or one of the following negative error codes:
nghttp2_error.NGHTTP2_ERR_NOMEM
Out of memory.
nghttp2_error.NGHTTP2_ERR_DATA_EXIST
DATA or HEADERS has been already submitted and not fully processed yet.
nghttp2_error.NGHTTP2_ERR_INVALID_ARGUMENT
The stream_id is 0.
nghttp2_error.NGHTTP2_ERR_STREAM_CLOSED
The stream was already closed; or the stream_id is invalid.
Note
Currently, only one DATA or HEADERS is allowed for a stream at a time. Submitting these frames more than once before first DATA or HEADERS is finished results in
nghttp2_error.NGHTTP2_ERR_DATA_EXIST
error code. The earliest callback which tells that previous frame is done isnghttp2_on_frame_send_callback
. In side that callback, new data can be submitted usingnghttp2_submit_data2()
. Of course, all data except for last one must not havenghttp2_flag.NGHTTP2_FLAG_END_STREAM
flag set in flags. This sounds a bit complicated, and we recommend to usenghttp2_submit_request2()
andnghttp2_submit_response2()
to avoid this cascading issue. The experience shows that for HTTP use, these two functions are enough to implement both client and server.