Struct Backend
pub struct Backend {
forks: MultiFork,
mem_db: CacheDB<EmptyDBWrapper>,
fork_init_journaled_state: JournaledState,
active_fork_ids: Option<(Uint<256, 4>, usize)>,
inner: BackendInner,
}
Expand description
Provides the underlying revm::Database
implementation.
A Backend
can be initialised in two forms:
§1. Empty in-memory Database
This is the default variant: an empty revm::Database
§2. Forked Database
A revm::Database
that forks off a remote client
In addition to that we support forking manually on the fly.
Additional forks can be created. Each unique fork is identified by its unique ForkId
. We treat
forks as unique if they have the same (endpoint, block number)
pair.
When it comes to testing, it’s intended that each contract will use its own Backend
(Backend::clone
). This way each contract uses its own encapsulated evm state. For in-memory
testing, the database is just an owned revm::InMemoryDB
.
Each Fork
, identified by a unique id, uses completely separate storage, write operations are
performed only in the fork’s own database, ForkDB
.
A ForkDB
consists of 2 halves:
- everything fetched from the remote is readonly
- all local changes (instructed by the contract) are written to the backend’s
db
and don’t alter the state of the remote client.
§Fork swapping
Multiple “forks” can be created Backend::create_fork()
, however only 1 can be used by the
db
. However, their state can be hot-swapped by swapping the read half of db
from one fork to
another.
When swapping forks (Backend::select_fork()
) we also update the current Env
of the EVM
accordingly, so that all block.*
config values match
When another for is selected DatabaseExt::select_fork()
the entire storage, including
JournaledState
is swapped, but the storage of the caller’s and the test contract account is
always cloned. This way a fork has entirely separate storage but data can still be shared
across fork boundaries via stack and contract variables.
§Snapshotting
A snapshot of the current overall state can be taken at any point in time. A snapshot is identified by a unique id that’s returned when a snapshot is created. A snapshot can only be reverted once. After a successful revert, the same snapshot id cannot be used again. Reverting a snapshot replaces the current active state with the snapshot state, the snapshot is deleted afterwards, as well as any snapshots taken after the reverted snapshot, (e.g.: reverting to id 0x1 will delete snapshots with ids 0x1, 0x2, etc.)
Note: State snapshots work across fork-swaps, e.g. if fork A
is currently active, then a
snapshot is created before fork B
is selected, then fork A
will be the active fork again
after reverting the snapshot.
Fields§
§forks: MultiFork
§mem_db: CacheDB<EmptyDBWrapper>
§fork_init_journaled_state: JournaledState
§active_fork_ids: Option<(Uint<256, 4>, usize)>
§inner: BackendInner
Implementations§
§impl Backend
impl Backend
pub fn spawn(fork: Option<CreateFork>) -> Backend
pub fn spawn(fork: Option<CreateFork>) -> Backend
Creates a new Backend with a spawned multi fork thread.
If fork
is Some
this will use a fork
database, otherwise with an in-memory
database.
pub fn new(forks: MultiFork, fork: Option<CreateFork>) -> Backend
pub fn new(forks: MultiFork, fork: Option<CreateFork>) -> Backend
Creates a new instance of Backend
If fork
is Some
this will use a fork
database, otherwise with an in-memory
database.
Prefer using spawn
instead.
pub fn clone_empty(&self) -> Backend
pub fn clone_empty(&self) -> Backend
Creates a new instance with a BackendDatabase::InMemory
cache layer for the CacheDB
pub fn insert_account_info(&mut self, address: Address, account: AccountInfo)
pub fn insert_account_storage(
&mut self,
address: Address,
slot: Uint<256, 4>,
value: Uint<256, 4>,
) -> Result<(), DatabaseError>
pub fn insert_account_storage( &mut self, address: Address, slot: Uint<256, 4>, value: Uint<256, 4>, ) -> Result<(), DatabaseError>
Inserts a value on an account’s storage without overriding account info
pub fn replace_account_storage(
&mut self,
address: Address,
storage: HashMap<Uint<256, 4>, Uint<256, 4>, RandomState>,
) -> Result<(), DatabaseError>
pub fn replace_account_storage( &mut self, address: Address, storage: HashMap<Uint<256, 4>, Uint<256, 4>, RandomState>, ) -> Result<(), DatabaseError>
Completely replace an account’s storage without overriding account info.
When forking, this causes the backend to assume a 0
value for all
unset storage slots instead of trying to fetch it.
pub fn state_snapshots(
&self,
) -> &StateSnapshots<BackendStateSnapshot<BackendDatabaseSnapshot>>
pub fn state_snapshots( &self, ) -> &StateSnapshots<BackendStateSnapshot<BackendDatabaseSnapshot>>
Returns all snapshots created in this backend
pub fn set_test_contract(&mut self, acc: Address) -> &mut Backend
pub fn set_test_contract(&mut self, acc: Address) -> &mut Backend
Sets the address of the DSTest
contract that is being executed
This will also mark the caller as persistent and remove the persistent status from the previous test contract address
This will also grant cheatcode access to the test account
pub fn set_caller(&mut self, acc: Address) -> &mut Backend
pub fn set_caller(&mut self, acc: Address) -> &mut Backend
Sets the caller address
pub fn set_spec_id(&mut self, spec_id: SpecId) -> &mut Backend
pub fn set_spec_id(&mut self, spec_id: SpecId) -> &mut Backend
Sets the current spec id
pub fn caller_address(&self) -> Option<Address>
pub fn caller_address(&self) -> Option<Address>
Returns the set caller address
pub fn has_state_snapshot_failure(&self) -> bool
pub fn has_state_snapshot_failure(&self) -> bool
Failures occurred in state snapshots are tracked when the state snapshot is reverted.
If an error occurs in a restored state snapshot, the test is considered failed.
This returns whether there was a reverted state snapshot that recorded an error.
pub fn set_state_snapshot_failure(&mut self, has_state_snapshot_failure: bool)
pub fn set_state_snapshot_failure(&mut self, has_state_snapshot_failure: bool)
Sets the state snapshot failure flag.
pub fn mem_db(&self) -> &CacheDB<EmptyDBWrapper>
pub fn mem_db(&self) -> &CacheDB<EmptyDBWrapper>
Returns the memory db used if not in forking mode
pub fn is_active_fork(&self, id: Uint<256, 4>) -> bool
pub fn is_active_fork(&self, id: Uint<256, 4>) -> bool
Returns true if the id
is currently active
pub fn is_in_forking_mode(&self) -> bool
pub fn is_in_forking_mode(&self) -> bool
Returns true
if the Backend
is currently in forking mode
pub fn active_fork(&self) -> Option<&Fork>
pub fn active_fork(&self) -> Option<&Fork>
Returns the currently active Fork
, if any
pub fn active_fork_mut(&mut self) -> Option<&mut Fork>
pub fn active_fork_mut(&mut self) -> Option<&mut Fork>
Returns the currently active Fork
, if any
pub fn active_fork_db(&self) -> Option<&CacheDB<SharedBackend>>
pub fn active_fork_db(&self) -> Option<&CacheDB<SharedBackend>>
Returns the currently active ForkDB
, if any
pub fn active_fork_db_mut(&mut self) -> Option<&mut CacheDB<SharedBackend>>
pub fn active_fork_db_mut(&mut self) -> Option<&mut CacheDB<SharedBackend>>
Returns the currently active ForkDB
, if any
pub fn db(&self) -> &dyn Database<Error = DatabaseError>
pub fn db(&self) -> &dyn Database<Error = DatabaseError>
Returns the current database implementation as a &dyn
value.
pub fn db_mut(&mut self) -> &mut dyn Database<Error = DatabaseError>
pub fn db_mut(&mut self) -> &mut dyn Database<Error = DatabaseError>
Returns the current database implementation as a &mut dyn
value.
pub fn merged_logs(&self, logs: Vec<Log>) -> Vec<Log>
pub fn merged_logs(&self, logs: Vec<Log>) -> Vec<Log>
Since each Fork
tracks logs separately, we need to merge them to get all of them
pub fn inspect<I>(
&mut self,
env: &mut EnvWithHandlerCfg,
inspector: &mut I,
) -> Result<ResultAndState, Report>where
I: InspectorExt,
pub fn inspect<I>(
&mut self,
env: &mut EnvWithHandlerCfg,
inspector: &mut I,
) -> Result<ResultAndState, Report>where
I: InspectorExt,
Executes the configured test call of the env
without committing state changes.
Note: in case there are any cheatcodes executed that modify the environment, this will
update the given env
with the new values.
pub fn is_existing_precompile(&self, addr: &Address) -> bool
pub fn is_existing_precompile(&self, addr: &Address) -> bool
Returns true if the address is a precompile
pub fn replay_until(
&mut self,
id: Uint<256, 4>,
env: Env,
tx_hash: FixedBytes<32>,
journaled_state: &mut JournaledState,
) -> Result<Option<Transaction<AnyTxEnvelope>>, Report>
pub fn replay_until( &mut self, id: Uint<256, 4>, env: Env, tx_hash: FixedBytes<32>, journaled_state: &mut JournaledState, ) -> Result<Option<Transaction<AnyTxEnvelope>>, Report>
Replays all the transactions at the forks current block that were mined before the tx
Returns the unmined transaction that corresponds to the given tx_hash
Trait Implementations§
§impl Database for Backend
impl Database for Backend
§type Error = DatabaseError
type Error = DatabaseError
§fn basic(
&mut self,
address: Address,
) -> Result<Option<AccountInfo>, <Backend as Database>::Error>
fn basic( &mut self, address: Address, ) -> Result<Option<AccountInfo>, <Backend as Database>::Error>
§fn code_by_hash(
&mut self,
code_hash: FixedBytes<32>,
) -> Result<Bytecode, <Backend as Database>::Error>
fn code_by_hash( &mut self, code_hash: FixedBytes<32>, ) -> Result<Bytecode, <Backend as Database>::Error>
§fn storage(
&mut self,
address: Address,
index: Uint<256, 4>,
) -> Result<Uint<256, 4>, <Backend as Database>::Error>
fn storage( &mut self, address: Address, index: Uint<256, 4>, ) -> Result<Uint<256, 4>, <Backend as Database>::Error>
§fn block_hash(
&mut self,
number: u64,
) -> Result<FixedBytes<32>, <Backend as Database>::Error>
fn block_hash( &mut self, number: u64, ) -> Result<FixedBytes<32>, <Backend as Database>::Error>
§impl DatabaseCommit for Backend
impl DatabaseCommit for Backend
§impl DatabaseExt for Backend
impl DatabaseExt for Backend
§fn select_fork(
&mut self,
id: Uint<256, 4>,
env: &mut Env,
active_journaled_state: &mut JournaledState,
) -> Result<(), Report>
fn select_fork( &mut self, id: Uint<256, 4>, env: &mut Env, active_journaled_state: &mut JournaledState, ) -> Result<(), Report>
Select an existing fork by id. When switching forks we copy the shared state
§fn roll_fork(
&mut self,
id: Option<Uint<256, 4>>,
block_number: u64,
env: &mut Env,
journaled_state: &mut JournaledState,
) -> Result<(), Report>
fn roll_fork( &mut self, id: Option<Uint<256, 4>>, block_number: u64, env: &mut Env, journaled_state: &mut JournaledState, ) -> Result<(), Report>
This is effectively the same as Self::create_select_fork()
but updating an existing
ForkId that is mapped to the LocalForkId
§fn load_allocs(
&mut self,
allocs: &BTreeMap<Address, GenesisAccount>,
journaled_state: &mut JournaledState,
) -> Result<(), BackendError>
fn load_allocs( &mut self, allocs: &BTreeMap<Address, GenesisAccount>, journaled_state: &mut JournaledState, ) -> Result<(), BackendError>
Loads the account allocs from the given allocs
map into the passed JournaledState.
Returns Ok if all accounts were successfully inserted into the journal, Err otherwise.
§fn clone_account(
&mut self,
source: &GenesisAccount,
target: &Address,
journaled_state: &mut JournaledState,
) -> Result<(), BackendError>
fn clone_account( &mut self, source: &GenesisAccount, target: &Address, journaled_state: &mut JournaledState, ) -> Result<(), BackendError>
§fn snapshot_state(
&mut self,
journaled_state: &JournaledState,
env: &Env,
) -> Uint<256, 4>
fn snapshot_state( &mut self, journaled_state: &JournaledState, env: &Env, ) -> Uint<256, 4>
§fn revert_state(
&mut self,
id: Uint<256, 4>,
current_state: &JournaledState,
current: &mut Env,
action: RevertStateSnapshotAction,
) -> Option<JournaledState>
fn revert_state( &mut self, id: Uint<256, 4>, current_state: &JournaledState, current: &mut Env, action: RevertStateSnapshotAction, ) -> Option<JournaledState>
§fn delete_state_snapshot(&mut self, id: Uint<256, 4>) -> bool
fn delete_state_snapshot(&mut self, id: Uint<256, 4>) -> bool
id
Read more§fn delete_state_snapshots(&mut self)
fn delete_state_snapshots(&mut self)
§fn create_fork(
&mut self,
create_fork: CreateFork,
) -> Result<Uint<256, 4>, Report>
fn create_fork( &mut self, create_fork: CreateFork, ) -> Result<Uint<256, 4>, Report>
§fn create_fork_at_transaction(
&mut self,
fork: CreateFork,
transaction: FixedBytes<32>,
) -> Result<Uint<256, 4>, Report>
fn create_fork_at_transaction( &mut self, fork: CreateFork, transaction: FixedBytes<32>, ) -> Result<Uint<256, 4>, Report>
§fn roll_fork_to_transaction(
&mut self,
id: Option<Uint<256, 4>>,
transaction: FixedBytes<32>,
env: &mut Env,
journaled_state: &mut JournaledState,
) -> Result<(), Report>
fn roll_fork_to_transaction( &mut self, id: Option<Uint<256, 4>>, transaction: FixedBytes<32>, env: &mut Env, journaled_state: &mut JournaledState, ) -> Result<(), Report>
§fn transact(
&mut self,
maybe_id: Option<Uint<256, 4>>,
transaction: FixedBytes<32>,
env: Env,
journaled_state: &mut JournaledState,
inspector: &mut dyn InspectorExt,
) -> Result<(), Report>
fn transact( &mut self, maybe_id: Option<Uint<256, 4>>, transaction: FixedBytes<32>, env: Env, journaled_state: &mut JournaledState, inspector: &mut dyn InspectorExt, ) -> Result<(), Report>
§fn transact_from_tx(
&mut self,
tx: &TransactionRequest,
env: Env,
journaled_state: &mut JournaledState,
inspector: &mut dyn InspectorExt,
) -> Result<(), Report>
fn transact_from_tx( &mut self, tx: &TransactionRequest, env: Env, journaled_state: &mut JournaledState, inspector: &mut dyn InspectorExt, ) -> Result<(), Report>
§fn active_fork_id(&self) -> Option<Uint<256, 4>>
fn active_fork_id(&self) -> Option<Uint<256, 4>>
ForkId
that’s currently used in the database, if fork mode is on§fn active_fork_url(&self) -> Option<String>
fn active_fork_url(&self) -> Option<String>
§fn ensure_fork(&self, id: Option<Uint<256, 4>>) -> Result<Uint<256, 4>, Report>
fn ensure_fork(&self, id: Option<Uint<256, 4>>) -> Result<Uint<256, 4>, Report>
§fn ensure_fork_id(&self, id: Uint<256, 4>) -> Result<&ForkId, Report>
fn ensure_fork_id(&self, id: Uint<256, 4>) -> Result<&ForkId, Report>
ForkId
exists for the given local id
§fn diagnose_revert(
&self,
callee: Address,
journaled_state: &JournaledState,
) -> Option<RevertDiagnostic>
fn diagnose_revert( &self, callee: Address, journaled_state: &JournaledState, ) -> Option<RevertDiagnostic>
§fn add_persistent_account(&mut self, account: Address) -> bool
fn add_persistent_account(&mut self, account: Address) -> bool
§fn remove_persistent_account(&mut self, account: &Address) -> bool
fn remove_persistent_account(&mut self, account: &Address) -> bool
§fn is_persistent(&self, acc: &Address) -> bool
fn is_persistent(&self, acc: &Address) -> bool
§fn allow_cheatcode_access(&mut self, account: Address) -> bool
fn allow_cheatcode_access(&mut self, account: Address) -> bool
account
Read more§fn revoke_cheatcode_access(&mut self, account: &Address) -> bool
fn revoke_cheatcode_access(&mut self, account: &Address) -> bool
§fn has_cheatcode_access(&self, account: &Address) -> bool
fn has_cheatcode_access(&self, account: &Address) -> bool
true
if the given account is allowed to execute cheatcodes§fn set_blockhash(
&mut self,
block_number: Uint<256, 4>,
block_hash: FixedBytes<32>,
)
fn set_blockhash( &mut self, block_number: Uint<256, 4>, block_hash: FixedBytes<32>, )
§fn create_select_fork(
&mut self,
fork: CreateFork,
env: &mut Env,
journaled_state: &mut JournaledState,
) -> Result<Uint<256, 4>, Report>
fn create_select_fork( &mut self, fork: CreateFork, env: &mut Env, journaled_state: &mut JournaledState, ) -> Result<Uint<256, 4>, Report>
§fn create_select_fork_at_transaction(
&mut self,
fork: CreateFork,
env: &mut Env,
journaled_state: &mut JournaledState,
transaction: FixedBytes<32>,
) -> Result<Uint<256, 4>, Report>
fn create_select_fork_at_transaction( &mut self, fork: CreateFork, env: &mut Env, journaled_state: &mut JournaledState, transaction: FixedBytes<32>, ) -> Result<Uint<256, 4>, Report>
§fn is_forked_mode(&self) -> bool
fn is_forked_mode(&self) -> bool
§fn remove_persistent_accounts(
&mut self,
accounts: impl IntoIterator<Item = Address>,
)where
Self: Sized,
fn remove_persistent_accounts(
&mut self,
accounts: impl IntoIterator<Item = Address>,
)where
Self: Sized,
§fn extend_persistent_accounts(
&mut self,
accounts: impl IntoIterator<Item = Address>,
)where
Self: Sized,
fn extend_persistent_accounts(
&mut self,
accounts: impl IntoIterator<Item = Address>,
)where
Self: Sized,
§fn ensure_cheatcode_access(&self, account: &Address) -> Result<(), BackendError>
fn ensure_cheatcode_access(&self, account: &Address) -> Result<(), BackendError>
account
is allowed to execute cheatcodes Read more§fn ensure_cheatcode_access_forking_mode(
&self,
account: &Address,
) -> Result<(), BackendError>
fn ensure_cheatcode_access_forking_mode( &self, account: &Address, ) -> Result<(), BackendError>
Self::ensure_cheatcode_access()
but only enforces it if the backend is currently
in forking mode§impl DatabaseRef for Backend
impl DatabaseRef for Backend
§type Error = DatabaseError
type Error = DatabaseError
§fn basic_ref(
&self,
address: Address,
) -> Result<Option<AccountInfo>, <Backend as DatabaseRef>::Error>
fn basic_ref( &self, address: Address, ) -> Result<Option<AccountInfo>, <Backend as DatabaseRef>::Error>
§fn code_by_hash_ref(
&self,
code_hash: FixedBytes<32>,
) -> Result<Bytecode, <Backend as DatabaseRef>::Error>
fn code_by_hash_ref( &self, code_hash: FixedBytes<32>, ) -> Result<Bytecode, <Backend as DatabaseRef>::Error>
§fn storage_ref(
&self,
address: Address,
index: Uint<256, 4>,
) -> Result<Uint<256, 4>, <Backend as DatabaseRef>::Error>
fn storage_ref( &self, address: Address, index: Uint<256, 4>, ) -> Result<Uint<256, 4>, <Backend as DatabaseRef>::Error>
§fn block_hash_ref(
&self,
number: u64,
) -> Result<FixedBytes<32>, <Backend as DatabaseRef>::Error>
fn block_hash_ref( &self, number: u64, ) -> Result<FixedBytes<32>, <Backend as DatabaseRef>::Error>
Auto Trait Implementations§
impl Freeze for Backend
impl !RefUnwindSafe for Backend
impl Send for Backend
impl Sync for Backend
impl Unpin for Backend
impl !UnwindSafe for Backend
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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<T, R> CollectAndApply<T, R> for T
impl<T, R> CollectAndApply<T, R> for T
§impl<T> Conv for T
impl<T> Conv 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> ⓘ
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 moreSource§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T
in a tonic::Request
§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> 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.§impl<T> TryConv for T
impl<T> TryConv for T
§impl<T> WithSubscriber for T
impl<T> WithSubscriber for T
§fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> ⓘwhere
S: Into<Dispatch>,
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> ⓘwhere
S: Into<Dispatch>,
§fn with_current_subscriber(self) -> WithDispatch<Self> ⓘ
fn with_current_subscriber(self) -> WithDispatch<Self> ⓘ
impl<T> ErasedDestructor for Twhere
T: 'static,
impl<T> MaybeSendSync for 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: 816 bytes