pub struct Transaction<Mode> {
inner: Transaction<'static, Db>,
metrics: TransactionMetricsGuard<Mode>,
}Expand description
An atomic SQL transaction.
Fields§
§inner: Transaction<'static, Db>§metrics: TransactionMetricsGuard<Mode>Implementations§
Source§impl<Mode> Transaction<Mode>where
Mode: TransactionMode,
impl<Mode> Transaction<Mode>where
Mode: TransactionMode,
async fn load_namespaces<Types>(
&mut self,
height: u64,
payload_size: u64,
) -> QueryResult<NamespaceMap<Types>>where
Types: NodeType,
Header<Types>: QueryableHeader<Types>,
Payload<Types>: QueryablePayload<Types>,
Source§impl<Mode> Transaction<Mode>where
Mode: TransactionMode,
impl<Mode> Transaction<Mode>where
Mode: TransactionMode,
Sourceasync fn sync_status_ranges(
&mut self,
table: &str,
indicator_column: &str,
start: usize,
end: usize,
) -> QueryResult<ResourceSyncStatus>
async fn sync_status_ranges( &mut self, table: &str, indicator_column: &str, start: usize, end: usize, ) -> QueryResult<ResourceSyncStatus>
Characterize consecutive ranges of objects in the given height-indexed table by status.
This function will find all ranges in [0, block_height). If pruned_height is specified,
an initial range will be created with bounds [0, pruned_height] and status
SyncStatus::Pruned. Then only the range [pruned_height + 1, block_height) will
actually be searched.
The search process uses an indexed outer self-join on table, which requires traversing
the table twice. Thus, it can be fairly expensive on large tables, but it is still linear in
the size of the table.
The value of indicator_column in the outer join results is used to check for missing
objects (indicated by a NULL value). If indicator_column is a NOT NULL column, such as
height, then this function will only consider objects missing if there is no corresponding
row in the database at all. However, indicator_column may also be a nullable column (such
as payload.data, in which case objects are treated as missing if there is no corresponding
row or if there is a row but it has an explicit NULL value for indicator_column).
Source§impl<Mode: TransactionMode> Transaction<Mode>
impl<Mode: TransactionMode> Transaction<Mode>
async fn time_window<Types: NodeType>( &mut self, start: u64, end: u64, limit: usize, ) -> QueryResult<TimeWindowQueryData<Header<Types>>>
Source§impl<Mode: TransactionMode> Transaction<Mode>
impl<Mode: TransactionMode> Transaction<Mode>
Sourceasync fn snapshot_info<Types, State, const ARITY: usize>(
&mut self,
snapshot: Snapshot<Types, State, ARITY>,
) -> QueryResult<(i64, State::Commit)>where
Types: NodeType,
State: MerklizedState<Types, ARITY>,
async fn snapshot_info<Types, State, const ARITY: usize>(
&mut self,
snapshot: Snapshot<Types, State, ARITY>,
) -> QueryResult<(i64, State::Commit)>where
Types: NodeType,
State: MerklizedState<Types, ARITY>,
Get information identifying a Snapshot.
If the given snapshot is known to the database, this function returns
- The block height at which the snapshot was created
- A digest of the Merkle commitment to the snapshotted state
Source§impl<Mode> Transaction<Mode>
impl<Mode> Transaction<Mode>
Sourcepub async fn load_header<Types: NodeType>(
&mut self,
id: impl Into<BlockId<Types>> + Send,
) -> QueryResult<Header<Types>>
pub async fn load_header<Types: NodeType>( &mut self, id: impl Into<BlockId<Types>> + Send, ) -> QueryResult<Header<Types>>
Load a header from storage.
This function is similar to AvailabilityStorage::get_header, but
- does not require the
QueryablePayload<Types>bound that that trait impl does - makes it easier to specify types since the type parameter is on the function and not on a trait impl
- allows type conversions for the
idparameter
This more ergonomic interface is useful as loading headers is important for many SQL storage
functions, not just the AvailabilityStorage interface.
Source§impl<Mode: TransactionMode> Transaction<Mode>
impl<Mode: TransactionMode> Transaction<Mode>
pub(super) async fn new(pool: &Pool<Db>, metrics: PoolMetrics) -> Result<Self>
Source§impl Transaction<Write>
Low-level, general database queries and mutation.
impl Transaction<Write>
Low-level, general database queries and mutation.
Source§impl Transaction<Write>
Query service specific mutations.
impl Transaction<Write>
Query service specific mutations.
Trait Implementations§
Source§impl<Types, Mode: TransactionMode> AggregatesStorage<Types> for Transaction<Mode>
impl<Types, Mode: TransactionMode> AggregatesStorage<Types> for Transaction<Mode>
Source§impl<Mode, Types> AvailabilityStorage<Types> for Transaction<Mode>where
Types: NodeType,
Mode: TransactionMode,
Payload<Types>: QueryablePayload<Types>,
Header<Types>: QueryableHeader<Types>,
impl<Mode, Types> AvailabilityStorage<Types> for Transaction<Mode>where
Types: NodeType,
Mode: TransactionMode,
Payload<Types>: QueryablePayload<Types>,
Header<Types>: QueryableHeader<Types>,
fn get_leaf<'life0, 'async_trait>(
&'life0 mut self,
id: LeafId<Types>,
) -> Pin<Box<dyn Future<Output = QueryResult<LeafQueryData<Types>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn get_block<'life0, 'async_trait>(
&'life0 mut self,
id: BlockId<Types>,
) -> Pin<Box<dyn Future<Output = QueryResult<BlockQueryData<Types>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn get_header<'life0, 'async_trait>(
&'life0 mut self,
id: BlockId<Types>,
) -> Pin<Box<dyn Future<Output = QueryResult<Header<Types>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn get_payload<'life0, 'async_trait>(
&'life0 mut self,
id: BlockId<Types>,
) -> Pin<Box<dyn Future<Output = QueryResult<PayloadQueryData<Types>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn get_payload_metadata<'life0, 'async_trait>(
&'life0 mut self,
id: BlockId<Types>,
) -> Pin<Box<dyn Future<Output = QueryResult<PayloadMetadata<Types>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn get_vid_common<'life0, 'async_trait>(
&'life0 mut self,
id: BlockId<Types>,
) -> Pin<Box<dyn Future<Output = QueryResult<VidCommonQueryData<Types>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn get_vid_common_metadata<'life0, 'async_trait>(
&'life0 mut self,
id: BlockId<Types>,
) -> Pin<Box<dyn Future<Output = QueryResult<VidCommonMetadata<Types>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn get_leaf_range<'life0, 'async_trait, R>( &'life0 mut self, range: R, ) -> Pin<Box<dyn Future<Output = QueryResult<Vec<QueryResult<LeafQueryData<Types>>>>> + Send + 'async_trait>>
fn get_block_range<'life0, 'async_trait, R>( &'life0 mut self, range: R, ) -> Pin<Box<dyn Future<Output = QueryResult<Vec<QueryResult<BlockQueryData<Types>>>>> + Send + 'async_trait>>
fn get_header_range<'life0, 'async_trait, R>( &'life0 mut self, range: R, ) -> Pin<Box<dyn Future<Output = QueryResult<Vec<QueryResult<Header<Types>>>>> + Send + 'async_trait>>
fn get_payload_range<'life0, 'async_trait, R>( &'life0 mut self, range: R, ) -> Pin<Box<dyn Future<Output = QueryResult<Vec<QueryResult<PayloadQueryData<Types>>>>> + Send + 'async_trait>>
fn get_payload_metadata_range<'life0, 'async_trait, R>(
&'life0 mut self,
range: R,
) -> Pin<Box<dyn Future<Output = QueryResult<Vec<QueryResult<PayloadMetadata<Types>>>>> + Send + 'async_trait>>where
R: RangeBounds<usize> + Send + 'static + 'async_trait,
Self: 'async_trait,
'life0: 'async_trait,
fn get_vid_common_range<'life0, 'async_trait, R>( &'life0 mut self, range: R, ) -> Pin<Box<dyn Future<Output = QueryResult<Vec<QueryResult<VidCommonQueryData<Types>>>>> + Send + 'async_trait>>
fn get_vid_common_metadata_range<'life0, 'async_trait, R>( &'life0 mut self, range: R, ) -> Pin<Box<dyn Future<Output = QueryResult<Vec<QueryResult<VidCommonMetadata<Types>>>>> + Send + 'async_trait>>
fn get_block_with_transaction<'life0, 'async_trait>(
&'life0 mut self,
hash: TransactionHash<Types>,
) -> Pin<Box<dyn Future<Output = QueryResult<BlockQueryData<Types>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
Source§fn first_available_leaf<'life0, 'async_trait>(
&'life0 mut self,
from: u64,
) -> Pin<Box<dyn Future<Output = QueryResult<LeafQueryData<Types>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn first_available_leaf<'life0, 'async_trait>(
&'life0 mut self,
from: u64,
) -> Pin<Box<dyn Future<Output = QueryResult<LeafQueryData<Types>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
from.Source§impl<Mode: Debug> Debug for Transaction<Mode>
impl<Mode: Debug> Debug for Transaction<Mode>
Source§impl<Mode> DerefMut for Transaction<Mode>
impl<Mode> DerefMut for Transaction<Mode>
Source§impl<Mode, Types> ExplorerStorage<Types> for Transaction<Mode>where
Mode: TransactionMode,
Types: NodeType,
Payload<Types>: QueryablePayload<Types>,
Header<Types>: QueryableHeader<Types> + ExplorerHeader<Types>,
Transaction<Types>: ExplorerTransaction<Types>,
BalanceAmount<Types>: Into<MonetaryValue>,
impl<Mode, Types> ExplorerStorage<Types> for Transaction<Mode>where
Mode: TransactionMode,
Types: NodeType,
Payload<Types>: QueryablePayload<Types>,
Header<Types>: QueryableHeader<Types> + ExplorerHeader<Types>,
Transaction<Types>: ExplorerTransaction<Types>,
BalanceAmount<Types>: Into<MonetaryValue>,
Source§fn get_block_summaries<'life0, 'async_trait>(
&'life0 mut self,
request: GetBlockSummariesRequest<Types>,
) -> Pin<Box<dyn Future<Output = Result<Vec<BlockSummary<Types>>, GetBlockSummariesError>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn get_block_summaries<'life0, 'async_trait>(
&'life0 mut self,
request: GetBlockSummariesRequest<Types>,
) -> Pin<Box<dyn Future<Output = Result<Vec<BlockSummary<Types>>, GetBlockSummariesError>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
get_block_summaries is a method that retrieves a list of block
summaries from the blockchain. The list is generated from the given
GetBlockSummariesRequest.Source§fn get_block_detail<'life0, 'async_trait>(
&'life0 mut self,
request: BlockIdentifier<Types>,
) -> Pin<Box<dyn Future<Output = Result<BlockDetail<Types>, GetBlockDetailError>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn get_block_detail<'life0, 'async_trait>(
&'life0 mut self,
request: BlockIdentifier<Types>,
) -> Pin<Box<dyn Future<Output = Result<BlockDetail<Types>, GetBlockDetailError>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
get_block_detail is a method that retrieves the details of a specific
block from the blockchain. The block is identified by the given
BlockIdentifier.Source§fn get_transaction_summaries<'life0, 'async_trait>(
&'life0 mut self,
request: GetTransactionSummariesRequest<Types>,
) -> Pin<Box<dyn Future<Output = Result<Vec<TransactionSummary<Types>>, GetTransactionSummariesError>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn get_transaction_summaries<'life0, 'async_trait>(
&'life0 mut self,
request: GetTransactionSummariesRequest<Types>,
) -> Pin<Box<dyn Future<Output = Result<Vec<TransactionSummary<Types>>, GetTransactionSummariesError>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
get_transaction_summaries is a method that retrieves a list of
transaction summaries from the blockchain. The list is generated from
the given GetTransactionSummariesRequest.Source§fn get_transaction_detail<'life0, 'async_trait>(
&'life0 mut self,
request: TransactionIdentifier<Types>,
) -> Pin<Box<dyn Future<Output = Result<TransactionDetailResponse<Types>, GetTransactionDetailError>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn get_transaction_detail<'life0, 'async_trait>(
&'life0 mut self,
request: TransactionIdentifier<Types>,
) -> Pin<Box<dyn Future<Output = Result<TransactionDetailResponse<Types>, GetTransactionDetailError>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
get_transaction_detail is a method that retrieves the details of a
specific transaction from the blockchain. The transaction is identified
by the given TransactionIdentifier.Source§fn get_explorer_summary<'life0, 'async_trait>(
&'life0 mut self,
) -> Pin<Box<dyn Future<Output = Result<ExplorerSummary<Types>, GetExplorerSummaryError>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn get_explorer_summary<'life0, 'async_trait>(
&'life0 mut self,
) -> Pin<Box<dyn Future<Output = Result<ExplorerSummary<Types>, GetExplorerSummaryError>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
get_explorer_summary is a method that retrieves a summary overview of
the blockchain. This is useful for displaying information that
indicates the overall status of the block chain.Source§fn get_search_results<'life0, 'async_trait>(
&'life0 mut self,
search_query: TaggedBase64,
) -> Pin<Box<dyn Future<Output = Result<SearchResult<Types>, GetSearchResultsError>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn get_search_results<'life0, 'async_trait>(
&'life0 mut self,
search_query: TaggedBase64,
) -> Pin<Box<dyn Future<Output = Result<SearchResult<Types>, GetSearchResultsError>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
get_search_results is a method that retrieves the results of a search
query against the blockchain. The results are generated from the given
query string.Source§impl<Mode: TransactionMode> MerklizedStateHeightStorage for Transaction<Mode>
impl<Mode: TransactionMode> MerklizedStateHeightStorage for Transaction<Mode>
fn get_last_state_height<'life0, 'async_trait>(
&'life0 mut self,
) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
Source§impl<Mode, Types, State, const ARITY: usize> MerklizedStateStorage<Types, State, ARITY> for Transaction<Mode>
impl<Mode, Types, State, const ARITY: usize> MerklizedStateStorage<Types, State, ARITY> for Transaction<Mode>
Source§fn get_path<'life0, 'async_trait>(
&'life0 mut self,
snapshot: Snapshot<Types, State, ARITY>,
key: State::Key,
) -> Pin<Box<dyn Future<Output = QueryResult<MerkleProof<State::Entry, State::Key, State::T, ARITY>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn get_path<'life0, 'async_trait>(
&'life0 mut self,
snapshot: Snapshot<Types, State, ARITY>,
key: State::Key,
) -> Pin<Box<dyn Future<Output = QueryResult<MerkleProof<State::Entry, State::Key, State::T, ARITY>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
Retrieves a Merkle path from the database
Source§impl<Mode, Types> NodeStorage<Types> for Transaction<Mode>
impl<Mode, Types> NodeStorage<Types> for Transaction<Mode>
fn block_height<'life0, 'async_trait>(
&'life0 mut self,
) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn count_transactions_in_range<'life0, 'async_trait>(
&'life0 mut self,
range: impl 'async_trait + RangeBounds<usize> + Send,
namespace: Option<NamespaceId<Types>>,
) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn payload_size_in_range<'life0, 'async_trait>(
&'life0 mut self,
range: impl 'async_trait + RangeBounds<usize> + Send,
namespace: Option<NamespaceId<Types>>,
) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
Source§fn sync_status_for_range<'life0, 'async_trait>(
&'life0 mut self,
from: usize,
to: usize,
) -> Pin<Box<dyn Future<Output = QueryResult<SyncStatusQueryData>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn sync_status_for_range<'life0, 'async_trait>(
&'life0 mut self,
from: usize,
to: usize,
) -> Pin<Box<dyn Future<Output = QueryResult<SyncStatusQueryData>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn get_header_window<'life0, 'async_trait>(
&'life0 mut self,
start: impl 'async_trait + Into<WindowStart<Types>> + Send + Sync,
end: u64,
limit: usize,
) -> Pin<Box<dyn Future<Output = QueryResult<TimeWindowQueryData<Header<Types>>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn latest_qc_chain<'life0, 'async_trait>(
&'life0 mut self,
) -> Pin<Box<dyn Future<Output = QueryResult<Option<[CertificatePair<Types>; 2]>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
Source§impl<Mode: TransactionMode> PrunedHeightStorage for Transaction<Mode>
impl<Mode: TransactionMode> PrunedHeightStorage for Transaction<Mode>
Source§impl<Mode: TransactionMode> Transaction for Transaction<Mode>
impl<Mode: TransactionMode> Transaction for Transaction<Mode>
Source§impl<Types: NodeType> UpdateAggregatesStorage<Types> for Transaction<Write>where
Header<Types>: QueryableHeader<Types>,
impl<Types: NodeType> UpdateAggregatesStorage<Types> for Transaction<Write>where
Header<Types>: QueryableHeader<Types>,
Source§async fn update_aggregates(
&mut self,
prev: Aggregate<Types>,
blocks: &[PayloadMetadata<Types>],
) -> Result<Aggregate<Types>>
async fn update_aggregates( &mut self, prev: Aggregate<Types>, blocks: &[PayloadMetadata<Types>], ) -> Result<Aggregate<Types>>
Source§impl<Types> UpdateAvailabilityStorage<Types> for Transaction<Write>where
Types: NodeType,
Payload<Types>: QueryablePayload<Types>,
Header<Types>: QueryableHeader<Types>,
impl<Types> UpdateAvailabilityStorage<Types> for Transaction<Write>where
Types: NodeType,
Payload<Types>: QueryablePayload<Types>,
Header<Types>: QueryableHeader<Types>,
async fn insert_leaf_with_qc_chain( &mut self, leaf: LeafQueryData<Types>, qc_chain: Option<[CertificatePair<Types>; 2]>, ) -> Result<()>
async fn insert_block(&mut self, block: BlockQueryData<Types>) -> Result<()>
async fn insert_vid( &mut self, common: VidCommonQueryData<Types>, share: Option<VidShare>, ) -> Result<()>
fn insert_leaf( &mut self, leaf: LeafQueryData<Types>, ) -> impl Send + Future<Output = Result<()>>
Source§impl<Types: NodeType, State: MerklizedState<Types, ARITY>, const ARITY: usize> UpdateStateData<Types, State, ARITY> for Transaction<Write>
impl<Types: NodeType, State: MerklizedState<Types, ARITY>, const ARITY: usize> UpdateStateData<Types, State, ARITY> for Transaction<Write>
fn set_last_state_height<'life0, 'async_trait>(
&'life0 mut self,
height: usize,
) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn insert_merkle_nodes<'life0, 'async_trait>(
&'life0 mut self,
proof: MerkleProof<State::Entry, State::Key, State::T, ARITY>,
traversal_path: Vec<usize>,
block_number: u64,
) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn insert_merkle_nodes_batch<'life0, 'async_trait>(
&'life0 mut self,
proofs: Vec<(MerkleProof<State::Entry, State::Key, State::T, ARITY>, Vec<usize>)>,
block_number: u64,
) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
Auto Trait Implementations§
impl<Mode> Freeze for Transaction<Mode>
impl<Mode> !RefUnwindSafe for Transaction<Mode>
impl<Mode> Send for Transaction<Mode>where
Mode: Send,
impl<Mode> Sync for Transaction<Mode>where
Mode: Sync,
impl<Mode> Unpin for Transaction<Mode>where
Mode: Unpin,
impl<Mode> !UnwindSafe for Transaction<Mode>
Blanket Implementations§
§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
§type ArchivedMetadata = ()
type ArchivedMetadata = ()
§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
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
§impl<T> Conv for T
impl<T> Conv for T
§impl<F, W, T, D> Deserialize<With<T, W>, D> for F
impl<F, W, T, D> Deserialize<With<T, W>, D> for F
§fn deserialize(
&self,
deserializer: &mut D,
) -> Result<With<T, W>, <D as Fallible>::Error>
fn deserialize( &self, deserializer: &mut D, ) -> Result<With<T, W>, <D as Fallible>::Error>
§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can
then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be
further downcast into Rc<ConcreteType> where ConcreteType implements Trait.§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.§impl<T> DowncastSync for T
impl<T> DowncastSync for T
§impl<T> FmtForward for T
impl<T> FmtForward for T
§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self to use its Binary implementation when Debug-formatted.§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self to use its Display implementation when
Debug-formatted.§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self to use its LowerExp implementation when
Debug-formatted.§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self to use its LowerHex implementation when
Debug-formatted.§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self to use its Octal implementation when Debug-formatted.§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self to use its Pointer implementation when
Debug-formatted.§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self to use its UpperExp implementation when
Debug-formatted.§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self to use its UpperHex implementation when
Debug-formatted.§fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more§impl<T> LayoutRaw for T
impl<T> LayoutRaw for T
§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
§impl<T> Paint for Twhere
T: ?Sized,
impl<T> Paint for Twhere
T: ?Sized,
§fn fg(&self, value: Color) -> Painted<&T>
fn fg(&self, value: Color) -> Painted<&T>
Returns a styled value derived from self with the foreground set to
value.
This method should be used rarely. Instead, prefer to use color-specific
builder methods like red() and
green(), which have the same functionality but are
pithier.
§Example
Set foreground color to white using fg():
use yansi::{Paint, Color};
painted.fg(Color::White);Set foreground color to white using white().
use yansi::Paint;
painted.white();§fn bright_black(&self) -> Painted<&T>
fn bright_black(&self) -> Painted<&T>
§fn bright_red(&self) -> Painted<&T>
fn bright_red(&self) -> Painted<&T>
§fn bright_green(&self) -> Painted<&T>
fn bright_green(&self) -> Painted<&T>
§fn bright_yellow(&self) -> Painted<&T>
fn bright_yellow(&self) -> Painted<&T>
§fn bright_blue(&self) -> Painted<&T>
fn bright_blue(&self) -> Painted<&T>
§fn bright_magenta(&self) -> Painted<&T>
fn bright_magenta(&self) -> Painted<&T>
§fn bright_cyan(&self) -> Painted<&T>
fn bright_cyan(&self) -> Painted<&T>
§fn bright_white(&self) -> Painted<&T>
fn bright_white(&self) -> Painted<&T>
§fn bg(&self, value: Color) -> Painted<&T>
fn bg(&self, value: Color) -> Painted<&T>
Returns a styled value derived from self with the background set to
value.
This method should be used rarely. Instead, prefer to use color-specific
builder methods like on_red() and
on_green(), which have the same functionality but
are pithier.
§Example
Set background color to red using fg():
use yansi::{Paint, Color};
painted.bg(Color::Red);Set background color to red using on_red().
use yansi::Paint;
painted.on_red();§fn on_primary(&self) -> Painted<&T>
fn on_primary(&self) -> Painted<&T>
§fn on_magenta(&self) -> Painted<&T>
fn on_magenta(&self) -> Painted<&T>
§fn on_bright_black(&self) -> Painted<&T>
fn on_bright_black(&self) -> Painted<&T>
§fn on_bright_red(&self) -> Painted<&T>
fn on_bright_red(&self) -> Painted<&T>
§fn on_bright_green(&self) -> Painted<&T>
fn on_bright_green(&self) -> Painted<&T>
§fn on_bright_yellow(&self) -> Painted<&T>
fn on_bright_yellow(&self) -> Painted<&T>
§fn on_bright_blue(&self) -> Painted<&T>
fn on_bright_blue(&self) -> Painted<&T>
§fn on_bright_magenta(&self) -> Painted<&T>
fn on_bright_magenta(&self) -> Painted<&T>
§fn on_bright_cyan(&self) -> Painted<&T>
fn on_bright_cyan(&self) -> Painted<&T>
§fn on_bright_white(&self) -> Painted<&T>
fn on_bright_white(&self) -> Painted<&T>
§fn attr(&self, value: Attribute) -> Painted<&T>
fn attr(&self, value: Attribute) -> Painted<&T>
Enables the styling [Attribute] value.
This method should be used rarely. Instead, prefer to use
attribute-specific builder methods like bold() and
underline(), which have the same functionality
but are pithier.
§Example
Make text bold using attr():
use yansi::{Paint, Attribute};
painted.attr(Attribute::Bold);Make text bold using using bold().
use yansi::Paint;
painted.bold();§fn rapid_blink(&self) -> Painted<&T>
fn rapid_blink(&self) -> Painted<&T>
§fn quirk(&self, value: Quirk) -> Painted<&T>
fn quirk(&self, value: Quirk) -> Painted<&T>
Enables the yansi [Quirk] value.
This method should be used rarely. Instead, prefer to use quirk-specific
builder methods like mask() and
wrap(), which have the same functionality but are
pithier.
§Example
Enable wrapping using .quirk():
use yansi::{Paint, Quirk};
painted.quirk(Quirk::Wrap);Enable wrapping using wrap().
use yansi::Paint;
painted.wrap();§fn clear(&self) -> Painted<&T>
👎Deprecated since 1.0.1: renamed to resetting() due to conflicts with Vec::clear().
The clear() method will be removed in a future release.
fn clear(&self) -> Painted<&T>
resetting() due to conflicts with Vec::clear().
The clear() method will be removed in a future release.§fn whenever(&self, value: Condition) -> Painted<&T>
fn whenever(&self, value: Condition) -> Painted<&T>
Conditionally enable styling based on whether the [Condition] value
applies. Replaces any previous condition.
See the crate level docs for more details.
§Example
Enable styling painted only when both stdout and stderr are TTYs:
use yansi::{Paint, Condition};
painted.red().on_yellow().whenever(Condition::STDOUTERR_ARE_TTY);§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self and passes that borrow into the pipe function. Read more§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self and passes that borrow into the pipe function. Read more§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self, then passes self.as_ref() into the pipe function.§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self, then passes self.as_mut() into the pipe
function.§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self, then passes self.deref() into the pipe function.§impl<T> Pointable for T
impl<T> Pointable for T
§impl<T> PolicyExt for Twhere
T: ?Sized,
impl<T> PolicyExt for Twhere
T: ?Sized,
§impl<T> Tap for T
impl<T> Tap for T
§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B> of a value. Read more§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B> of a value. Read more§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R> view of a value. Read more§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R> view of a value. Read more§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target of a value. Read more§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target of a value. Read more§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap() only in debug builds, and is erased in release builds.§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut() only in debug builds, and is erased in release
builds.§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow() only in debug builds, and is erased in release
builds.§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut() only in debug builds, and is erased in release
builds.§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref() only in debug builds, and is erased in release
builds.§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut() only in debug builds, and is erased in release
builds.§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref() only in debug builds, and is erased in release
builds.