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 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130
pub use crate::p1::{Error, Result}; #[derive(Debug, PartialEq, Default)] pub struct Header(pub(crate) Vec<(String, String)>); impl Header { pub fn add(&mut self, name: &str, value: &str) { self.0.push((name.to_string(), value.to_string())) } pub fn bool_with_default(&self, name: &str, def: bool) -> Result<bool> { match self.bool(name) { Ok(b) => Ok(b), Err(Error::NotFound { key: _ }) => Ok(def), e => e, } } pub fn bool_optional(&self, name: &str) -> Result<Option<bool>> { match self.bool(name) { Ok(b) => Ok(Some(b)), Err(Error::NotFound { key: _ }) => Ok(None), Err(e) => Err(e), } } pub fn bool(&self, name: &str) -> Result<bool> { for (k, v) in self.0.iter() { if k == name { return if v == "true" || v == "false" { Ok(v == "true") } else { Err(Error::CantParseBool) }; } } Err(Error::NotFound { key: name.to_string(), }) } pub fn i32_with_default(&self, name: &str, def: i32) -> Result<i32> { match self.i32(name) { Ok(b) => Ok(b), Err(Error::NotFound { key: _ }) => Ok(def), e => e, } } pub fn i32_optional(&self, name: &str) -> Result<Option<i32>> { match self.i32(name) { Ok(b) => Ok(Some(b)), Err(Error::NotFound { key: _ }) => Ok(None), Err(e) => Err(e), } } pub fn i32(&self, name: &str) -> Result<i32> { for (k, v) in self.0.iter() { if k == name { return Ok(v.parse()?); } } Err(Error::NotFound { key: name.to_string(), }) } pub fn f64(&self, name: &str) -> Result<f64> { for (k, v) in self.0.iter() { if k == name { return Ok(v.parse()?); } } Err(Error::NotFound { key: name.to_string(), }) } pub fn str_with_default<'a>(&'a self, name: &str, def: &'a str) -> Result<&'a str> { match self.str(name) { Ok(b) => Ok(b), Err(Error::NotFound { key: _ }) => Ok(def), e => e, } } pub fn str_optional(&self, name: &str) -> Result<Option<&str>> { match self.str(name) { Ok(b) => Ok(Some(b)), Err(Error::NotFound { key: _ }) => Ok(None), Err(e) => Err(e), } } pub fn str(&self, name: &str) -> Result<&str> { for (k, v) in self.0.iter() { if k == name { return Ok(v.as_str()); } } Err(Error::NotFound { key: name.to_string(), }) } pub fn string(&self, name: &str) -> Result<String> { self.str(name).map(ToString::to_string) } pub fn string_optional(&self, name: &str) -> Result<Option<String>> { Ok(self.str_optional(name)?.map(ToString::to_string)) } pub fn string_with_default(&self, name: &str, def: &str) -> Result<String> { self.str_with_default(name, def).map(ToString::to_string) } pub fn get_map(&self) -> Result<std::collections::HashMap<String, String>> { let unique_keys: std::collections::HashSet<&String> = self.0.iter().map(|(x, _)| x).collect(); if unique_keys.len() != self.0.len() { return Err(Error::DuplicateKeys); } Ok(self.0.iter().map(|(x, y)| (x.to_string(), y.to_string())).collect()) } pub fn get(&self) -> &[(String, String)] { self.0.as_slice() } }