Struct SourceUrl

Source
pub struct SourceUrl {
    pub url: Url,
    pub vcs_info: Option<VcsInfo>,
}
Expand description

A URL for package sources.

Wraps the Url type and provides optional information on VCS systems.

Can be created from custom URL strings, that in part resemble the default URL syntax, e.g.:

git+https://example.org/example-project.git#tag=v1.0.0?signed

The above example provides an overview of the custom URL syntax:

  • The optional VCS specifier git is prepended, directly followed by a “+” sign as delimiter,
  • specific URL fragment types such as tag are used to encode information about the particular VCS objects to address,
  • the URL query component signed is used to indicate that OpenPGP signature verification is required for a VCS type.

§Note

The URL format used by SourceUrl deviates from the default URL syntax by allowing to change the order of the query and fragment component!

Refer to the alpm-package-source documentation for a more detailed overview of the custom URL syntax.

§Examples

use std::str::FromStr;

use alpm_types::SourceUrl;

// Create Url from &str
let url =
    SourceUrl::from_str("git+https://your-vcs.org/example-project.git?signed#tag=v1.0.0")?;
assert_eq!(
    &url.to_string(),
    "git+https://your-vcs.org/example-project.git?signed#tag=v1.0.0"
);

Fields§

§url: Url

The URL from where the sources are retrieved.

§vcs_info: Option<VcsInfo>

Optional data on VCS systems using the URL for the retrieval of sources.

Implementations§

Source§

impl SourceUrl

Source

fn parser(input: &mut &str) -> ModalResult<SourceUrl>

Parses a full SourceUrl from a string slice.

Source

fn inner_url_parser(input: &mut &str) -> ModalResult<String>

Recognizes a URL in an alpm-package-source string.

Considers all chars until a special char or the EOF is encountered:

  • # character that indicates a fragment
  • ? character indicates a query
  • EOF we reached the end of the string.

All of the above indicate that the end of the URL has been reached. The # or ? are not consumed, so that an outer parser may continue parsing afterwards.

Trait Implementations§

Source§

impl Clone for SourceUrl

Source§

fn clone(&self) -> SourceUrl

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for SourceUrl

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<'de> Deserialize<'de> for SourceUrl

Source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl Display for SourceUrl

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl FromStr for SourceUrl

Source§

fn from_str(s: &str) -> Result<Self, Self::Err>

Creates a new SourceUrl instance from a string slice.

§Examples
use std::str::FromStr;

use alpm_types::SourceUrl;

let url =
    SourceUrl::from_str("git+https://your-vcs.org/example-project.git?signed#tag=v1.0.0")?;
assert_eq!(
    &url.to_string(),
    "git+https://your-vcs.org/example-project.git?signed#tag=v1.0.0"
);
Source§

type Err = Error

The associated error which can be returned from parsing.
Source§

impl PartialEq for SourceUrl

Source§

fn eq(&self, other: &SourceUrl) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Serialize for SourceUrl

Source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl Eq for SourceUrl

Source§

impl StructuralPartialEq for SourceUrl

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dst: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,

§

impl<T> ErasedDestructor for T
where T: 'static,

§

impl<T> MaybeSendSync for T