Struct rustc_metadata::rmeta::LazyTable
source · struct LazyTable<I, T> {
position: NonZeroUsize,
width: usize,
len: usize,
_marker: PhantomData<fn(_: I) -> T>,
}
Expand description
A list of lazily-decoded values, with the added capability of random access.
Random-access table (i.e. offering constant-time get
/set
), similar to
LazyArray<T>
, but without requiring encoding or decoding all the values
eagerly and in-order.
Fields§
§position: NonZeroUsize
§width: usize
The encoded size of the elements of a table is selected at runtime to drop trailing zeroes. This is the number of bytes used for each table element.
len: usize
How many elements are in the table.
_marker: PhantomData<fn(_: I) -> T>
Implementations§
source§impl<I: Idx, const N: usize, T: FixedSizeEncoding<ByteArray = [u8; N]> + ParameterizedOverTcx> LazyTable<I, T>where
for<'tcx> T::Value<'tcx>: FixedSizeEncoding<ByteArray = [u8; N]>,
impl<I: Idx, const N: usize, T: FixedSizeEncoding<ByteArray = [u8; N]> + ParameterizedOverTcx> LazyTable<I, T>where for<'tcx> T::Value<'tcx>: FixedSizeEncoding<ByteArray = [u8; N]>,
source§impl<I, T> LazyTable<I, T>
impl<I, T> LazyTable<I, T>
fn from_position_and_encoded_size( position: NonZeroUsize, width: usize, len: usize ) -> LazyTable<I, T>
Trait Implementations§
source§impl<'a, 'tcx, I: Idx, T> Decodable<DecodeContext<'a, 'tcx>> for LazyTable<I, T>
impl<'a, 'tcx, I: Idx, T> Decodable<DecodeContext<'a, 'tcx>> for LazyTable<I, T>
fn decode(decoder: &mut DecodeContext<'a, 'tcx>) -> Self
source§impl<'a, 'tcx, I, T> Encodable<EncodeContext<'a, 'tcx>> for LazyTable<I, T>
impl<'a, 'tcx, I, T> Encodable<EncodeContext<'a, 'tcx>> for LazyTable<I, T>
fn encode(&self, e: &mut EncodeContext<'a, 'tcx>)
source§impl<I: 'static, T: ParameterizedOverTcx> ParameterizedOverTcx for LazyTable<I, T>
impl<I: 'static, T: ParameterizedOverTcx> ParameterizedOverTcx for LazyTable<I, T>
type Value<'tcx> = LazyTable<I, <T as ParameterizedOverTcx>::Value<'tcx>>
impl<I, T> Copy for LazyTable<I, T>
Auto Trait Implementations§
impl<I, T> RefUnwindSafe for LazyTable<I, T>
impl<I, T> Send for LazyTable<I, T>
impl<I, T> Sync for LazyTable<I, T>
impl<I, T> Unpin for LazyTable<I, T>
impl<I, T> UnwindSafe for LazyTable<I, T>
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
Mutably borrows from an owned value. Read more
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: 24 bytes