pub struct Builder { /* private fields */ }
Expand description
A builder for Uri
s.
This type can be used to construct an instance of Uri
through a builder pattern.
Implementations§
Source§impl Builder
impl Builder
Sourcepub fn new() -> Builder
pub fn new() -> Builder
Creates a new default instance of Builder
to construct a Uri
.
§Examples
let uri = uri::Builder::new()
.scheme("https")
.authority("hyper.rs")
.path_and_query("/")
.build()
.unwrap();
Sourcepub fn scheme<T>(self, scheme: T) -> Self
pub fn scheme<T>(self, scheme: T) -> Self
Set the Scheme
for this URI.
§Examples
let mut builder = uri::Builder::new();
builder.scheme("https");
Set the Authority
for this URI.
§Examples
let uri = uri::Builder::new()
.authority("tokio.rs")
.build()
.unwrap();
Sourcepub fn path_and_query<T>(self, p_and_q: T) -> Self
pub fn path_and_query<T>(self, p_and_q: T) -> Self
Set the PathAndQuery
for this URI.
§Examples
let uri = uri::Builder::new()
.path_and_query("/hello?foo=bar")
.build()
.unwrap();
Sourcepub fn build(self) -> Result<Uri, Error>
pub fn build(self) -> Result<Uri, Error>
Consumes this builder, and tries to construct a valid Uri
from
the configured pieces.
§Errors
This function may return an error if any previously configured argument
failed to parse or get converted to the internal representation. For
example if an invalid scheme
was specified via scheme("!@#%/^")
the error will be returned when this function is called rather than
when scheme
was called.
Additionally, the various forms of URI require certain combinations of parts to be set to be valid. If the parts don’t fit into any of the valid forms of URI, a new error is returned.
§Examples
let uri = Uri::builder()
.build()
.unwrap();
Trait Implementations§
Auto Trait Implementations§
impl !Freeze for Builder
impl RefUnwindSafe for Builder
impl Send for Builder
impl Sync for Builder
impl Unpin for Builder
impl UnwindSafe for Builder
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Layout§
Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...)
attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.
Size: 88 bytes