fixup! Some comments and documentation for name resolution crate
This commit is contained in:
parent
68d6eddaf8
commit
433a03e6ff
@ -878,8 +878,9 @@ enum RibKind<'a> {
|
|||||||
///
|
///
|
||||||
/// A rib represents a scope names can live in. Note that these appear in many places, not just
|
/// A rib represents a scope names can live in. Note that these appear in many places, not just
|
||||||
/// around braces. At any place where the list of accessible names (of the given namespace)
|
/// around braces. At any place where the list of accessible names (of the given namespace)
|
||||||
/// changes, a new rib is put onto a stack. This may be, for example, a `let` statement (because it
|
/// changes or a new restrictions on the name accessibility are introduced, a new rib is put onto a
|
||||||
/// introduces variables), a macro, etc.
|
/// stack. This may be, for example, a `let` statement (because it introduces variables), a macro,
|
||||||
|
/// etc.
|
||||||
///
|
///
|
||||||
/// Different [rib kinds](enum.RibKind) are transparent for different names.
|
/// Different [rib kinds](enum.RibKind) are transparent for different names.
|
||||||
///
|
///
|
||||||
@ -935,11 +936,26 @@ enum PathResult<'a> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
enum ModuleKind {
|
enum ModuleKind {
|
||||||
/// Inline `mod something { ... }`.
|
/// An anonymous module, eg. just a block.
|
||||||
Block(NodeId),
|
|
||||||
/// Module from another file.
|
|
||||||
///
|
///
|
||||||
/// Also called a normal module in the following code.
|
/// ```
|
||||||
|
/// fn main() {
|
||||||
|
/// fn f() {} // (1)
|
||||||
|
/// { // This is an anonymous module
|
||||||
|
/// f(); // This resolves to (2) as we are inside the block.
|
||||||
|
/// fn f() {} // (2)
|
||||||
|
/// }
|
||||||
|
/// f(); // Resolves to (1)
|
||||||
|
/// }
|
||||||
|
/// ```
|
||||||
|
Block(NodeId),
|
||||||
|
/// Any module with a name.
|
||||||
|
///
|
||||||
|
/// This could be:
|
||||||
|
///
|
||||||
|
/// * A normal module ‒ either `mod from_file;` or `mod from_block { }`.
|
||||||
|
/// * A trait or an enum (it implicitly contains associated types, methods and variant
|
||||||
|
/// constructors).
|
||||||
Def(Def, Name),
|
Def(Def, Name),
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1444,8 +1460,8 @@ impl<'a, 'b: 'a> ty::DefIdTree for &'a Resolver<'b> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// This is the interface through which the rest of the compiler asks about name resolution after
|
/// This interface is used through the AST→HIR step, to embed full paths into the HIR. After that
|
||||||
/// the whole AST has been indexed.
|
/// the resolver is no longer needed as all the relevant information is inline.
|
||||||
impl<'a> hir::lowering::Resolver for Resolver<'a> {
|
impl<'a> hir::lowering::Resolver for Resolver<'a> {
|
||||||
fn resolve_hir_path(&mut self, path: &mut hir::Path, is_value: bool) {
|
fn resolve_hir_path(&mut self, path: &mut hir::Path, is_value: bool) {
|
||||||
self.resolve_hir_path_cb(path, is_value,
|
self.resolve_hir_path_cb(path, is_value,
|
||||||
|
Loading…
Reference in New Issue
Block a user