[−][src]Struct mime_guess::Mime
Mime, or Media Type. Encapsulates common registers types.
Consider that a traditional mime type contains a "top level type", a "sub level type", and 0-N "parameters". And they're all strings. Strings everywhere. Strings mean typos. Rust has type safety. We should use types!
So, Mime bundles together this data into types so the compiler can catch your typos.
This improves things so you use match without Strings:
use mime::{Mime, TopLevel, SubLevel}; let mime: Mime = "application/json".parse().unwrap(); match mime { Mime(TopLevel::Application, SubLevel::Json, _) => println!("matched json!"), _ => () }
Methods
impl<P> Mime<P> where
P: AsRef<[(Attr, Value)]>,
[src][−]
P: AsRef<[(Attr, Value)]>,
Trait Implementations
impl<T> Hash for Mime<T> where
T: AsRef<[(Attr, Value)]> + Hash,
[src][+]
T: AsRef<[(Attr, Value)]> + Hash,
impl FromStr for Mime<Vec<(Attr, Value)>>
[src][+]
impl<T> Display for Mime<T> where
T: AsRef<[(Attr, Value)]>,
[src][+]
T: AsRef<[(Attr, Value)]>,
impl<T> Eq for Mime<T> where
T: Eq + AsRef<[(Attr, Value)]>,
[src]
T: Eq + AsRef<[(Attr, Value)]>,
impl<LHS, RHS> PartialEq<Mime<RHS>> for Mime<LHS> where
LHS: AsRef<[(Attr, Value)]>,
RHS: AsRef<[(Attr, Value)]>,
[src][+]
LHS: AsRef<[(Attr, Value)]>,
RHS: AsRef<[(Attr, Value)]>,
impl<T> Clone for Mime<T> where
T: Clone + AsRef<[(Attr, Value)]>,
[src][+]
T: Clone + AsRef<[(Attr, Value)]>,
impl<T> Ord for Mime<T> where
T: Ord + AsRef<[(Attr, Value)]>,
[src][+]
T: Ord + AsRef<[(Attr, Value)]>,
impl<T> PartialOrd<Mime<T>> for Mime<T> where
T: PartialOrd<T> + AsRef<[(Attr, Value)]>,
[src][+]
T: PartialOrd<T> + AsRef<[(Attr, Value)]>,
impl<T> Debug for Mime<T> where
T: AsRef<[(Attr, Value)]> + Debug,
[src][+]
T: AsRef<[(Attr, Value)]> + Debug,
Auto Trait Implementations
Blanket Implementations
impl<T> ToString for T where
T: Display + ?Sized,
[src][−]
T: Display + ?Sized,
impl<T> From for T
[src][−]
impl<T, U> Into for T where
U: From<T>,
[src][−]
U: From<T>,
impl<T> ToOwned for T where
T: Clone,
[src][−]
T: Clone,
impl<T, U> TryFrom for T where
T: From<U>,
[src][−]
T: From<U>,
type Error = !
🔬 This is a nightly-only experimental API. (
try_from
)The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src][−]
impl<T> Borrow for T where
T: ?Sized,
[src][−]
T: ?Sized,
impl<T> BorrowMut for T where
T: ?Sized,
[src][−]
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T
[src][−]
impl<T, U> TryInto for T where
U: TryFrom<T>,
[src][−]
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
🔬 This is a nightly-only experimental API. (
try_from
)The type returned in the event of a conversion error.
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
[src][−]
impl<T> Any for T where
T: 'static + ?Sized,
[src][−]
T: 'static + ?Sized,