struct V0SymbolMangler<'tcx> {
tcx: TyCtxt<'tcx>,
binders: Vec<BinderLevel>,
out: String,
is_exportable: bool,
start_offset: usize,
paths: FxHashMap<(DefId, &'tcx [GenericArg<'tcx>]), usize>,
types: FxHashMap<Ty<'tcx>, usize>,
consts: FxHashMap<Const<'tcx>, usize>,
}
Fields§
§tcx: TyCtxt<'tcx>
§binders: Vec<BinderLevel>
§out: String
§is_exportable: bool
§start_offset: usize
The length of the prefix in out
(e.g. 2 for _R
).
paths: FxHashMap<(DefId, &'tcx [GenericArg<'tcx>]), usize>
The values are start positions in out
, in bytes.
types: FxHashMap<Ty<'tcx>, usize>
§consts: FxHashMap<Const<'tcx>, usize>
Implementations§
Source§impl<'tcx> V0SymbolMangler<'tcx>
impl<'tcx> V0SymbolMangler<'tcx>
fn push(&mut self, s: &str)
Sourcefn push_integer_62(&mut self, x: u64)
fn push_integer_62(&mut self, x: u64)
Push a _
-terminated base 62 integer, using the format
specified in the RFC as <base-62-number>
, that is:
x = 0
is encoded as just the"_"
terminatorx > 0
is encoded asx - 1
in base 62, followed by"_"
, e.g.1
becomes"0_"
,62
becomes"Z_"
, etc.
Sourcefn push_opt_integer_62(&mut self, tag: &str, x: u64)
fn push_opt_integer_62(&mut self, tag: &str, x: u64)
Push a tag
-prefixed base 62 integer, when larger than 0
, that is:
x = 0
is encoded as""
(nothing)x > 0
is encoded as thetag
followed bypush_integer_62(x - 1)
e.g.1
becomestag + "_"
,2
becomestag + "0_"
, etc.
fn push_disambiguator(&mut self, dis: u64)
fn push_ident(&mut self, ident: &str)
fn path_append_ns( &mut self, print_prefix: impl FnOnce(&mut Self) -> Result<(), PrintError>, ns: char, disambiguator: u64, name: &str, ) -> Result<(), PrintError>
fn print_backref(&mut self, i: usize) -> Result<(), PrintError>
fn wrap_binder<T>(
&mut self,
value: &Binder<'tcx, T>,
print_value: impl FnOnce(&mut Self, &T) -> Result<(), PrintError>,
) -> Result<(), PrintError>where
T: TypeVisitable<TyCtxt<'tcx>>,
fn print_pat(&mut self, pat: Pattern<'tcx>) -> Result<(), Error>
Trait Implementations§
Source§impl<'tcx> Printer<'tcx> for V0SymbolMangler<'tcx>
impl<'tcx> Printer<'tcx> for V0SymbolMangler<'tcx>
fn tcx(&self) -> TyCtxt<'tcx>
Source§fn print_def_path(
&mut self,
def_id: DefId,
args: &'tcx [GenericArg<'tcx>],
) -> Result<(), PrintError>
fn print_def_path( &mut self, def_id: DefId, args: &'tcx [GenericArg<'tcx>], ) -> Result<(), PrintError>
Appends a representation of an entity with a normal path, e.g. “std::io::Read”.
Source§fn print_impl_path(
&mut self,
impl_def_id: DefId,
args: &'tcx [GenericArg<'tcx>],
) -> Result<(), PrintError>
fn print_impl_path( &mut self, impl_def_id: DefId, args: &'tcx [GenericArg<'tcx>], ) -> Result<(), PrintError>
Like
print_def_path
, but for DefPathData::Impl
.Source§fn print_region(&mut self, region: Region<'_>) -> Result<(), PrintError>
fn print_region(&mut self, region: Region<'_>) -> Result<(), PrintError>
Appends a representation of a region.
Source§fn print_type(&mut self, ty: Ty<'tcx>) -> Result<(), PrintError>
fn print_type(&mut self, ty: Ty<'tcx>) -> Result<(), PrintError>
Appends a representation of a type.
Source§fn print_dyn_existential(
&mut self,
predicates: &'tcx List<PolyExistentialPredicate<'tcx>>,
) -> Result<(), PrintError>
fn print_dyn_existential( &mut self, predicates: &'tcx List<PolyExistentialPredicate<'tcx>>, ) -> Result<(), PrintError>
Appends a representation of a list of
PolyExistentialPredicate
s.Source§fn print_const(&mut self, ct: Const<'tcx>) -> Result<(), PrintError>
fn print_const(&mut self, ct: Const<'tcx>) -> Result<(), PrintError>
Appends a representation of a const.
Source§fn print_crate_name(&mut self, cnum: CrateNum) -> Result<(), PrintError>
fn print_crate_name(&mut self, cnum: CrateNum) -> Result<(), PrintError>
Appends a representation of a crate name, e.g.
std
, or even ``.Source§fn print_path_with_qualified(
&mut self,
self_ty: Ty<'tcx>,
trait_ref: Option<TraitRef<'tcx>>,
) -> Result<(), PrintError>
fn print_path_with_qualified( &mut self, self_ty: Ty<'tcx>, trait_ref: Option<TraitRef<'tcx>>, ) -> Result<(), PrintError>
Appends a representation of a qualified path segment, e.g.
<OsString as From<&T>>
.
If trait_ref
is None
, it may fall back to simpler forms, e.g. <Vec<T>>
or just Foo
.Source§fn print_path_with_impl(
&mut self,
_: impl FnOnce(&mut Self) -> Result<(), PrintError>,
_: Ty<'tcx>,
_: Option<TraitRef<'tcx>>,
) -> Result<(), PrintError>
fn print_path_with_impl( &mut self, _: impl FnOnce(&mut Self) -> Result<(), PrintError>, _: Ty<'tcx>, _: Option<TraitRef<'tcx>>, ) -> Result<(), PrintError>
Source§fn print_path_with_simple(
&mut self,
print_prefix: impl FnOnce(&mut Self) -> Result<(), PrintError>,
disambiguated_data: &DisambiguatedDefPathData,
) -> Result<(), PrintError>
fn print_path_with_simple( &mut self, print_prefix: impl FnOnce(&mut Self) -> Result<(), PrintError>, disambiguated_data: &DisambiguatedDefPathData, ) -> Result<(), PrintError>
Appends a representation of a (full or partial) simple path, in two parts.
print_prefix
,
when called, appends the representation of the leading segments. The rest of the method
appends the representation of the final segment, the details of which are in
disambiguated_data
. Read moreSource§fn print_path_with_generic_args(
&mut self,
print_prefix: impl FnOnce(&mut Self) -> Result<(), PrintError>,
args: &[GenericArg<'tcx>],
) -> Result<(), PrintError>
fn print_path_with_generic_args( &mut self, print_prefix: impl FnOnce(&mut Self) -> Result<(), PrintError>, args: &[GenericArg<'tcx>], ) -> Result<(), PrintError>
Appends a representation of a path ending in generic args, in two parts.
print_prefix
,
when called, appends the leading segments. The rest of the method appends the
representation of the generic args. (Some printers choose to skip appending the generic
args.) Read morefn print_coroutine_with_kind( &mut self, def_id: DefId, parent_args: &'tcx [GenericArg<'tcx>], kind: Ty<'tcx>, ) -> Result<(), Error>
fn default_print_def_path( &mut self, def_id: DefId, args: &'tcx [GenericArg<'tcx>], ) -> Result<(), Error>
fn default_print_impl_path( &mut self, impl_def_id: DefId, self_ty: Ty<'tcx>, impl_trait_ref: Option<TraitRef<TyCtxt<'tcx>>>, ) -> Result<(), Error>
Auto Trait Implementations§
impl<'tcx> DynSend for V0SymbolMangler<'tcx>
impl<'tcx> DynSync for V0SymbolMangler<'tcx>
impl<'tcx> Freeze for V0SymbolMangler<'tcx>
impl<'tcx> !RefUnwindSafe for V0SymbolMangler<'tcx>
impl<'tcx> !Send for V0SymbolMangler<'tcx>
impl<'tcx> !Sync for V0SymbolMangler<'tcx>
impl<'tcx> Unpin for V0SymbolMangler<'tcx>
impl<'tcx> !UnwindSafe for V0SymbolMangler<'tcx>
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
Source§impl<T, R> CollectAndApply<T, R> for T
impl<T, R> CollectAndApply<T, R> for T
Source§impl<T> Filterable for T
impl<T> Filterable for T
Source§fn filterable(
self,
filter_name: &'static str,
) -> RequestFilterDataProvider<T, fn(DataRequest<'_>) -> bool>
fn filterable( self, filter_name: &'static str, ) -> RequestFilterDataProvider<T, fn(DataRequest<'_>) -> bool>
Creates a filterable data provider with the given name for debugging. Read more
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>
Converts
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>
Converts
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<P> IntoQueryParam<P> for P
impl<P> IntoQueryParam<P> for P
fn into_query_param(self) -> P
Source§impl<T> MaybeResult<T> for T
impl<T> MaybeResult<T> for T
Source§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<I, T, U> Upcast<I, U> for Twhere
U: UpcastFrom<I, T>,
impl<I, T, U> Upcast<I, U> for Twhere
U: UpcastFrom<I, T>,
Source§impl<I, T> UpcastFrom<I, T> for T
impl<I, T> UpcastFrom<I, T> for T
fn upcast_from(from: T, _tcx: I) -> T
Source§impl<Tcx, T> Value<Tcx> for Twhere
Tcx: DepContext,
impl<Tcx, T> Value<Tcx> for Twhere
Tcx: DepContext,
default fn from_cycle_error( tcx: Tcx, cycle_error: &CycleError, _guar: ErrorGuaranteed, ) -> T
Source§impl<T> WithSubscriber for T
impl<T> WithSubscriber for T
Source§fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
Source§fn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
impl<T> ErasedDestructor for Twhere
T: 'static,
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: 168 bytes