Enum parity_multiaddr::Protocol [−][src]
pub enum Protocol<'a> {}Show variants
Dccp(u16), Dns(Cow<'a, str>), Dns4(Cow<'a, str>), Dns6(Cow<'a, str>), Dnsaddr(Cow<'a, str>), Http, Https, Ip4(Ipv4Addr), Ip6(Ipv6Addr), P2pWebRtcDirect, P2pWebRtcStar, P2pWebSocketStar, Memory(u64), Onion(Cow<'a, [u8; 10]>, u16), Onion3(Onion3Addr<'a>), P2p(Multihash), P2pCircuit, Quic, Sctp(u16), Tcp(u16), Udp(u16), Udt, Unix(Cow<'a, str>), Utp, Ws(Cow<'a, str>), Wss(Cow<'a, str>),
Protocol
describes all possible multiaddress protocols.
For Unix
, Ws
and Wss
we use &str
instead of Path
to allow
cross-platform usage of Protocol
since encoding Paths
to bytes is
platform-specific. This means that the actual validation of paths needs to
happen separately.
Variants
Dccp(u16)
Ip4(Ipv4Addr)
Ip6(Ipv6Addr)
Memory(u64)
Contains the “port” to contact. Similar to TCP or UDP, 0 means “assign me a port”.
Onion3(Onion3Addr<'a>)
P2p(Multihash)
Sctp(u16)
Tcp(u16)
Udp(u16)
Implementations
impl<'a> Protocol<'a>
[src]
impl<'a> Protocol<'a>
[src]pub fn from_str_parts<I>(iter: I) -> Result<Self> where
I: Iterator<Item = &'a str>,
[src]
I: Iterator<Item = &'a str>,
Parse a protocol value from the given iterator of string slices.
The parsing only consumes the minimum amount of string slices necessary to produce a well-formed protocol. The same iterator can thus be used to parse a sequence of protocols in succession. It is up to client code to check that iteration has finished whenever appropriate.
pub fn from_bytes(input: &'a [u8]) -> Result<(Self, &'a [u8])>
[src]
Parse a single Protocol
value from its byte slice representation,
returning the protocol as well as the remaining byte slice.
pub fn write_bytes<W: Write>(&self, w: &mut W) -> Result<()>
[src]
Encode this protocol by writing its binary representation into
the given Write
impl.
pub fn acquire<'b>(self) -> Protocol<'b>
[src]
Turn this Protocol
into one that owns its data, thus being valid for any lifetime.
Trait Implementations
impl<'a> FromIterator<Protocol<'a>> for Multiaddr
[src]
impl<'a> FromIterator<Protocol<'a>> for Multiaddr
[src]fn from_iter<T>(iter: T) -> Self where
T: IntoIterator<Item = Protocol<'a>>,
[src]
T: IntoIterator<Item = Protocol<'a>>,