pub(crate) struct JsonRenderer<'tcx> {
tcx: TyCtxt<'tcx>,
index: Rc<RefCell<FxHashMap<Id, Item>>>,
out_dir: Option<PathBuf>,
cache: Rc<Cache>,
imported_items: DefIdSet,
id_interner: Rc<RefCell<FxHashMap<(FullItemId, Option<FullItemId>), Id>>>,
}
Fields§
§tcx: TyCtxt<'tcx>
§index: Rc<RefCell<FxHashMap<Id, Item>>>
A mapping of IDs that contains all local items for this crate which gets output as a top level field of the JSON blob.
out_dir: Option<PathBuf>
The directory where the JSON blob should be written to.
If this is None
, the blob will be printed to stdout
instead.
cache: Rc<Cache>
§imported_items: DefIdSet
§id_interner: Rc<RefCell<FxHashMap<(FullItemId, Option<FullItemId>), Id>>>
Implementations§
source§impl JsonRenderer<'_>
impl JsonRenderer<'_>
pub(super) fn convert_item(&self, item: Item) -> Option<Item>
fn convert_span(&self, span: Span) -> Option<Span>
fn convert_visibility(&self, v: Option<Visibility<DefId>>) -> Visibility
pub(crate) fn id_from_item_default(&self, item_id: ItemId) -> Id
pub(crate) fn id_from_item_inner( &self, item_id: ItemId, name: Option<Symbol>, extra: Option<Id>, ) -> Id
pub(crate) fn id_from_item(&self, item: &Item) -> Id
fn ids(&self, items: impl IntoIterator<Item = Item>) -> Vec<Id>
fn ids_keeping_stripped( &self, items: impl IntoIterator<Item = Item>, ) -> Vec<Option<Id>>
source§impl<'tcx> JsonRenderer<'tcx>
impl<'tcx> JsonRenderer<'tcx>
Trait Implementations§
source§impl<'tcx> Clone for JsonRenderer<'tcx>
impl<'tcx> Clone for JsonRenderer<'tcx>
source§fn clone(&self) -> JsonRenderer<'tcx>
fn clone(&self) -> JsonRenderer<'tcx>
Returns a copy of the value. Read more
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moresource§impl<'tcx> FormatRenderer<'tcx> for JsonRenderer<'tcx>
impl<'tcx> FormatRenderer<'tcx> for JsonRenderer<'tcx>
source§fn item(&mut self, item: Item) -> Result<(), Error>
fn item(&mut self, item: Item) -> Result<(), Error>
Inserts an item into the index. This should be used rather than directly calling insert on the hashmap because certain items (traits and types) need to have their mappings for trait implementations filled out before they’re inserted.
source§const RUN_ON_MODULE: bool = false
const RUN_ON_MODULE: bool = false
Whether to call
item
recursively for modules Read moresource§fn descr() -> &'static str
fn descr() -> &'static str
Gives a description of the renderer. Used for performance profiling.
source§fn init(
krate: Crate,
options: RenderOptions,
cache: Cache,
tcx: TyCtxt<'tcx>,
) -> Result<(Self, Crate), Error>
fn init( krate: Crate, options: RenderOptions, cache: Cache, tcx: TyCtxt<'tcx>, ) -> Result<(Self, Crate), Error>
Sets up any state required for the renderer. When this is called the cache has already been
populated.
source§fn make_child_renderer(&self) -> Self
fn make_child_renderer(&self) -> Self
Make a new renderer to render a child of the item currently being rendered.
source§fn mod_item_in(&mut self, _item: &Item) -> Result<(), Error>
fn mod_item_in(&mut self, _item: &Item) -> Result<(), Error>
Renders a module (should not handle recursing into children).
source§fn after_krate(&mut self) -> Result<(), Error>
fn after_krate(&mut self) -> Result<(), Error>
Post processing hook for cleanup and dumping output to files.
fn cache(&self) -> &Cache
Auto Trait Implementations§
impl<'tcx> Freeze for JsonRenderer<'tcx>
impl<'tcx> !RefUnwindSafe for JsonRenderer<'tcx>
impl<'tcx> !Send for JsonRenderer<'tcx>
impl<'tcx> !Sync for JsonRenderer<'tcx>
impl<'tcx> Unpin for JsonRenderer<'tcx>
impl<'tcx> !UnwindSafe for JsonRenderer<'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> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
🔬This is a nightly-only experimental API. (
clone_to_uninit
)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<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>
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: 88 bytes