diff options
| author | Barosl Lee <vcs@barosl.com> | 2015-05-26 11:27:15 +0900 |
|---|---|---|
| committer | Barosl Lee <vcs@barosl.com> | 2015-05-26 17:42:56 +0900 |
| commit | 0ae30e608c5823a195af62051bfc4e9460f4bd25 (patch) | |
| tree | 2968d67e7b30702c520b31672c4ff5b5595c1b4e /src/libsyntax | |
| parent | 7cb9914fceaeaa6a39add43d3da15bb6e1d191f6 (diff) | |
| download | rust-0ae30e608c5823a195af62051bfc4e9460f4bd25.tar.gz rust-0ae30e608c5823a195af62051bfc4e9460f4bd25.zip | |
Associate each path in a `use` declaration with the item in the AST map
Currently, for `use` declarations with multiple paths, only the `use` item itself is saved in the AST map, not the individual path nodes. This can lead to a problem when a span of a specific path node is needed. For example, #24818 caused an ICE because of this, in `ImportResolver::check_for_conflicting_import()`. Fixes #25763.
Diffstat (limited to 'src/libsyntax')
| -rw-r--r-- | src/libsyntax/ast_map/mod.rs | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/src/libsyntax/ast_map/mod.rs b/src/libsyntax/ast_map/mod.rs index 795391d4009..ce6c33c6ab6 100644 --- a/src/libsyntax/ast_map/mod.rs +++ b/src/libsyntax/ast_map/mod.rs @@ -714,6 +714,16 @@ impl<'ast> Visitor<'ast> for NodeCollector<'ast> { self.insert(ti.id, NodeTraitItem(ti)); } } + ItemUse(ref view_path) => { + match view_path.node { + ViewPathList(_, ref paths) => { + for path in paths { + self.insert(path.node.id(), NodeItem(i)); + } + } + _ => () + } + } _ => {} } visit::walk_item(self, i); |
