31
31
libcurl) */
32
32
#if (defined(_WIN32 ) || defined(__WIN32__ )) && !defined(WIN32 )
33
33
# define WIN32
34
- #endif
34
+ #endif /* (defined(_WIN32) || defined(__WIN32__)) && !defined(WIN32) */
35
35
36
36
#ifdef __cplusplus
37
37
extern "C" {
38
- #endif
38
+ #endif /* defined(__cplusplus) */
39
39
40
40
#include <stdlib.h>
41
41
#if defined(_MSC_VER ) && (_MSC_VER < 1800 )
42
42
/* MSVC < 2013 does not have inttypes.h because it is not C99
43
43
compliant. See compiler macros and version number in
44
44
https://sourceforge.net/p/predef/wiki/Compilers/ */
45
45
# include <stdint.h>
46
- #else /* !defined(_MSC_VER) || (_MSC_VER >= 1800) */
46
+ #else /* !( defined(_MSC_VER) && (_MSC_VER < 1800) ) */
47
47
# include <inttypes.h>
48
- #endif /* !defined(_MSC_VER) || (_MSC_VER >= 1800) */
48
+ #endif /* !( defined(_MSC_VER) && (_MSC_VER < 1800) ) */
49
49
#include <sys/types.h>
50
50
#include <stdarg.h>
51
51
#include <stddef.h>
@@ -57,22 +57,22 @@ extern "C" {
57
57
#elif defined(WIN32 )
58
58
# ifdef BUILDING_NGHTTP3
59
59
# define NGHTTP3_EXTERN __declspec(dllexport)
60
- # else /* !BUILDING_NGHTTP3 */
60
+ # else /* !defined( BUILDING_NGHTTP3) */
61
61
# define NGHTTP3_EXTERN __declspec(dllimport)
62
- # endif /* !BUILDING_NGHTTP3 */
63
- #else /* !defined(WIN32) */
62
+ # endif /* !defined( BUILDING_NGHTTP3) */
63
+ #else /* !( defined(NGHTTP3_STATICLIB) || defined( WIN32) ) */
64
64
# ifdef BUILDING_NGHTTP3
65
65
# define NGHTTP3_EXTERN __attribute__((visibility("default")))
66
- # else /* !BUILDING_NGHTTP3 */
66
+ # else /* !defined( BUILDING_NGHTTP3) */
67
67
# define NGHTTP3_EXTERN
68
- # endif /* !BUILDING_NGHTTP3 */
69
- #endif /* !defined(WIN32) */
68
+ # endif /* !defined( BUILDING_NGHTTP3) */
69
+ #endif /* !( defined(NGHTTP3_STATICLIB) || defined( WIN32) ) */
70
70
71
71
#ifdef _MSC_VER
72
72
# define NGHTTP3_ALIGN (N ) __declspec(align(N))
73
- #else /* !_MSC_VER */
73
+ #else /* !defined( _MSC_VER) */
74
74
# define NGHTTP3_ALIGN (N ) __attribute__((aligned(N)))
75
- #endif /* !_MSC_VER */
75
+ #endif /* !defined( _MSC_VER) */
76
76
77
77
/**
78
78
* @typedef
@@ -624,7 +624,7 @@ typedef struct nghttp3_buf {
624
624
*/
625
625
uint8_t * end ;
626
626
/**
627
- * :member:`pos` pointers to the start of data. Typically, this
627
+ * :member:`pos` points to the start of data. Typically, this
628
628
* points to the address that next data should be read. Initially,
629
629
* it points to :member:`begin`.
630
630
*/
@@ -1161,8 +1161,8 @@ NGHTTP3_EXTERN void nghttp3_qpack_encoder_del(nghttp3_qpack_encoder *encoder);
1161
1161
* anymore.
1162
1162
*/
1163
1163
NGHTTP3_EXTERN int nghttp3_qpack_encoder_encode (
1164
- nghttp3_qpack_encoder * encoder , nghttp3_buf * pbuf , nghttp3_buf * rbuf ,
1165
- nghttp3_buf * ebuf , int64_t stream_id , const nghttp3_nv * nva , size_t nvlen );
1164
+ nghttp3_qpack_encoder * encoder , nghttp3_buf * pbuf , nghttp3_buf * rbuf ,
1165
+ nghttp3_buf * ebuf , int64_t stream_id , const nghttp3_nv * nva , size_t nvlen );
1166
1166
1167
1167
/**
1168
1168
* @function
@@ -1182,7 +1182,7 @@ NGHTTP3_EXTERN int nghttp3_qpack_encoder_encode(
1182
1182
* |encoder| is unable to process input because it is malformed.
1183
1183
*/
1184
1184
NGHTTP3_EXTERN nghttp3_ssize nghttp3_qpack_encoder_read_decoder (
1185
- nghttp3_qpack_encoder * encoder , const uint8_t * src , size_t srclen );
1185
+ nghttp3_qpack_encoder * encoder , const uint8_t * src , size_t srclen );
1186
1186
1187
1187
/**
1188
1188
* @function
@@ -1343,7 +1343,7 @@ NGHTTP3_EXTERN void nghttp3_qpack_decoder_del(nghttp3_qpack_decoder *decoder);
1343
1343
* Could not interpret encoder stream instruction.
1344
1344
*/
1345
1345
NGHTTP3_EXTERN nghttp3_ssize nghttp3_qpack_decoder_read_encoder (
1346
- nghttp3_qpack_decoder * decoder , const uint8_t * src , size_t srclen );
1346
+ nghttp3_qpack_decoder * decoder , const uint8_t * src , size_t srclen );
1347
1347
1348
1348
/**
1349
1349
* @function
@@ -1436,9 +1436,9 @@ nghttp3_qpack_decoder_get_icnt(const nghttp3_qpack_decoder *decoder);
1436
1436
* HTTP field is too large.
1437
1437
*/
1438
1438
NGHTTP3_EXTERN nghttp3_ssize nghttp3_qpack_decoder_read_request (
1439
- nghttp3_qpack_decoder * decoder , nghttp3_qpack_stream_context * sctx ,
1440
- nghttp3_qpack_nv * nv , uint8_t * pflags , const uint8_t * src , size_t srclen ,
1441
- int fin );
1439
+ nghttp3_qpack_decoder * decoder , nghttp3_qpack_stream_context * sctx ,
1440
+ nghttp3_qpack_nv * nv , uint8_t * pflags , const uint8_t * src , size_t srclen ,
1441
+ int fin );
1442
1442
1443
1443
/**
1444
1444
* @function
@@ -1568,7 +1568,7 @@ typedef void (*nghttp3_debug_vprintf_callback)(const char *format,
1568
1568
* times because this is important.
1569
1569
*/
1570
1570
NGHTTP3_EXTERN void nghttp3_set_debug_vprintf_callback (
1571
- nghttp3_debug_vprintf_callback debug_vprintf_callback );
1571
+ nghttp3_debug_vprintf_callback debug_vprintf_callback );
1572
1572
1573
1573
/**
1574
1574
* @macrosection
@@ -2118,9 +2118,10 @@ NGHTTP3_EXTERN int nghttp3_conn_bind_qpack_streams(nghttp3_conn *conn,
2118
2118
* :macro:`NGHTTP3_ERR_CALLBACK_FAILURE`
2119
2119
* User callback failed.
2120
2120
*
2121
- * It may return the other error codes. In general, the negative
2122
- * error code means that |conn| encountered a connection error, and
2123
- * the connection should be closed.
2121
+ * It may return the other error codes. The negative error code means
2122
+ * that |conn| encountered a connection error, and the connection must
2123
+ * be closed. Calling nghttp3 API other than `nghttp3_conn_del`
2124
+ * causes undefined behavior.
2124
2125
*/
2125
2126
NGHTTP3_EXTERN nghttp3_ssize nghttp3_conn_read_stream (nghttp3_conn * conn ,
2126
2127
int64_t stream_id ,
@@ -2152,9 +2153,10 @@ NGHTTP3_EXTERN nghttp3_ssize nghttp3_conn_read_stream(nghttp3_conn *conn,
2152
2153
* :macro:`NGHTTP3_ERR_CALLBACK_FAILURE`
2153
2154
* User callback failed.
2154
2155
*
2155
- * It may return the other error codes. In general, the negative
2156
- * error code means that |conn| encountered a connection error, and
2157
- * the connection should be closed.
2156
+ * It may return the other error codes. The negative error code means
2157
+ * that |conn| encountered a connection error, and the connection must
2158
+ * be closed. Calling nghttp3 API other than `nghttp3_conn_del`
2159
+ * causes undefined behavior.
2158
2160
*/
2159
2161
NGHTTP3_EXTERN nghttp3_ssize nghttp3_conn_writev_stream (nghttp3_conn * conn ,
2160
2162
int64_t * pstream_id ,
@@ -2198,6 +2200,9 @@ NGHTTP3_EXTERN int nghttp3_conn_add_write_offset(nghttp3_conn *conn,
2198
2200
* If a stream denoted by |stream_id| is not found, this function
2199
2201
* returns 0.
2200
2202
*
2203
+ * Alternatively, `nghttp3_conn_update_ack_offset` can be used to
2204
+ * accomplish the same thing.
2205
+ *
2201
2206
* This function returns 0 if it succeeds, or one of the following
2202
2207
* negative error codes:
2203
2208
*
@@ -2207,6 +2212,31 @@ NGHTTP3_EXTERN int nghttp3_conn_add_write_offset(nghttp3_conn *conn,
2207
2212
NGHTTP3_EXTERN int nghttp3_conn_add_ack_offset (nghttp3_conn * conn ,
2208
2213
int64_t stream_id , uint64_t n );
2209
2214
2215
+ /**
2216
+ * @function
2217
+ *
2218
+ * `nghttp3_conn_update_ack_offset` tells |conn| that QUIC stack has
2219
+ * acknowledged the stream data up to |offset| for a stream denoted by
2220
+ * |stream_id|.
2221
+ *
2222
+ * If a stream denoted by |stream_id| is not found, this function
2223
+ * returns 0.
2224
+ *
2225
+ * Alternatively, `nghttp3_conn_add_ack_offset` can be used to
2226
+ * accomplish the same thing.
2227
+ *
2228
+ * This function returns 0 if it succeeds, or one of the following
2229
+ * negative error codes:
2230
+ *
2231
+ * :macro:`NGHTTP3_ERR_INVALID_ARGUMENT`
2232
+ * |offset| is less than the number of bytes acknowledged so far.
2233
+ * :macro:`NGHTTP3_ERR_CALLBACK_FAILURE`
2234
+ * User callback failed.
2235
+ */
2236
+ NGHTTP3_EXTERN int nghttp3_conn_update_ack_offset (nghttp3_conn * conn ,
2237
+ int64_t stream_id ,
2238
+ uint64_t offset );
2239
+
2210
2240
/**
2211
2241
* @function
2212
2242
*
@@ -2314,9 +2344,9 @@ NGHTTP3_EXTERN int nghttp3_conn_resume_stream(nghttp3_conn *conn,
2314
2344
/**
2315
2345
* @function
2316
2346
*
2317
- * `nghttp3_conn_close_stream` closes stream identified by
2318
- * |stream_id|. QUIC application error code |app_error_code| is the
2319
- * reason of the closure.
2347
+ * `nghttp3_conn_close_stream` tells the library that a stream
2348
+ * identified by |stream_id| has been closed . QUIC application error
2349
+ * code |app_error_code| is the reason of the closure.
2320
2350
*
2321
2351
* This function returns 0 if it succeeds, or one of the following
2322
2352
* negative error codes:
@@ -2419,8 +2449,8 @@ nghttp3_conn_set_max_concurrent_streams(nghttp3_conn *conn,
2419
2449
* stream.
2420
2450
*/
2421
2451
typedef nghttp3_ssize (* nghttp3_read_data_callback )(
2422
- nghttp3_conn * conn , int64_t stream_id , nghttp3_vec * vec , size_t veccnt ,
2423
- uint32_t * pflags , void * conn_user_data , void * stream_user_data );
2452
+ nghttp3_conn * conn , int64_t stream_id , nghttp3_vec * vec , size_t veccnt ,
2453
+ uint32_t * pflags , void * conn_user_data , void * stream_user_data );
2424
2454
2425
2455
/**
2426
2456
* @struct
@@ -2460,8 +2490,8 @@ typedef struct nghttp3_data_reader {
2460
2490
* Out of memory.
2461
2491
*/
2462
2492
NGHTTP3_EXTERN int nghttp3_conn_submit_request (
2463
- nghttp3_conn * conn , int64_t stream_id , const nghttp3_nv * nva , size_t nvlen ,
2464
- const nghttp3_data_reader * dr , void * stream_user_data );
2493
+ nghttp3_conn * conn , int64_t stream_id , const nghttp3_nv * nva , size_t nvlen ,
2494
+ const nghttp3_data_reader * dr , void * stream_user_data );
2465
2495
2466
2496
/**
2467
2497
* @function
@@ -2667,7 +2697,7 @@ typedef struct NGHTTP3_ALIGN(8) nghttp3_pri {
2667
2697
* Stream not found.
2668
2698
*/
2669
2699
NGHTTP3_EXTERN int nghttp3_conn_get_stream_priority_versioned (
2670
- nghttp3_conn * conn , int pri_version , nghttp3_pri * dest , int64_t stream_id );
2700
+ nghttp3_conn * conn , int pri_version , nghttp3_pri * dest , int64_t stream_id );
2671
2701
2672
2702
/**
2673
2703
* @function
@@ -2720,8 +2750,8 @@ NGHTTP3_EXTERN int nghttp3_conn_set_client_stream_priority(nghttp3_conn *conn,
2720
2750
* Out of memory.
2721
2751
*/
2722
2752
NGHTTP3_EXTERN int nghttp3_conn_set_server_stream_priority_versioned (
2723
- nghttp3_conn * conn , int64_t stream_id , int pri_version ,
2724
- const nghttp3_pri * pri );
2753
+ nghttp3_conn * conn , int64_t stream_id , int pri_version ,
2754
+ const nghttp3_pri * pri );
2725
2755
2726
2756
/**
2727
2757
* @function
@@ -2884,7 +2914,7 @@ NGHTTP3_EXTERN int nghttp3_err_is_fatal(int liberr);
2884
2914
*/
2885
2915
#define nghttp3_conn_set_server_stream_priority (CONN , STREAM_ID , PRI ) \
2886
2916
nghttp3_conn_set_server_stream_priority_versioned( \
2887
- (CONN), (STREAM_ID), NGHTTP3_PRI_VERSION, (PRI))
2917
+ (CONN), (STREAM_ID), NGHTTP3_PRI_VERSION, (PRI))
2888
2918
2889
2919
/*
2890
2920
* `nghttp3_conn_get_stream_priority` is a wrapper around
@@ -2906,6 +2936,6 @@ NGHTTP3_EXTERN int nghttp3_err_is_fatal(int liberr);
2906
2936
2907
2937
#ifdef __cplusplus
2908
2938
}
2909
- #endif
2939
+ #endif /* defined(__cplusplus) */
2910
2940
2911
- #endif /* NGHTTP3_H */
2941
+ #endif /* !defined( NGHTTP3_H) */
0 commit comments