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()] });