cogo_http/header/common/transfer_encoding.rs
1use crate::header::Encoding;
2
3header! {
4 /// `Transfer-Encoding` header, defined in
5 /// [RFC7230](http://tools.ietf.org/html/rfc7230#section-3.3.1)
6 ///
7 /// The `Transfer-Encoding` header field lists the transfer coding names
8 /// corresponding to the sequence of transfer codings that have been (or
9 /// will be) applied to the payload body in order to form the message
10 /// body.
11 ///
12 /// # ABNF
13 /// ```plain
14 /// Transfer-Encoding = 1#transfer-coding
15 /// ```
16 ///
17 /// # Example values
18 /// * `gzip, chunked`
19 ///
20 /// # Example
21 /// ```
22 /// use cogo_http::header::{Headers, TransferEncoding, Encoding};
23 ///
24 /// let mut headers = Headers::new();
25 /// headers.set(
26 /// TransferEncoding(vec![
27 /// Encoding::Gzip,
28 /// Encoding::Chunked,
29 /// ])
30 /// );
31 /// ```
32 (TransferEncoding, "Transfer-Encoding") => (Encoding)+
33
34 transfer_encoding {
35 test_header!(
36 test1,
37 vec![b"gzip, chunked"],
38 Some(HeaderField(
39 vec![Encoding::Gzip, Encoding::Chunked]
40 )));
41 // Issue: #683
42 test_header!(
43 test2,
44 vec![b"chunked", b"chunked"],
45 Some(HeaderField(
46 vec![Encoding::Chunked, Encoding::Chunked]
47 )));
48
49 }
50}
51
52bench_header!(normal, TransferEncoding, { vec![b"chunked, gzip".to_vec()] });
53bench_header!(ext, TransferEncoding, { vec![b"ext".to_vec()] });