Trait frame_support::dispatch::marker::Sync

1.0.0 · source ·
pub unsafe auto trait Sync { }
Expand description

Types for which it is safe to share references between threads.

This trait is automatically implemented when the compiler determines it’s appropriate.

The precise definition is: a type T is Sync if and only if &T is Send. In other words, if there is no possibility of undefined behavior (including data races) when passing &T references between threads.

As one would expect, primitive types like u8 and f64 are all Sync, and so are simple aggregate types containing them, like tuples, structs and enums. More examples of basic Sync types include “immutable” types like &T, and those with simple inherited mutability, such as Box<T>, Vec<T> and most other collection types. (Generic parameters need to be Sync for their container to be Sync.)

A somewhat surprising consequence of the definition is that &mut T is Sync (if T is Sync) even though it seems like that might provide unsynchronized mutation. The trick is that a mutable reference behind a shared reference (that is, & &mut T) becomes read-only, as if it were a & &T. Hence there is no risk of a data race.

A shorter overview of how Sync and Send relate to referencing:

  • &T is Send if and only if T is Sync
  • &mut T is Send if and only if T is Send
  • &T and &mut T are Sync if and only if T is Sync

Types that are not Sync are those that have “interior mutability” in a non-thread-safe form, such as Cell and RefCell. These types allow for mutation of their contents even through an immutable, shared reference. For example the set method on Cell<T> takes &self, so it requires only a shared reference &Cell<T>. The method performs no synchronization, thus Cell cannot be Sync.

Another example of a non-Sync type is the reference-counting pointer Rc. Given any reference &Rc<T>, you can clone a new Rc<T>, modifying the reference counts in a non-atomic way.

For cases when one does need thread-safe interior mutability, Rust provides atomic data types, as well as explicit locking via sync::Mutex and sync::RwLock. These types ensure that any mutation cannot cause data races, hence the types are Sync. Likewise, sync::Arc provides a thread-safe analogue of Rc.

Any types with interior mutability must also use the cell::UnsafeCell wrapper around the value(s) which can be mutated through a shared reference. Failing to doing this is undefined behavior. For example, transmute-ing from &T to &mut T is invalid.

See the Nomicon for more details about Sync.

Implementors§

1.26.0 · source§

impl !Sync for Args

1.26.0 · source§

impl !Sync for ArgsOs

source§

impl Sync for TableElementwhere VMExternRef: Sync,

source§

impl Sync for Bytes

source§

impl Sync for BytesMut

source§

impl Sync for Select<'_>

source§

impl Sync for Collector

source§

impl Sync for Unparker

source§

impl Sync for Scope<'_>

source§

impl Sync for AtomicWaker

source§

impl Sync for GuardNoSend

source§

impl Sync for GdbJitImageRegistration

source§

impl Sync for ExportFunction

source§

impl Sync for ExportGlobal

source§

impl Sync for ExportMemory

source§

impl Sync for ExportTable

source§

impl Sync for VMExternRef

source§

impl Sync for InstanceHandle

source§

impl Sync for VMCallerCheckedAnyfunc

source§

impl Sync for VMFunctionImport

source§

impl Sync for VMGlobalImport

source§

impl Sync for VMMemoryImport

source§

impl Sync for VMRuntimeLimits

source§

impl Sync for VMTableImport

source§

impl Sync for VMHostFuncContext

1.6.0 · source§

impl Sync for alloc::string::Drain<'_>

source§

impl Sync for AtomicBool

1.34.0 · source§

impl Sync for AtomicI8

1.34.0 · source§

impl Sync for AtomicI16

1.34.0 · source§

impl Sync for AtomicI32

1.34.0 · source§

impl Sync for AtomicI64

source§

impl Sync for AtomicI128

source§

impl Sync for AtomicIsize

1.34.0 · source§

impl Sync for AtomicU8

1.34.0 · source§

impl Sync for AtomicU16

1.34.0 · source§

impl Sync for AtomicU32

1.34.0 · source§

impl Sync for AtomicU64

source§

impl Sync for AtomicU128

source§

impl Sync for AtomicUsize

1.36.0 · source§

impl Sync for Waker

source§

impl<'a> Sync for CDict<'a>

source§

impl<'a> Sync for DDict<'a>

1.44.0 · source§

impl<'a> Sync for IoSlice<'a>

1.44.0 · source§

impl<'a> Sync for IoSliceMut<'a>

source§

impl<'a, 'b, K, Q, V, S, A> Sync for OccupiedEntryRef<'a, 'b, K, Q, V, S, A>where K: Sync, Q: Sync + ?Sized, V: Sync, S: Sync, A: Sync + Allocator + Clone,

source§

impl<'a, A> Sync for arrayvec::Drain<'a, A>where A: Array + Sync,

source§

impl<'a, K, V> Sync for lru::Iter<'a, K, V>where K: Sync, V: Sync,

source§

impl<'a, K, V> Sync for lru::IterMut<'a, K, V>where K: Sync, V: Sync,

source§

impl<'a, R, G, T> Sync for MappedReentrantMutexGuard<'a, R, G, T>where R: RawMutex + Sync + 'a, G: GetThreadId + Sync + 'a, T: Sync + 'a + ?Sized,

source§

impl<'a, R, G, T> Sync for ReentrantMutexGuard<'a, R, G, T>where R: RawMutex + Sync + 'a, G: GetThreadId + Sync + 'a, T: Sync + 'a + ?Sized,

source§

impl<'a, R, T> Sync for lock_api::mutex::MappedMutexGuard<'a, R, T>where R: RawMutex + Sync + 'a, T: Sync + 'a + ?Sized,

source§

impl<'a, R, T> Sync for lock_api::mutex::MutexGuard<'a, R, T>where R: RawMutex + Sync + 'a, T: Sync + 'a + ?Sized,

source§

impl<'a, R, T> Sync for MappedRwLockReadGuard<'a, R, T>where R: RawRwLock + 'a, T: Sync + 'a + ?Sized,

source§

impl<'a, R, T> Sync for MappedRwLockWriteGuard<'a, R, T>where R: RawRwLock + 'a, T: Sync + 'a + ?Sized,

source§

impl<'a, R, T> Sync for RwLockUpgradableReadGuard<'a, R, T>where R: RawRwLockUpgrade + 'a, T: Sync + 'a + ?Sized,

source§

impl<'a, T> Sync for OnceRef<'a, T>where T: Sync,

source§

impl<'a, T> Sync for smallvec::Drain<'a, T>where T: Sync + Array,

source§

impl<'a, T, const CAP: usize> Sync for arrayvec::arrayvec::Drain<'a, T, CAP>where T: Sync,

source§

impl<C> Sync for Secp256k1<C>where C: Context,

source§

impl<Dyn> Sync for DynMetadata<Dyn>where Dyn: ?Sized,

source§

impl<Fut> Sync for futures_util::stream::futures_unordered::iter::IntoIter<Fut>where Fut: Sync + Unpin,

source§

impl<Fut> Sync for IterPinMut<'_, Fut>where Fut: Sync,

source§

impl<Fut> Sync for IterPinRef<'_, Fut>where Fut: Sync,

source§

impl<Fut> Sync for FuturesUnordered<Fut>where Fut: Sync,

source§

impl<K, V> Sync for indexmap::map::core::raw::OccupiedEntry<'_, K, V>where K: Sync, V: Sync,

source§

impl<K, V, S> Sync for LruCache<K, V, S>where K: Sync, V: Sync, S: Sync,

source§

impl<K, V, S, A> Sync for hashbrown::map::OccupiedEntry<'_, K, V, S, A>where K: Sync, V: Sync, S: Sync, A: Sync + Allocator + Clone,

source§

impl<K, V, S, A> Sync for RawOccupiedEntryMut<'_, K, V, S, A>where K: Sync, V: Sync, S: Sync, A: Sync + Allocator + Clone,

source§

impl<M, T, O> Sync for BitRef<'_, M, T, O>where M: Mutability, T: BitStore + Sync, O: BitOrder,

source§

impl<R, G> Sync for RawReentrantMutex<R, G>where R: RawMutex + Sync, G: GetThreadId + Sync,

source§

impl<R, G, T> Sync for ReentrantMutex<R, G, T>where R: RawMutex + Sync, G: GetThreadId + Sync, T: Send + ?Sized,

source§

impl<R, T> Sync for lock_api::mutex::Mutex<R, T>where R: RawMutex + Sync, T: Send + ?Sized,

source§

impl<R, T> Sync for lock_api::rwlock::RwLock<R, T>where R: RawRwLock + Sync, T: Send + Sync + ?Sized,

source§

impl<T> !Sync for *const Twhere T: ?Sized,

source§

impl<T> !Sync for *mut Twhere T: ?Sized,

source§

impl<T> !Sync for Rc<T>where T: ?Sized,

1.4.0 · source§

impl<T> !Sync for alloc::rc::Weak<T>where T: ?Sized,

1.70.0 · source§

impl<T> !Sync for OnceCell<T>

source§

impl<T> !Sync for Cell<T>where T: ?Sized,

source§

impl<T> !Sync for RefCell<T>where T: ?Sized,

source§

impl<T> !Sync for UnsafeCell<T>where T: ?Sized,

1.25.0 · source§

impl<T> !Sync for NonNull<T>where T: ?Sized,

NonNull pointers are not Sync because the data they reference may be aliased.

source§

impl<T> !Sync for std::sync::mpsc::Receiver<T>

source§

impl<T> !Sync for std::sync::mpsc::Sender<T>

source§

impl<T> Sync for BitSpanError<T>where T: BitStore,

source§

impl<T> Sync for MisalignError<T>

source§

impl<T> Sync for crossbeam_channel::channel::Receiver<T>where T: Send,

source§

impl<T> Sync for crossbeam_channel::channel::Sender<T>where T: Send,

source§

impl<T> Sync for Injector<T>where T: Send,

source§

impl<T> Sync for Stealer<T>where T: Send,

source§

impl<T> Sync for Atomic<T>where T: Pointable + Send + Sync + ?Sized,

source§

impl<T> Sync for AtomicCell<T>where T: Send,

source§

impl<T> Sync for CachePadded<T>where T: Sync,

source§

impl<T> Sync for ShardedLock<T>where T: Send + Sync + ?Sized,

source§

impl<T> Sync for ShardedLockReadGuard<'_, T>where T: Sync + ?Sized,

source§

impl<T> Sync for ShardedLockWriteGuard<'_, T>where T: Sync + ?Sized,

source§

impl<T> Sync for ScopedJoinHandle<'_, T>

source§

impl<T> Sync for BiLockGuard<'_, T>where T: Send + Sync,

source§

impl<T> Sync for futures_util::lock::mutex::Mutex<T>where T: Send + ?Sized,

source§

impl<T> Sync for futures_util::lock::mutex::MutexGuard<'_, T>where T: Sync + ?Sized,

source§

impl<T> Sync for MutexLockFuture<'_, T>where T: ?Sized,

source§

impl<T> Sync for OwnedMutexGuard<T>where T: Sync + ?Sized,

source§

impl<T> Sync for OwnedMutexLockFuture<T>where T: ?Sized,

source§

impl<T> Sync for OnceBox<T>where T: Sync + Send,

source§

impl<T> Sync for ThreadLocal<T>where T: Send,

source§

impl<T> Sync for ThinBox<T>where T: Sync + ?Sized,

ThinBox<T> is Sync if T is Sync because the data is owned.

source§

impl<T> Sync for alloc::collections::linked_list::Iter<'_, T>where T: Sync,

source§

impl<T> Sync for alloc::collections::linked_list::IterMut<'_, T>where T: Sync,

source§

impl<T> Sync for Arc<T>where T: Sync + Send + ?Sized,

1.4.0 · source§

impl<T> Sync for alloc::sync::Weak<T>where T: Sync + Send + ?Sized,

source§

impl<T> Sync for SyncUnsafeCell<T>where T: Sync + ?Sized,

1.31.0 · source§

impl<T> Sync for ChunksExactMut<'_, T>where T: Sync,

source§

impl<T> Sync for ChunksMut<'_, T>where T: Sync,

source§

impl<T> Sync for core::slice::iter::Iter<'_, T>where T: Sync,

source§

impl<T> Sync for core::slice::iter::IterMut<'_, T>where T: Sync,

1.31.0 · source§

impl<T> Sync for RChunksExactMut<'_, T>where T: Sync,

1.31.0 · source§

impl<T> Sync for RChunksMut<'_, T>where T: Sync,

source§

impl<T> Sync for AtomicPtr<T>

source§

impl<T> Sync for Exclusive<T>where T: ?Sized,

source§

impl<T> Sync for std::sync::mutex::Mutex<T>where T: Send + ?Sized,

1.19.0 · source§

impl<T> Sync for std::sync::mutex::MutexGuard<'_, T>where T: Sync + ?Sized,

1.70.0 · source§

impl<T> Sync for OnceLock<T>where T: Sync + Send,

source§

impl<T> Sync for std::sync::rwlock::RwLock<T>where T: Send + Sync + ?Sized,

1.23.0 · source§

impl<T> Sync for RwLockReadGuard<'_, T>where T: Sync + ?Sized,

1.23.0 · source§

impl<T> Sync for RwLockWriteGuard<'_, T>where T: Sync + ?Sized,

1.29.0 · source§

impl<T> Sync for JoinHandle<T>

source§

impl<T, A> Sync for RawDrain<'_, T, A>where A: Allocator + Copy + Sync, T: Sync,

source§

impl<T, A> Sync for RawIntoIter<T, A>where A: Allocator + Clone + Sync, T: Sync,

source§

impl<T, A> Sync for RawTable<T, A>where A: Allocator + Clone + Sync, T: Sync,

source§

impl<T, A> Sync for Cursor<'_, T, A>where T: Sync, A: Allocator + Sync,

source§

impl<T, A> Sync for CursorMut<'_, T, A>where T: Sync, A: Allocator + Sync,

source§

impl<T, A> Sync for LinkedList<T, A>where T: Sync, A: Allocator + Sync,

1.6.0 · source§

impl<T, A> Sync for alloc::collections::vec_deque::drain::Drain<'_, T, A>where T: Sync, A: Allocator + Sync,

1.6.0 · source§

impl<T, A> Sync for alloc::vec::drain::Drain<'_, T, A>where T: Sync, A: Sync + Allocator,

source§

impl<T, A> Sync for alloc::vec::into_iter::IntoIter<T, A>where T: Sync, A: Allocator + Sync,

source§

impl<T, C> Sync for OwnedRef<T, C>where T: Sync + Clear + Default, C: Config,

source§

impl<T, C> Sync for OwnedRefMut<T, C>where T: Sync + Clear + Default, C: Config,

source§

impl<T, C> Sync for Pool<T, C>where T: Sync + Clear + Default, C: Config,

source§

impl<T, C> Sync for OwnedEntry<T, C>where T: Sync, C: Config,

source§

impl<T, C> Sync for Slab<T, C>where T: Sync, C: Config,

source§

impl<T, F> Sync for Lazy<T, F>where F: Send, OnceCell<T>: Sync,

source§

impl<T, F> Sync for LazyLock<T, F>where T: Sync + Send, F: Send,

source§

impl<T, F, S> Sync for ScopeGuard<T, F, S>where T: Sync, F: FnOnce(T), S: Strategy,

source§

impl<T, N> Sync for generic_array::GenericArray<T, N>where T: Sync, N: ArrayLength<T>,

source§

impl<T, N> Sync for generic_array::GenericArray<T, N>where T: Sync, N: ArrayLength<T>,

source§

impl<T, O> Sync for bitvec::boxed::iter::IntoIter<T, O>where T: BitStore + Sync, O: BitOrder,

source§

impl<T, O> Sync for BitBox<T, O>where T: BitStore, O: BitOrder,

source§

impl<T, O> Sync for bitvec::slice::iter::Iter<'_, T, O>where T: BitStore, O: BitOrder, BitSlice<T, O>: Sync,

source§

impl<T, O> Sync for bitvec::slice::iter::IterMut<'_, T, O>where T: BitStore, O: BitOrder, BitSlice<T, O>: Sync,

source§

impl<T, O> Sync for BitSlice<T, O>where T: BitStore + Sync, O: BitOrder,

Bit-Slice Thread Safety

This allows bit-slice references to be moved across thread boundaries only when the underlying T element can tolerate concurrency.

All BitSlice references, shared or exclusive, are only threadsafe if the T element type is Send, because any given bit-slice reference may only have partial control of a memory element that is also being shared by a bit-slice reference on another thread. As such, this is never implemented for Cell<U>, but always implemented for AtomicU and U for a given unsigned integer type U.

Atomic integers safely handle concurrent writes, cells do not allow concurrency at all, so the only missing piece is &mut BitSlice<_, U: Unsigned>. This is handled by the aliasing system that the mutable splitters employ: a mutable reference to an unsynchronized bit-slice can only cross threads when no other handle is able to exist to the elements it governs. Splitting a mutable bit-slice causes the split halves to change over to either atomics or cells, so concurrency is either safe or impossible.

source§

impl<T, O> Sync for bitvec::vec::iter::Drain<'_, T, O>where T: BitStore, O: BitOrder, BitSlice<T, O>: Sync,

source§

impl<T, O> Sync for BitVec<T, O>where T: BitStore, O: BitOrder,

source§

impl<T, U> Sync for futures_util::lock::mutex::MappedMutexGuard<'_, T, U>where T: Sync + ?Sized, U: Sync + ?Sized,

Auto implementors§

§

impl Sync for Never

§

impl Sync for Void

§

impl Sync for DispatchError

§

impl Sync for InvalidTransaction

§

impl Sync for TransactionSource

§

impl Sync for TransactionValidityError

§

impl Sync for UnknownTransaction

§

impl Sync for ChildInfo

§

impl Sync for ChildType

§

impl Sync for KillStorageResult

§

impl Sync for StateVersion

§

impl Sync for Everything

§

impl Sync for ExecuteOverweightError

§

impl Sync for Nothing

§

impl Sync for ProcessMessageError

§

impl Sync for LookupError

§

impl Sync for BalanceStatus

§

impl Sync for DepositConsequence

§

impl Sync for ExistenceRequirement

§

impl Sync for DispatchClass

§

impl Sync for Pays

§

impl Sync for Alignment

§

impl Sync for CheckInherentsResult

§

impl Sync for Instance1

§

impl Sync for Instance2

§

impl Sync for Instance3

§

impl Sync for Instance4

§

impl Sync for Instance5

§

impl Sync for Instance6

§

impl Sync for Instance7

§

impl Sync for Instance8

§

impl Sync for Instance9

§

impl Sync for Instance10

§

impl Sync for Instance11

§

impl Sync for Instance12

§

impl Sync for Instance13

§

impl Sync for Instance14

§

impl Sync for Instance15

§

impl Sync for Instance16

§

impl Sync for GetDefault

§

impl Sync for InherentData

§

impl Sync for ValidTransaction

§

impl Sync for Weight

§

impl Sync for MultiRemovalResults

§

impl Sync for StorageNoopGuard

§

impl Sync for OptionQuery

§

impl Sync for ValueQuery

§

impl Sync for Blake2_128

§

impl Sync for Blake2_128Concat

§

impl Sync for Blake2_256

§

impl Sync for Identity

§

impl Sync for PalletId

§

impl Sync for Twox64Concat

§

impl Sync for Twox128

§

impl Sync for Twox256

§

impl Sync for Backing

§

impl Sync for CallMetadata

§

impl Sync for CrateVersion

§

impl Sync for EqualPrivilegeOnly

§

impl Sync for Footprint

§

impl Sync for PalletInfoData

§

impl Sync for SaturatingCurrencyToVote

§

impl Sync for StorageInfo

§

impl Sync for StorageVersion

§

impl Sync for TrackedStorageKey

§

impl Sync for U128CurrencyToVote

§

impl Sync for WithdrawReasons

§

impl Sync for BlockExecutionWeight

§

impl Sync for ExtrinsicBaseWeight

§

impl Sync for ParityDbWeight

§

impl Sync for RocksDbWeight

§

impl Sync for OldWeight

§

impl Sync for RuntimeDbWeight

§

impl Sync for WeightMeter

§

impl Sync for Error

§

impl Sync for DispatchInfo

§

impl Sync for PostDispatchInfo

§

impl Sync for PhantomPinned

§

impl<'a> !Sync for Arguments<'a>

§

impl<'a> !Sync for Formatter<'a>

§

impl<'a, 'b> !Sync for DebugList<'a, 'b>

§

impl<'a, 'b> !Sync for DebugMap<'a, 'b>

§

impl<'a, 'b> !Sync for DebugSet<'a, 'b>

§

impl<'a, 'b> !Sync for DebugStruct<'a, 'b>

§

impl<'a, 'b> !Sync for DebugTuple<'a, 'b>

§

impl<'a, T> Sync for frame_support::dispatch::result::Iter<'a, T>where T: Sync,

§

impl<'a, T> Sync for frame_support::dispatch::result::IterMut<'a, T>where T: Sync,

§

impl<'a, T, S> Sync for BoundedSlice<'a, T, S>where S: Sync, T: Sync,

§

impl<A, B> Sync for SameOrOther<A, B>where A: Sync, B: Sync,

§

impl<A, B, OnDrop, OppositeOnDrop> Sync for frame_support::traits::tokens::fungibles::Imbalance<A, B, OnDrop, OppositeOnDrop>where A: Sync, B: Sync, OnDrop: Sync, OppositeOnDrop: Sync,

§

impl<AccountId> Sync for AttributeNamespace<AccountId>where AccountId: Sync,

§

impl<AccountId> Sync for RawOrigin<AccountId>where AccountId: Sync,

§

impl<B, OnDrop, OppositeOnDrop> Sync for frame_support::traits::tokens::fungible::Imbalance<B, OnDrop, OppositeOnDrop>where B: Sync, OnDrop: Sync, OppositeOnDrop: Sync,

§

impl<B, PositiveImbalance> Sync for SignedImbalance<B, PositiveImbalance>where PositiveImbalance: Sync, <PositiveImbalance as Imbalance<B>>::Opposite: Sync,

§

impl<Balance> Sync for WithdrawConsequence<Balance>where Balance: Sync,

§

impl<Balance> Sync for WeightToFeeCoefficient<Balance>where Balance: Sync,

§

impl<Balance, Imbalance, Target1, Target2, const PART1: u32, const PART2: u32> Sync for SplitTwoWays<Balance, Imbalance, Target1, Target2, PART1, PART2>where Balance: Sync, Imbalance: Sync, Target1: Sync, Target2: Sync,

§

impl<BlockNumber> Sync for DispatchTime<BlockNumber>where BlockNumber: Sync,

§

impl<C, A> Sync for ActiveIssuanceOf<C, A>where A: Sync, C: Sync,

§

impl<C, A> Sync for TotalIssuanceOf<C, A>where A: Sync, C: Sync,

§

impl<CP> Sync for FromContainsPair<CP>where CP: Sync,

§

impl<E> Sync for MakeFatalError<E>where E: Sync,

§

impl<EO> Sync for AsEnsureOriginWithArg<EO>where EO: Sync,

§

impl<Error> Sync for ResultQuery<Error>where Error: Sync,

§

impl<Exclude> Sync for EverythingBut<Exclude>where Exclude: Sync,

§

impl<F, A, AccountId> Sync for frame_support::traits::tokens::fungible::ItemOf<F, A, AccountId>where A: Sync, AccountId: Sync, F: Sync,

§

impl<F, A, AccountId> Sync for frame_support::traits::tokens::nonfungible::ItemOf<F, A, AccountId>where A: Sync, AccountId: Sync, F: Sync,

§

impl<F, A, AccountId> Sync for frame_support::traits::tokens::nonfungible_v2::ItemOf<F, A, AccountId>where A: Sync, AccountId: Sync, F: Sync,

§

impl<F, T> Sync for ClearFilterGuard<F, T>where T: Sync, <F as FilterStack<T>>::Stack: Sync,

§

impl<F, T> Sync for FilterStackGuard<F, T>where F: Sync, T: Sync,

§

impl<Hasher, KeyType> Sync for Key<Hasher, KeyType>where Hasher: Sync, KeyType: Sync,

§

impl<K, T, H> Sync for StorageKeyIterator<K, T, H>where H: Sync, K: Sync, T: Sync,

§

impl<K, V, S> Sync for BoundedBTreeMap<K, V, S>where K: Sync, S: Sync, V: Sync,

§

impl<L, R> Sync for EitherOf<L, R>where L: Sync, R: Sync,

§

impl<L, R> Sync for EitherOfDiverse<L, R>where L: Sync, R: Sync,

§

impl<M> Sync for KeyLenOf<M>where M: Sync,

§

impl<OM> Sync for AsContains<OM>where OM: Sync,

§

impl<Orig, Mutator> Sync for TryMapSuccess<Orig, Mutator>where Mutator: Sync, Orig: Sync,

§

impl<Origin, PrivilegeCmp> Sync for EnsureOriginEqualOrHigherPrivilege<Origin, PrivilegeCmp>where Origin: Sync, PrivilegeCmp: Sync,

§

impl<Original, Mutator> Sync for MapSuccess<Original, Mutator>where Mutator: Sync, Original: Sync,

§

impl<P, T> Sync for ClassCountOf<P, T>where P: Sync, T: Sync,

§

impl<Prefix, Hasher1, Key1, Hasher2, Key2, Value, QueryKind, OnEmpty, MaxValues> Sync for StorageDoubleMap<Prefix, Hasher1, Key1, Hasher2, Key2, Value, QueryKind, OnEmpty, MaxValues>where Hasher1: Sync, Hasher2: Sync, Key1: Sync, Key2: Sync, MaxValues: Sync, OnEmpty: Sync, Prefix: Sync, QueryKind: Sync, Value: Sync,

§

impl<Prefix, Hasher, Key, Value, QueryKind, OnEmpty, MaxValues> Sync for CountedStorageMap<Prefix, Hasher, Key, Value, QueryKind, OnEmpty, MaxValues>where Hasher: Sync, Key: Sync, MaxValues: Sync, OnEmpty: Sync, Prefix: Sync, QueryKind: Sync, Value: Sync,

§

impl<Prefix, Hasher, Key, Value, QueryKind, OnEmpty, MaxValues> Sync for StorageMap<Prefix, Hasher, Key, Value, QueryKind, OnEmpty, MaxValues>where Hasher: Sync, Key: Sync, MaxValues: Sync, OnEmpty: Sync, Prefix: Sync, QueryKind: Sync, Value: Sync,

§

impl<Prefix, Key, Value, QueryKind, OnEmpty, MaxValues> Sync for StorageNMap<Prefix, Key, Value, QueryKind, OnEmpty, MaxValues>where Key: Sync, MaxValues: Sync, OnEmpty: Sync, Prefix: Sync, QueryKind: Sync, Value: Sync,

§

impl<Prefix, Value, QueryKind, OnEmpty> Sync for StorageValue<Prefix, Value, QueryKind, OnEmpty>where OnEmpty: Sync, Prefix: Sync, QueryKind: Sync, Value: Sync,

§

impl<R> Sync for TransactionOutcome<R>where R: Sync,

§

impl<S, L, K, T> Sync for StorageMapShim<S, L, K, T>where K: Sync, L: Sync, S: Sync, T: Sync,

§

impl<Success> Sync for NeverEnsureOrigin<Success>where Success: Sync,

§

impl<T> Sync for Bounded<T>where T: Sync,

§

impl<T> Sync for StorageIterator<T>where T: Sync,

§

impl<T> Sync for ChildTriePrefixIterator<T>

§

impl<T> Sync for KeyPrefixIterator<T>

§

impl<T> Sync for IsInVec<T>where T: Sync,

§

impl<T> Sync for WrapperKeepOpaque<T>where T: Sync,

§

impl<T> Sync for WrapperOpaque<T>where T: Sync,

§

impl<T> Sync for IdentityFee<T>where T: Sync,

§

impl<T> Sync for frame_support::dispatch::result::IntoIter<T>where T: Sync,

§

impl<T> Sync for PerDispatchClass<T>where T: Sync,

§

impl<T, A> Sync for Vec<T, A>where A: Sync, T: Sync,

§

impl<T, E> Sync for Result<T, E>where E: Sync, T: Sync,

§

impl<T, Hash> Sync for MaybeHashed<T, Hash>where Hash: Sync, T: Sync,

§

impl<T, M> Sync for ConstantMultiplier<T, M>where M: Sync, T: Sync,

§

impl<T, OnRemoval> Sync for PrefixIterator<T, OnRemoval>where OnRemoval: Sync,

§

impl<T, S> Sync for BoundedBTreeSet<T, S>where S: Sync, T: Sync,

§

impl<T, S> Sync for BoundedVec<T, S>where S: Sync, T: Sync,

§

impl<T, S> Sync for WeakBoundedVec<T, S>where S: Sync, T: Sync,

§

impl<T: ?Sized> Sync for PhantomData<T>where T: Sync,

§

impl<Tally, Moment, Class> Sync for PollStatus<Tally, Moment, Class>where Class: Sync, Moment: Sync, Tally: Sync,

§

impl<These, Except> Sync for TheseExcept<These, Except>where Except: Sync, These: Sync,

§

impl<These, Those> Sync for InsideBoth<These, Those>where These: Sync, Those: Sync,

§

impl<const T: bool> Sync for ConstBool<T>

§

impl<const T: i8> Sync for ConstI8<T>

§

impl<const T: i16> Sync for ConstI16<T>

§

impl<const T: i32> Sync for ConstI32<T>

§

impl<const T: i64> Sync for ConstI64<T>

§

impl<const T: i128> Sync for ConstI128<T>

§

impl<const T: u8> Sync for ConstU8<T>

§

impl<const T: u16> Sync for ConstU16<T>

§

impl<const T: u32> Sync for ConstU32<T>

§

impl<const T: u64> Sync for ConstU64<T>

§

impl<const T: u128> Sync for ConstU128<T>