Struct rocket::http::uri::Absolute [−][src]
pub struct Absolute<'a> { /* fields omitted */ }
Expand description
A URI with a scheme, authority, path, and query:
http://user:pass@domain.com:4444/path?query
.
Structure
The following diagram illustrates the syntactic structure of an absolute URI with all optional parts:
http://user:pass@domain.com:4444/path?query
|--| |-----------------------||---------|
scheme authority origin
The scheme part of the absolute URI and at least one of authority or origin are required.
Implementations
impl<'a> Absolute<'a>
[src]
impl<'a> Absolute<'a>
[src]pub fn parse(string: &'a str) -> Result<Absolute<'a>, Error<'a>>
[src]
pub fn parse(string: &'a str) -> Result<Absolute<'a>, Error<'a>>
[src]Parses the string string
into an Absolute
. Parsing will never
allocate. Returns an Error
if string
is not a valid absolute URI.
Example
use rocket::http::uri::Absolute; // Parse a valid authority URI. let uri = Absolute::parse("http://google.com").expect("valid URI"); assert_eq!(uri.scheme(), "http"); assert_eq!(uri.authority().unwrap().host(), "google.com"); assert_eq!(uri.origin(), None);
pub fn scheme(&self) -> &str
[src]
pub fn scheme(&self) -> &str
[src]Returns the scheme part of the absolute URI.
Example
use rocket::http::uri::Absolute; let uri = Absolute::parse("ftp://127.0.0.1").expect("valid URI"); assert_eq!(uri.scheme(), "ftp");
pub fn authority(&self) -> Option<&Authority<'a>>
[src]
pub fn authority(&self) -> Option<&Authority<'a>>
[src]Returns the authority part of the absolute URI, if there is one.
Example
use rocket::http::uri::Absolute; let uri = Absolute::parse("https://rocket.rs:80").expect("valid URI"); assert_eq!(uri.scheme(), "https"); let authority = uri.authority().unwrap(); assert_eq!(authority.host(), "rocket.rs"); assert_eq!(authority.port(), Some(80)); let uri = Absolute::parse("file:/web/home").expect("valid URI"); assert_eq!(uri.authority(), None);
pub fn origin(&self) -> Option<&Origin<'a>>
[src]
pub fn origin(&self) -> Option<&Origin<'a>>
[src]Returns the origin part of the absolute URI, if there is one.
Example
use rocket::http::uri::Absolute; let uri = Absolute::parse("file:/web/home.html?new").expect("valid URI"); assert_eq!(uri.scheme(), "file"); let origin = uri.origin().unwrap(); assert_eq!(origin.path(), "/web/home.html"); assert_eq!(origin.query(), Some("new")); let uri = Absolute::parse("https://rocket.rs").expect("valid URI"); assert_eq!(uri.origin(), None);
Trait Implementations
Auto Trait Implementations
impl<'a> !RefUnwindSafe for Absolute<'a>
impl<'a> Send for Absolute<'a>
impl<'a> Sync for Absolute<'a>
impl<'a> Unpin for Absolute<'a>
impl<'a> UnwindSafe for Absolute<'a>
Blanket Implementations
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]pub fn borrow_mut(&mut self) -> &mut T
[src]
pub fn borrow_mut(&mut self) -> &mut T
[src]Mutably borrows from an owned value. Read more
impl<T> IntoCollection<T> for T
[src]
impl<T> IntoCollection<T> for T
[src]pub fn into_collection<A>(self) -> SmallVec<A> where
A: Array<Item = T>,
[src]
pub fn into_collection<A>(self) -> SmallVec<A> where
A: Array<Item = T>,
[src]Converts self
into a collection.
pub fn mapped<U, F, A>(self, f: F) -> SmallVec<A> where
F: FnMut(T) -> U,
A: Array<Item = U>,
[src]
F: FnMut(T) -> U,
A: Array<Item = U>,
impl<T> Same<T> for T
impl<T> Same<T> for T
type Output = T
type Output = T
Should always be Self
impl<T> ToOwned for T where
T: Clone,
[src]
impl<T> ToOwned for T where
T: Clone,
[src]type Owned = T
type Owned = T
The resulting type after obtaining ownership.
pub fn to_owned(&self) -> T
[src]
pub fn to_owned(&self) -> T
[src]Creates owned data from borrowed data, usually by cloning. Read more
pub fn clone_into(&self, target: &mut T)
[src]
pub fn clone_into(&self, target: &mut T)
[src]🔬 This is a nightly-only experimental API. (toowned_clone_into
)
recently added
Uses borrowed data to replace owned data, usually by cloning. Read more
impl<V, T> VZip<V> for T where
V: MultiLane<T>,
impl<V, T> VZip<V> for T where
V: MultiLane<T>,