Trait ibc_core::primitives::prelude::Copy
1.0.0 · source · pub trait Copy: Clone { }
Expand description
Types whose values can be duplicated simply by copying bits.
By default, variable bindings have ‘move semantics.’ In other words:
#[derive(Debug)]
struct Foo;
let x = Foo;
let y = x;
// `x` has moved into `y`, and so cannot be used
// println!("{x:?}"); // error: use of moved value
However, if a type implements Copy
, it instead has ‘copy semantics’:
// We can derive a `Copy` implementation. `Clone` is also required, as it's
// a supertrait of `Copy`.
#[derive(Debug, Copy, Clone)]
struct Foo;
let x = Foo;
let y = x;
// `y` is a copy of `x`
println!("{x:?}"); // A-OK!
It’s important to note that in these two examples, the only difference is whether you
are allowed to access x
after the assignment. Under the hood, both a copy and a move
can result in bits being copied in memory, although this is sometimes optimized away.
§How can I implement Copy
?
There are two ways to implement Copy
on your type. The simplest is to use derive
:
#[derive(Copy, Clone)]
struct MyStruct;
You can also implement Copy
and Clone
manually:
struct MyStruct;
impl Copy for MyStruct { }
impl Clone for MyStruct {
fn clone(&self) -> MyStruct {
*self
}
}
There is a small difference between the two: the derive
strategy will also place a Copy
bound on type parameters, which isn’t always desired.
§What’s the difference between Copy
and Clone
?
Copies happen implicitly, for example as part of an assignment y = x
. The behavior of
Copy
is not overloadable; it is always a simple bit-wise copy.
Cloning is an explicit action, x.clone()
. The implementation of Clone
can
provide any type-specific behavior necessary to duplicate values safely. For example,
the implementation of Clone
for String
needs to copy the pointed-to string
buffer in the heap. A simple bitwise copy of String
values would merely copy the
pointer, leading to a double free down the line. For this reason, String
is Clone
but not Copy
.
Clone
is a supertrait of Copy
, so everything which is Copy
must also implement
Clone
. If a type is Copy
then its Clone
implementation only needs to return *self
(see the example above).
§When can my type be Copy
?
A type can implement Copy
if all of its components implement Copy
. For example, this
struct can be Copy
:
#[derive(Copy, Clone)]
struct Point {
x: i32,
y: i32,
}
A struct can be Copy
, and i32
is Copy
, therefore Point
is eligible to be Copy
.
By contrast, consider
struct PointList {
points: Vec<Point>,
}
The struct PointList
cannot implement Copy
, because Vec<T>
is not Copy
. If we
attempt to derive a Copy
implementation, we’ll get an error:
the trait `Copy` cannot be implemented for this type; field `points` does not implement `Copy`
Shared references (&T
) are also Copy
, so a type can be Copy
, even when it holds
shared references of types T
that are not Copy
. Consider the following struct,
which can implement Copy
, because it only holds a shared reference to our non-Copy
type PointList
from above:
#[derive(Copy, Clone)]
struct PointListWrapper<'a> {
point_list_ref: &'a PointList,
}
§When can’t my type be Copy
?
Some types can’t be copied safely. For example, copying &mut T
would create an aliased
mutable reference. Copying String
would duplicate responsibility for managing the
String
’s buffer, leading to a double free.
Generalizing the latter case, any type implementing Drop
can’t be Copy
, because it’s
managing some resource besides its own size_of::<T>
bytes.
If you try to implement Copy
on a struct or enum containing non-Copy
data, you will get
the error E0204.
§When should my type be Copy
?
Generally speaking, if your type can implement Copy
, it should. Keep in mind, though,
that implementing Copy
is part of the public API of your type. If the type might become
non-Copy
in the future, it could be prudent to omit the Copy
implementation now, to
avoid a breaking API change.
§Additional implementors
In addition to the implementors listed below,
the following types also implement Copy
:
- Function item types (i.e., the distinct types defined for each function)
- Function pointer types (e.g.,
fn() -> i32
) - Closure types, if they capture no value from the environment
or if all such captured values implement
Copy
themselves. Note that variables captured by shared reference always implementCopy
(even if the referent doesn’t), while variables captured by mutable reference never implementCopy
.
Object Safety§
Implementors§
impl Copy for ibc_core::channel::types::channel::Order
impl Copy for ibc_core::channel::types::channel::State
impl Copy for ibc_core::channel::types::proto::v1::Order
impl Copy for ResponseResultType
impl Copy for ibc_core::channel::types::proto::v1::State
impl Copy for TimeoutHeight
impl Copy for HashOp
impl Copy for LengthOp
impl Copy for ibc_core::connection::types::State
impl Copy for ibc_core::connection::types::proto::v1::State
impl Copy for Expiry
impl Copy for AsciiChar
impl Copy for core::cmp::Ordering
impl Copy for Infallible
impl Copy for core::fmt::Alignment
impl Copy for IpAddr
impl Copy for Ipv6MulticastScope
impl Copy for SocketAddr
impl Copy for FpCategory
impl Copy for core::sync::atomic::Ordering
impl Copy for SeekFrom
impl Copy for std::io::error::ErrorKind
impl Copy for Shutdown
impl Copy for BacktraceStyle
impl Copy for RecvTimeoutError
impl Copy for TryRecvError
impl Copy for _Unwind_Action
impl Copy for _Unwind_Reason_Code
impl Copy for DecodePaddingMode
impl Copy for borsh::nostd_io::ErrorKind
impl Copy for TruncSide
impl Copy for ibc_proto::cosmos::gov::v1::ProposalStatus
impl Copy for ibc_proto::cosmos::gov::v1::VoteOption
impl Copy for ibc_proto::cosmos::gov::v1beta1::ProposalStatus
impl Copy for ibc_proto::cosmos::gov::v1beta1::VoteOption
impl Copy for AuthorizationType
impl Copy for BondStatus
impl Copy for Infraction
impl Copy for ibc_proto::cosmos::staking::v1beta1::InfractionType
impl Copy for SignMode
impl Copy for BroadcastMode
impl Copy for OrderBy
impl Copy for VerificationState
impl Copy for EnumType
impl Copy for FieldPresence
impl Copy for JsonFormat
impl Copy for MessageEncoding
impl Copy for RepeatedFieldEncoding
impl Copy for StringFieldValidation
impl Copy for Label
impl Copy for ibc_proto::google::protobuf::field_descriptor_proto::Type
impl Copy for CType
impl Copy for JsType
impl Copy for OptionRetention
impl Copy for OptionTargetType
impl Copy for OptimizeMode
impl Copy for Semantic
impl Copy for IdempotencyLevel
impl Copy for ibc_proto::ibc::applications::interchain_accounts::v1::Type
impl Copy for ConsumerPacketDataType
impl Copy for ibc_proto::interchain_security::ccv::v1::InfractionType
impl Copy for MetaForm
impl Copy for PortableForm
impl Copy for InstanceType
impl Copy for Category
impl Copy for tendermint_proto::tendermint::v0_34::abci::CheckTxType
impl Copy for EvidenceType
impl Copy for tendermint_proto::tendermint::v0_34::abci::response_apply_snapshot_chunk::Result
impl Copy for tendermint_proto::tendermint::v0_34::abci::response_offer_snapshot::Result
impl Copy for tendermint_proto::tendermint::v0_34::privval::Errors
impl Copy for tendermint_proto::tendermint::v0_34::types::BlockIdFlag
impl Copy for tendermint_proto::tendermint::v0_34::types::SignedMsgType
impl Copy for tendermint_proto::tendermint::v0_37::abci::CheckTxType
impl Copy for tendermint_proto::tendermint::v0_37::abci::MisbehaviorType
impl Copy for tendermint_proto::tendermint::v0_37::abci::response_apply_snapshot_chunk::Result
impl Copy for tendermint_proto::tendermint::v0_37::abci::response_offer_snapshot::Result
impl Copy for tendermint_proto::tendermint::v0_37::abci::response_process_proposal::ProposalStatus
impl Copy for tendermint_proto::tendermint::v0_37::privval::Errors
impl Copy for tendermint_proto::tendermint::v0_37::types::BlockIdFlag
impl Copy for tendermint_proto::tendermint::v0_37::types::SignedMsgType
impl Copy for tendermint_proto::tendermint::v0_38::abci::CheckTxType
impl Copy for tendermint_proto::tendermint::v0_38::abci::MisbehaviorType
impl Copy for tendermint_proto::tendermint::v0_38::abci::response_apply_snapshot_chunk::Result
impl Copy for tendermint_proto::tendermint::v0_38::abci::response_offer_snapshot::Result
impl Copy for tendermint_proto::tendermint::v0_38::abci::response_process_proposal::ProposalStatus
impl Copy for VerifyStatus
impl Copy for tendermint_proto::tendermint::v0_38::privval::Errors
impl Copy for tendermint_proto::tendermint::v0_38::types::BlockIdFlag
impl Copy for tendermint_proto::tendermint::v0_38::types::SignedMsgType
impl Copy for Code
impl Copy for CheckTxKind
impl Copy for ApplySnapshotChunkResult
impl Copy for OfferSnapshot
impl Copy for ProcessProposal
impl Copy for VerifyVoteExtension
impl Copy for BlockSignatureInfo
impl Copy for MisbehaviorKind
impl Copy for tendermint::block::block_id_flag::BlockIdFlag
impl Copy for tendermint::hash::Algorithm
impl Copy for tendermint::hash::Hash
impl Copy for TxIndexStatus
impl Copy for tendermint::proposal::msg_type::Type
impl Copy for tendermint::public_key::Algorithm
impl Copy for PublicKey
impl Copy for TendermintKey
impl Copy for tendermint::vote::Type
impl Copy for Parse
impl Copy for ParseFromDescription
impl Copy for TryFromParsed
impl Copy for time::format_description::component::Component
impl Copy for MonthRepr
impl Copy for Padding
impl Copy for SubsecondDigits
impl Copy for UnixTimestampPrecision
impl Copy for WeekNumberRepr
impl Copy for WeekdayRepr
impl Copy for YearRepr
impl Copy for DateKind
impl Copy for FormattedComponents
impl Copy for OffsetPrecision
impl Copy for TimePrecision
impl Copy for time::month::Month
impl Copy for time::weekday::Weekday
impl Copy for SearchStep
impl Copy for bool
impl Copy for char
impl Copy for f32
impl Copy for f64
impl Copy for i8
impl Copy for i16
impl Copy for i32
impl Copy for i64
impl Copy for i128
impl Copy for isize
impl Copy for !
impl Copy for u8
impl Copy for u16
impl Copy for u32
impl Copy for u64
impl Copy for u128
impl Copy for usize
impl Copy for ibc_core::client::types::Height
impl Copy for Sequence
impl Copy for Timestamp
impl Copy for Global
impl Copy for Layout
impl Copy for AllocError
impl Copy for TypeId
impl Copy for TryFromSliceError
impl Copy for CharTryFromError
impl Copy for TryFromCharError
impl Copy for CpuidResult
impl Copy for __m128
impl Copy for __m128bh
impl Copy for __m128d
impl Copy for __m128i
impl Copy for __m256
impl Copy for __m256bh
impl Copy for __m256d
impl Copy for __m256i
impl Copy for __m512
impl Copy for __m512bh
impl Copy for __m512d
impl Copy for __m512i
impl Copy for core::fmt::Error
impl Copy for PhantomPinned
impl Copy for Assume
impl Copy for Ipv4Addr
impl Copy for Ipv6Addr
impl Copy for SocketAddrV4
impl Copy for SocketAddrV6
impl Copy for core::num::error::TryFromIntError
impl Copy for RangeFull
impl Copy for core::ptr::alignment::Alignment
impl Copy for TimSortRun
impl Copy for RawWakerVTable
impl Copy for core::time::Duration
impl Copy for System
impl Copy for FileTimes
impl Copy for FileType
impl Copy for Empty
impl Copy for Sink
impl Copy for UCred
impl Copy for ExitCode
impl Copy for ExitStatus
impl Copy for ExitStatusError
impl Copy for WaitTimeoutResult
impl Copy for RecvError
impl Copy for AccessError
impl Copy for ThreadId
impl Copy for std::time::Instant
impl Copy for SystemTime
impl Copy for GeneralPurposeConfig
impl Copy for blake3::Hash
impl Copy for Eager
impl Copy for block_buffer::Error
impl Copy for Lazy
impl Copy for InvalidLength
impl Copy for deranged::TryFromIntError
impl Copy for MacError
impl Copy for InvalidBufferSize
impl Copy for InvalidOutputSize
impl Copy for Signature
impl Copy for InstallError
impl Copy for itoa::Buffer
impl Copy for OptionBool
impl Copy for FormatterOptions
impl Copy for EncodeError
impl Copy for ryu::buffer::Buffer
impl Copy for MetaType
impl Copy for IgnoredAny
impl Copy for Base64
impl Copy for Hex
impl Copy for Identity
impl Copy for Choice
impl Copy for tendermint::account::Id
impl Copy for Version
impl Copy for tendermint::block::height::Height
impl Copy for tendermint::block::id::Id
impl Copy for Header
impl Copy for Round
impl Copy for tendermint::channel::id::Id
impl Copy for VerificationKey
impl Copy for tendermint::evidence::Duration
impl Copy for tendermint::node::id::Id
impl Copy for tendermint::time::Time
impl Copy for Timeout
impl Copy for TrustThresholdFraction
impl Copy for ProposerPriority
impl Copy for Power
impl Copy for ValidatorIndex
impl Copy for time_core::convert::Day
impl Copy for time_core::convert::Hour
impl Copy for Microsecond
impl Copy for Millisecond
impl Copy for time_core::convert::Minute
impl Copy for Nanosecond
impl Copy for time_core::convert::Second
impl Copy for Week
impl Copy for Date
impl Copy for time::duration::Duration
impl Copy for ComponentRange
impl Copy for ConversionRange
impl Copy for DifferentVariant
impl Copy for InvalidVariant
impl Copy for time::format_description::modifier::Day
impl Copy for End
impl Copy for time::format_description::modifier::Hour
impl Copy for Ignore
impl Copy for time::format_description::modifier::Minute
impl Copy for time::format_description::modifier::Month
impl Copy for OffsetHour
impl Copy for OffsetMinute
impl Copy for OffsetSecond
impl Copy for Ordinal
impl Copy for Period
impl Copy for time::format_description::modifier::Second
impl Copy for Subsecond
impl Copy for UnixTimestamp
impl Copy for WeekNumber
impl Copy for time::format_description::modifier::Weekday
impl Copy for Year
impl Copy for Rfc2822
impl Copy for Rfc3339
impl Copy for time::instant::Instant
impl Copy for OffsetDateTime
impl Copy for Parsed
impl Copy for PrimitiveDateTime
impl Copy for time::time::Time
impl Copy for UtcOffset
impl Copy for ATerm
impl Copy for B0
impl Copy for B1
impl Copy for Z0
impl Copy for Equal
impl Copy for Greater
impl Copy for Less
impl Copy for UTerm
impl Copy for Utf8Error
impl<'a> Copy for std::path::Component<'a>
impl<'a> Copy for Prefix<'a>
impl<'a> Copy for Unexpected<'a>
impl<'a> Copy for Arguments<'a>
impl<'a> Copy for Location<'a>
impl<'a> Copy for IoSlice<'a>
impl<'a> Copy for Ancestors<'a>
impl<'a> Copy for PrefixComponent<'a>
impl<'a, E> Copy for BytesDeserializer<'a, E>
impl<'a, T> Copy for CompactRef<'a, T>where
T: Copy,
impl<'a, T> Copy for Symbol<'a, T>where
T: Copy + 'a,
impl<'a, T> Copy for Ptr<'a, T>where
T: ?Sized,
impl<'a, T, const N: usize> Copy for ArrayWindows<'a, T, N>where
T: Copy + 'a,
impl<'de, E> Copy for BorrowedBytesDeserializer<'de, E>
impl<'de, E> Copy for BorrowedStrDeserializer<'de, E>
impl<'de, E> Copy for StrDeserializer<'de, E>
impl<'fd> Copy for BorrowedFd<'fd>
impl<B, C> Copy for ControlFlow<B, C>
impl<Dyn> Copy for DynMetadata<Dyn>where
Dyn: ?Sized,
impl<E> Copy for BoolDeserializer<E>
impl<E> Copy for CharDeserializer<E>
impl<E> Copy for F32Deserializer<E>
impl<E> Copy for F64Deserializer<E>
impl<E> Copy for I8Deserializer<E>
impl<E> Copy for I16Deserializer<E>
impl<E> Copy for I32Deserializer<E>
impl<E> Copy for I64Deserializer<E>
impl<E> Copy for I128Deserializer<E>
impl<E> Copy for IsizeDeserializer<E>
impl<E> Copy for U8Deserializer<E>
impl<E> Copy for U16Deserializer<E>
impl<E> Copy for U32Deserializer<E>
impl<E> Copy for U64Deserializer<E>
impl<E> Copy for U128Deserializer<E>
impl<E> Copy for UnitDeserializer<E>
impl<E> Copy for UsizeDeserializer<E>
impl<F> Copy for RepeatWith<F>where
F: Copy,
impl<Idx> Copy for RangeTo<Idx>where
Idx: Copy,
impl<Idx> Copy for RangeToInclusive<Idx>where
Idx: Copy,
impl<Ptr> Copy for Pin<Ptr>where
Ptr: Copy,
impl<T> Copy for Option<T>where
T: Copy,
impl<T> Copy for Bound<T>where
T: Copy,
impl<T> Copy for Poll<T>where
T: Copy,
impl<T> Copy for TrySendError<T>where
T: Copy,
impl<T> Copy for *const Twhere
T: ?Sized,
impl<T> Copy for *mut Twhere
T: ?Sized,
impl<T> Copy for &Twhere
T: ?Sized,
Shared references can be copied, but mutable references cannot!