1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
pub use self::custom_stream::CustomStream;
pub use self::equal_reader::EqualReader;
pub use self::messages_queue::MessagesQueue;
pub use self::refined_tcp_stream::RefinedTcpStream;
pub use self::sequential::{SequentialReaderBuilder, SequentialReader};
pub use self::sequential::{SequentialWriterBuilder, SequentialWriter};
pub use self::task_pool::TaskPool;
use std::str::FromStr;
mod custom_stream;
mod equal_reader;
mod messages_queue;
mod refined_tcp_stream;
mod sequential;
mod task_pool;
pub fn parse_header_value<'a>(input: &'a str) -> Vec<(&'a str, f32)> {
input.split(',').filter_map(|elem| {
let mut params = elem.split(';');
let t = params.next();
if t.is_none() { return None; }
let mut value = 1.0f32;
for p in params {
if p.trim_left().starts_with("q=") {
match FromStr::from_str(&p.trim_left()[2..].trim()) {
Ok(val) => { value = val; break },
_ => ()
}
}
}
Some((t.unwrap().trim(), value))
}).collect()
}
#[cfg(test)]
mod test {
#[test]
fn test_parse_header() {
let result = super::parse_header_value("text/html, text/plain; q=1.5 , image/png ; q=2.0");
assert_eq!(result.len(), 3);
assert_eq!(result[0].0, "text/html");
assert_eq!(result[0].1, 1.0);
assert_eq!(result[1].0, "text/plain");
assert_eq!(result[1].1, 1.5);
assert_eq!(result[2].0, "image/png");
assert_eq!(result[2].1, 2.0);
}
}