Struct mysql_async::consts::CapabilityFlags

source ·
pub struct CapabilityFlags(/* private fields */);
Expand description

Client capability flags

Implementations§

source§

impl CapabilityFlags

source

pub const CLIENT_LONG_PASSWORD: CapabilityFlags = _

Use the improved version of Old Password Authentication. Assumed to be set since 4.1.1.

source

pub const CLIENT_FOUND_ROWS: CapabilityFlags = _

Send found rows instead of affected rows in EOF_Packet.

source

pub const CLIENT_LONG_FLAG: CapabilityFlags = _

Get all column flags. Longer flags in Protocol::ColumnDefinition320.

§Server

Supports longer flags.

§Client

Expects longer flags.

source

pub const CLIENT_CONNECT_WITH_DB: CapabilityFlags = _

Database (schema) name can be specified on connect in Handshake Response Packet.

§Server

Supports schema-name in Handshake Response Packet.

§Client

Handshake Response Packet contains a schema-name.

source

pub const CLIENT_NO_SCHEMA: CapabilityFlags = _

Don’t allow database.table.column.

source

pub const CLIENT_COMPRESS: CapabilityFlags = _

Compression protocol supported.

§Server

Supports compression.

§Client

Switches to Compression compressed protocol after successful authentication.

source

pub const CLIENT_ODBC: CapabilityFlags = _

Special handling of ODBC behavior.

source

pub const CLIENT_LOCAL_FILES: CapabilityFlags = _

Can use LOAD DATA LOCAL.

§Server

Enables the LOCAL INFILE request of LOAD DATA|XML.

§Client

Will handle LOCAL INFILE request.

source

pub const CLIENT_IGNORE_SPACE: CapabilityFlags = _

Ignore spaces before ‘(’.

§Server

Parser can ignore spaces before ‘(’.

§Client

Let the parser ignore spaces before ‘(’.

source

pub const CLIENT_PROTOCOL_41: CapabilityFlags = _

source

pub const CLIENT_INTERACTIVE: CapabilityFlags = _

This is an interactive client. Use System_variables::net_wait_timeout versus System_variables::net_interactive_timeout.

§Server

Supports interactive and noninteractive clients.

§Client

Client is interactive.

source

pub const CLIENT_SSL: CapabilityFlags = _

Use SSL encryption for the session.

§Server

Supports SSL

§Client

Switch to SSL after sending the capability-flags.

source

pub const CLIENT_IGNORE_SIGPIPE: CapabilityFlags = _

Client only flag. Not used.

§Client

Do not issue SIGPIPE if network failures occur (libmysqlclient only).

source

pub const CLIENT_TRANSACTIONS: CapabilityFlags = _

Client knows about transactions.

§Server

Can send status flags in OK_Packet / EOF_Packet.

§Client

Expects status flags in OK_Packet / EOF_Packet.

§Note

This flag is optional in 3.23, but always set by the server since 4.0.

source

pub const CLIENT_RESERVED: CapabilityFlags = _

source

pub const CLIENT_SECURE_CONNECTION: CapabilityFlags = _

source

pub const CLIENT_MULTI_STATEMENTS: CapabilityFlags = _

Enable/disable multi-stmt support. Also sets CLIENT_MULTI_RESULTS. Currently not checked anywhere.

§Server

Can handle multiple statements per COM_QUERY and COM_STMT_PREPARE.

§Client

May send multiple statements per COM_QUERY and COM_STMT_PREPARE.

source

pub const CLIENT_MULTI_RESULTS: CapabilityFlags = _

Enable/disable multi-results.

§Server

Can send multiple resultsets for COM_QUERY. Error if the server needs to send them and client does not support them.

§Client

Can handle multiple resultsets for COM_QUERY.

§Requires

CLIENT_PROTOCOL_41

source

pub const CLIENT_PS_MULTI_RESULTS: CapabilityFlags = _

Multi-results and OUT parameters in PS-protocol.

§Server

Can send multiple resultsets for COM_STMT_EXECUTE.

§Client

Can handle multiple resultsets for COM_STMT_EXECUTE.

§Requires

CLIENT_PROTOCOL_41

source

pub const CLIENT_PLUGIN_AUTH: CapabilityFlags = _

Client supports plugin authentication.

§Server

Sends extra data in Initial Handshake Packet and supports the pluggable authentication protocol.

§Client

Supports authentication plugins.

§Requires

CLIENT_PROTOCOL_41

source

pub const CLIENT_CONNECT_ATTRS: CapabilityFlags = _

Client supports connection attributes.

§Server

Permits connection attributes in Protocol::HandshakeResponse41.

§Client

Sends connection attributes in Protocol::HandshakeResponse41.

source

pub const CLIENT_PLUGIN_AUTH_LENENC_CLIENT_DATA: CapabilityFlags = _

Enable authentication response packet to be larger than 255 bytes. When the ability to change default plugin require that the initial password field in the Protocol::HandshakeResponse41 paclet can be of arbitrary size. However, the 4.1 client-server protocol limits the length of the auth-data-field sent from client to server to 255 bytes. The solution is to change the type of the field to a true length encoded string and indicate the protocol change with this client capability flag.

§Server

Understands length-encoded integer for auth response data in Protocol::HandshakeResponse41.

§Client

Length of auth response data in Protocol::HandshakeResponse41 is a length-encoded integer.

§Note

The flag was introduced in 5.6.6, but had the wrong value.

source

pub const CLIENT_CAN_HANDLE_EXPIRED_PASSWORDS: CapabilityFlags = _

Don’t close the connection for a user account with expired password.

§Server

Announces support for expired password extension.

§Client

Can handle expired passwords.

source

pub const CLIENT_SESSION_TRACK: CapabilityFlags = _

Capable of handling server state change information. Its a hint to the server to include the state change information in OK_Packet.

§Server

Can set SERVER_SESSION_STATE_CHANGED in the SERVER_STATUS_flags_enum and send Session State Information in a OK_Packet.

§Client

Expects the server to send Session State Information in a OK_Packet.

source

pub const CLIENT_DEPRECATE_EOF: CapabilityFlags = _

Client no longer needs EOF_Packet and will use OK_Packet instead.

§Server

Can send OK after a Text Resultset.

§Client

Expects an OK_Packet (instead of EOF_Packet) after the resultset rows of a Text Resultset.

§Background

To support CLIENT_SESSION_TRACK, additional information must be sent after all successful commands. Although the OK_Packet is extensible, the EOF_Packet is not due to the overlap of its bytes with the content of the Text Resultset Row.

Therefore, the EOF_Packet in the Text Resultset is replaced with an OK_Packet. EOF_Packet is deprecated as of MySQL 5.7.5.

source

pub const CLIENT_OPTIONAL_RESULTSET_METADATA: CapabilityFlags = _

The client can handle optional metadata information in the resultset.

source

pub const CLIENT_ZSTD_COMPRESSION_ALGORITHM: CapabilityFlags = _

Compression protocol extended to support zstd compression method.

This capability flag is used to send zstd compression level between client and server provided both client and server are enabled with this flag.

§Server

Server sets this flag when global variable protocol-compression-algorithms has zstd in its list of supported values.

§Client

Client sets this flag when it is configured to use zstd compression method.

source

pub const CLIENT_QUERY_ATTRIBUTES: CapabilityFlags = _

Support optional extension for query parameters into the COM_QUERY and COM_STMT_EXECUTE packets.

§Server

Expects an optional part containing the query parameter set(s). Executes the query for each set of parameters or returns an error if more than 1 set of parameters is sent and the server can’t execute it.

§Client

Can send the optional part containing the query parameter set(s).

source

pub const MULTI_FACTOR_AUTHENTICATION: CapabilityFlags = _

Support Multi factor authentication.

§Server

Server sends AuthNextFactor packet after every nth factor authentication method succeeds, except the last factor authentication.

§Client

Client reads AuthNextFactor packet sent by server and initiates next factor authentication method.

source

pub const CLIENT_PROGRESS_OBSOLETE: CapabilityFlags = _

Client or server supports progress reports within error packet.

source

pub const CLIENT_SSL_VERIFY_SERVER_CERT: CapabilityFlags = _

Verify server certificate. Client only flag.

Deprecated in favor of –ssl-mode.

source

pub const CLIENT_REMEMBER_OPTIONS: CapabilityFlags = _

Don’t reset the options after an unsuccessful connect. Client only flag.

source§

impl CapabilityFlags

source

pub const fn empty() -> CapabilityFlags

Get a flags value with all bits unset.

source

pub const fn all() -> CapabilityFlags

Get a flags value with all known bits set.

source

pub const fn bits(&self) -> u32

Get the underlying bits value.

The returned value is exactly the bits set in this flags value.

source

pub const fn from_bits(bits: u32) -> Option<CapabilityFlags>

Convert from a bits value.

This method will return None if any unknown bits are set.

source

pub const fn from_bits_truncate(bits: u32) -> CapabilityFlags

Convert from a bits value, unsetting any unknown bits.

source

pub const fn from_bits_retain(bits: u32) -> CapabilityFlags

Convert from a bits value exactly.

source

pub fn from_name(name: &str) -> Option<CapabilityFlags>

Get a flags value with the bits of a flag with the given name set.

This method will return None if name is empty or doesn’t correspond to any named flag.

source

pub const fn is_empty(&self) -> bool

Whether all bits in this flags value are unset.

source

pub const fn is_all(&self) -> bool

Whether all known bits in this flags value are set.

source

pub const fn intersects(&self, other: CapabilityFlags) -> bool

Whether any set bits in a source flags value are also set in a target flags value.

source

pub const fn contains(&self, other: CapabilityFlags) -> bool

Whether all set bits in a source flags value are also set in a target flags value.

source

pub fn insert(&mut self, other: CapabilityFlags)

The bitwise or (|) of the bits in two flags values.

source

pub fn remove(&mut self, other: CapabilityFlags)

The intersection of a source flags value with the complement of a target flags value (&!).

This method is not equivalent to self & !other when other has unknown bits set. remove won’t truncate other, but the ! operator will.

source

pub fn toggle(&mut self, other: CapabilityFlags)

The bitwise exclusive-or (^) of the bits in two flags values.

source

pub fn set(&mut self, other: CapabilityFlags, value: bool)

Call insert when value is true or remove when value is false.

source

pub const fn intersection(self, other: CapabilityFlags) -> CapabilityFlags

The bitwise and (&) of the bits in two flags values.

source

pub const fn union(self, other: CapabilityFlags) -> CapabilityFlags

The bitwise or (|) of the bits in two flags values.

source

pub const fn difference(self, other: CapabilityFlags) -> CapabilityFlags

The intersection of a source flags value with the complement of a target flags value (&!).

This method is not equivalent to self & !other when other has unknown bits set. difference won’t truncate other, but the ! operator will.

source

pub const fn symmetric_difference( self, other: CapabilityFlags, ) -> CapabilityFlags

The bitwise exclusive-or (^) of the bits in two flags values.

source

pub const fn complement(self) -> CapabilityFlags

The bitwise negation (!) of the bits in a flags value, truncating the result.

source§

impl CapabilityFlags

source

pub const fn iter(&self) -> Iter<CapabilityFlags>

Yield a set of contained flags values.

Each yielded flags value will correspond to a defined named flag. Any unknown bits will be yielded together as a final flags value.

source

pub const fn iter_names(&self) -> IterNames<CapabilityFlags>

Yield a set of contained named flags values.

This method is like iter, except only yields bits in contained named flags. Any unknown bits, or bits not corresponding to a contained flag will not be yielded.

Trait Implementations§

source§

impl Binary for CapabilityFlags

source§

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

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

impl BitAnd for CapabilityFlags

source§

fn bitand(self, other: CapabilityFlags) -> CapabilityFlags

The bitwise and (&) of the bits in two flags values.

§

type Output = CapabilityFlags

The resulting type after applying the & operator.
source§

impl BitAndAssign for CapabilityFlags

source§

fn bitand_assign(&mut self, other: CapabilityFlags)

The bitwise and (&) of the bits in two flags values.

source§

impl BitOr for CapabilityFlags

source§

fn bitor(self, other: CapabilityFlags) -> CapabilityFlags

The bitwise or (|) of the bits in two flags values.

§

type Output = CapabilityFlags

The resulting type after applying the | operator.
source§

impl BitOrAssign for CapabilityFlags

source§

fn bitor_assign(&mut self, other: CapabilityFlags)

The bitwise or (|) of the bits in two flags values.

source§

impl BitXor for CapabilityFlags

source§

fn bitxor(self, other: CapabilityFlags) -> CapabilityFlags

The bitwise exclusive-or (^) of the bits in two flags values.

§

type Output = CapabilityFlags

The resulting type after applying the ^ operator.
source§

impl BitXorAssign for CapabilityFlags

source§

fn bitxor_assign(&mut self, other: CapabilityFlags)

The bitwise exclusive-or (^) of the bits in two flags values.

source§

impl Clone for CapabilityFlags

source§

fn clone(&self) -> CapabilityFlags

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 CapabilityFlags

source§

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

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

impl Default for CapabilityFlags

source§

fn default() -> CapabilityFlags

Returns the “default value” for a type. Read more
source§

impl Extend<CapabilityFlags> for CapabilityFlags

source§

fn extend<T>(&mut self, iterator: T)
where T: IntoIterator<Item = CapabilityFlags>,

The bitwise or (|) of the bits in each flags value.

source§

fn extend_one(&mut self, item: A)

🔬This is a nightly-only experimental API. (extend_one)
Extends a collection with exactly one element.
source§

fn extend_reserve(&mut self, additional: usize)

🔬This is a nightly-only experimental API. (extend_one)
Reserves capacity in a collection for the given number of additional elements. Read more
source§

impl Flags for CapabilityFlags

source§

const FLAGS: &'static [Flag<CapabilityFlags>] = _

The set of defined flags.
§

type Bits = u32

The underlying bits type.
source§

fn bits(&self) -> u32

Get the underlying bits value. Read more
source§

fn from_bits_retain(bits: u32) -> CapabilityFlags

Convert from a bits value exactly.
source§

fn empty() -> Self

Get a flags value with all bits unset.
source§

fn all() -> Self

Get a flags value with all known bits set.
source§

fn from_bits(bits: Self::Bits) -> Option<Self>

Convert from a bits value. Read more
source§

fn from_bits_truncate(bits: Self::Bits) -> Self

Convert from a bits value, unsetting any unknown bits.
source§

fn from_name(name: &str) -> Option<Self>

Get a flags value with the bits of a flag with the given name set. Read more
source§

fn iter(&self) -> Iter<Self>

Yield a set of contained flags values. Read more
source§

fn iter_names(&self) -> IterNames<Self>

Yield a set of contained named flags values. Read more
source§

fn is_empty(&self) -> bool

Whether all bits in this flags value are unset.
source§

fn is_all(&self) -> bool

Whether all known bits in this flags value are set.
source§

fn intersects(&self, other: Self) -> bool
where Self: Sized,

Whether any set bits in a source flags value are also set in a target flags value.
source§

fn contains(&self, other: Self) -> bool
where Self: Sized,

Whether all set bits in a source flags value are also set in a target flags value.
source§

fn insert(&mut self, other: Self)
where Self: Sized,

The bitwise or (|) of the bits in two flags values.
source§

fn remove(&mut self, other: Self)
where Self: Sized,

The intersection of a source flags value with the complement of a target flags value (&!). Read more
source§

fn toggle(&mut self, other: Self)
where Self: Sized,

The bitwise exclusive-or (^) of the bits in two flags values.
source§

fn set(&mut self, other: Self, value: bool)
where Self: Sized,

Call Flags::insert when value is true or Flags::remove when value is false.
source§

fn intersection(self, other: Self) -> Self

The bitwise and (&) of the bits in two flags values.
source§

fn union(self, other: Self) -> Self

The bitwise or (|) of the bits in two flags values.
source§

fn difference(self, other: Self) -> Self

The intersection of a source flags value with the complement of a target flags value (&!). Read more
source§

fn symmetric_difference(self, other: Self) -> Self

The bitwise exclusive-or (^) of the bits in two flags values.
source§

fn complement(self) -> Self

The bitwise negation (!) of the bits in a flags value, truncating the result.
source§

impl FromIterator<CapabilityFlags> for CapabilityFlags

source§

fn from_iter<T>(iterator: T) -> CapabilityFlags
where T: IntoIterator<Item = CapabilityFlags>,

The bitwise or (|) of the bits in each flags value.

source§

impl Hash for CapabilityFlags

source§

fn hash<__H>(&self, state: &mut __H)
where __H: Hasher,

Feeds this value into the given Hasher. Read more
1.3.0 · source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
source§

impl IntoIterator for CapabilityFlags

§

type Item = CapabilityFlags

The type of the elements being iterated over.
§

type IntoIter = Iter<CapabilityFlags>

Which kind of iterator are we turning this into?
source§

fn into_iter(self) -> <CapabilityFlags as IntoIterator>::IntoIter

Creates an iterator from a value. Read more
source§

impl LowerHex for CapabilityFlags

source§

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

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

impl Not for CapabilityFlags

source§

fn not(self) -> CapabilityFlags

The bitwise negation (!) of the bits in a flags value, truncating the result.

§

type Output = CapabilityFlags

The resulting type after applying the ! operator.
source§

impl Octal for CapabilityFlags

source§

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

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

impl PartialEq for CapabilityFlags

source§

fn eq(&self, other: &CapabilityFlags) -> 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 Sub for CapabilityFlags

source§

fn sub(self, other: CapabilityFlags) -> CapabilityFlags

The intersection of a source flags value with the complement of a target flags value (&!).

This method is not equivalent to self & !other when other has unknown bits set. difference won’t truncate other, but the ! operator will.

§

type Output = CapabilityFlags

The resulting type after applying the - operator.
source§

impl SubAssign for CapabilityFlags

source§

fn sub_assign(&mut self, other: CapabilityFlags)

The intersection of a source flags value with the complement of a target flags value (&!).

This method is not equivalent to self & !other when other has unknown bits set. difference won’t truncate other, but the ! operator will.

source§

impl TryFrom<u32> for CapabilityFlags

§

type Error = UnknownCapabilityFlags

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

fn try_from(val: u32) -> Result<CapabilityFlags, UnknownCapabilityFlags>

Performs the conversion.
source§

impl UpperHex for CapabilityFlags

source§

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

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

impl Copy for CapabilityFlags

source§

impl Eq for CapabilityFlags

source§

impl StructuralPartialEq for CapabilityFlags

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§

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

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

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

source§

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

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

impl<T> Conv for T

source§

fn conv<T>(self) -> T
where Self: Into<T>,

Converts self into T using Into<T>. Read more
source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
source§

impl<T> FmtForward for T

source§

fn fmt_binary(self) -> FmtBinary<Self>
where Self: Binary,

Causes self to use its Binary implementation when Debug-formatted.
source§

fn fmt_display(self) -> FmtDisplay<Self>
where Self: Display,

Causes self to use its Display implementation when Debug-formatted.
source§

fn fmt_lower_exp(self) -> FmtLowerExp<Self>
where Self: LowerExp,

Causes self to use its LowerExp implementation when Debug-formatted.
source§

fn fmt_lower_hex(self) -> FmtLowerHex<Self>
where Self: LowerHex,

Causes self to use its LowerHex implementation when Debug-formatted.
source§

fn fmt_octal(self) -> FmtOctal<Self>
where Self: Octal,

Causes self to use its Octal implementation when Debug-formatted.
source§

fn fmt_pointer(self) -> FmtPointer<Self>
where Self: Pointer,

Causes self to use its Pointer implementation when Debug-formatted.
source§

fn fmt_upper_exp(self) -> FmtUpperExp<Self>
where Self: UpperExp,

Causes self to use its UpperExp implementation when Debug-formatted.
source§

fn fmt_upper_hex(self) -> FmtUpperHex<Self>
where Self: UpperHex,

Causes self to use its UpperHex implementation when Debug-formatted.
source§

fn fmt_list(self) -> FmtList<Self>
where &'a Self: for<'a> IntoIterator,

Formats each item in a sequence. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> Instrument for T

source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> Pipe for T
where T: ?Sized,

source§

fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> R
where Self: Sized,

Pipes by value. This is generally the method you want to use. Read more
source§

fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> R
where R: 'a,

Borrows self and passes that borrow into the pipe function. Read more
source§

fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> R
where R: 'a,

Mutably borrows self and passes that borrow into the pipe function. Read more
source§

fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
where Self: Borrow<B>, B: 'a + ?Sized, R: 'a,

Borrows self, then passes self.borrow() into the pipe function. Read more
source§

fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
where Self: BorrowMut<B>, B: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.borrow_mut() into the pipe function. Read more
source§

fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
where Self: AsRef<U>, U: 'a + ?Sized, R: 'a,

Borrows self, then passes self.as_ref() into the pipe function.
source§

fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
where Self: AsMut<U>, U: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.as_mut() into the pipe function.
source§

fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
where Self: Deref<Target = T>, T: 'a + ?Sized, R: 'a,

Borrows self, then passes self.deref() into the pipe function.
source§

fn pipe_deref_mut<'a, T, R>( &'a mut self, func: impl FnOnce(&'a mut T) -> R, ) -> R
where Self: DerefMut<Target = T> + Deref, T: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.deref_mut() into the pipe function.
source§

impl<T> Pointable for T

source§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
source§

impl<T> Same for T

§

type Output = T

Should always be Self
source§

impl<T> Tap for T

source§

fn tap(self, func: impl FnOnce(&Self)) -> Self

Immutable access to a value. Read more
source§

fn tap_mut(self, func: impl FnOnce(&mut Self)) -> Self

Mutable access to a value. Read more
source§

fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Immutable access to the Borrow<B> of a value. Read more
source§

fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Mutable access to the BorrowMut<B> of a value. Read more
source§

fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Immutable access to the AsRef<R> view of a value. Read more
source§

fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Mutable access to the AsMut<R> view of a value. Read more
source§

fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Immutable access to the Deref::Target of a value. Read more
source§

fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Mutable access to the Deref::Target of a value. Read more
source§

fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self

Calls .tap() only in debug builds, and is erased in release builds.
source§

fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self

Calls .tap_mut() only in debug builds, and is erased in release builds.
source§

fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Calls .tap_borrow() only in debug builds, and is erased in release builds.
source§

fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Calls .tap_borrow_mut() only in debug builds, and is erased in release builds.
source§

fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Calls .tap_ref() only in debug builds, and is erased in release builds.
source§

fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Calls .tap_ref_mut() only in debug builds, and is erased in release builds.
source§

fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Calls .tap_deref() only in debug builds, and is erased in release builds.
source§

fn tap_deref_mut_dbg<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Calls .tap_deref_mut() only in debug builds, and is erased in release builds.
source§

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

§

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> TryConv for T

source§

fn try_conv<T>(self) -> Result<T, Self::Error>
where Self: TryInto<T>,

Attempts to convert self into T using TryInto<T>. Read more
source§

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

§

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>,

§

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<V, T> VZip<V> for T
where V: MultiLane<T>,

source§

fn vzip(self) -> V

source§

impl<T> WithSubscriber for T

source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more