2021-07-10 16:34:41 -05:00
|
|
|
use rustc_span::{ExpnId, LocalExpnId};
|
2019-12-22 16:42:04 -06:00
|
|
|
use std::fmt;
|
2019-11-29 14:41:22 -06:00
|
|
|
|
|
|
|
rustc_index::newtype_index! {
|
2021-01-09 19:44:10 -06:00
|
|
|
/// Identifies an AST node.
|
|
|
|
///
|
|
|
|
/// This identifies top-level definitions, expressions, and everything in between.
|
|
|
|
/// This is later turned into [`DefId`] and `HirId` for the HIR.
|
|
|
|
///
|
|
|
|
/// [`DefId`]: rustc_span::def_id::DefId
|
2019-11-29 14:41:22 -06:00
|
|
|
pub struct NodeId {
|
|
|
|
DEBUG_FORMAT = "NodeId({})"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-12-24 15:42:56 -06:00
|
|
|
rustc_data_structures::define_id_collections!(NodeMap, NodeSet, NodeId);
|
|
|
|
|
2021-01-09 19:44:10 -06:00
|
|
|
/// The [`NodeId`] used to represent the root of the crate.
|
2020-03-10 15:44:53 -05:00
|
|
|
pub const CRATE_NODE_ID: NodeId = NodeId::from_u32(0);
|
2020-01-11 08:03:15 -06:00
|
|
|
|
2021-02-07 21:42:12 -06:00
|
|
|
/// When parsing and at the beginning of doing expansions, we initially give all AST nodes
|
|
|
|
/// this dummy AST [`NodeId`]. Then, during a later phase of expansion, we renumber them
|
|
|
|
/// to have small, positive IDs.
|
2020-01-11 08:03:15 -06:00
|
|
|
pub const DUMMY_NODE_ID: NodeId = NodeId::MAX;
|
|
|
|
|
2019-11-29 14:41:22 -06:00
|
|
|
impl NodeId {
|
|
|
|
pub fn placeholder_from_expn_id(expn_id: ExpnId) -> Self {
|
2021-07-10 16:34:41 -05:00
|
|
|
NodeId::from_u32(expn_id.expect_local().as_u32())
|
2019-11-29 14:41:22 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
pub fn placeholder_to_expn_id(self) -> ExpnId {
|
2021-07-10 16:34:41 -05:00
|
|
|
LocalExpnId::from_u32(self.as_u32()).to_expn_id()
|
2019-11-29 14:41:22 -06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl fmt::Display for NodeId {
|
|
|
|
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
|
|
|
|
fmt::Display::fmt(&self.as_u32(), f)
|
|
|
|
}
|
|
|
|
}
|