Skip to content

Commit 5dd8614

Browse files
committed
Pass Option<Symbol> to def_path_data/create_def methods.
It's clearer than using `kw::Empty` to mean `None`.
1 parent 039eb30 commit 5dd8614

File tree

10 files changed

+45
-51
lines changed

10 files changed

+45
-51
lines changed

compiler/rustc_ast_lowering/src/expr.rs

+2-2
Original file line numberDiff line numberDiff line change
@@ -13,7 +13,7 @@ use rustc_middle::span_bug;
1313
use rustc_middle::ty::TyCtxt;
1414
use rustc_session::errors::report_lit_error;
1515
use rustc_span::source_map::{Spanned, respan};
16-
use rustc_span::{DUMMY_SP, DesugaringKind, Ident, Span, Symbol, kw, sym};
16+
use rustc_span::{DUMMY_SP, DesugaringKind, Ident, Span, Symbol, sym};
1717
use thin_vec::{ThinVec, thin_vec};
1818
use visit::{Visitor, walk_expr};
1919

@@ -483,7 +483,7 @@ impl<'hir> LoweringContext<'_, 'hir> {
483483
if legacy_args_idx.contains(&idx) {
484484
let parent_def_id = self.current_hir_id_owner.def_id;
485485
let node_id = self.next_node_id();
486-
self.create_def(parent_def_id, node_id, kw::Empty, DefKind::AnonConst, f.span);
486+
self.create_def(parent_def_id, node_id, None, DefKind::AnonConst, f.span);
487487
let mut visitor = WillCreateDefIdsVisitor {};
488488
let const_value = if let ControlFlow::Break(span) = visitor.visit_expr(&arg) {
489489
AstP(Expr {

compiler/rustc_ast_lowering/src/lib.rs

+3-4
Original file line numberDiff line numberDiff line change
@@ -492,7 +492,7 @@ impl<'a, 'hir> LoweringContext<'a, 'hir> {
492492
&mut self,
493493
parent: LocalDefId,
494494
node_id: ast::NodeId,
495-
name: Symbol,
495+
name: Option<Symbol>,
496496
def_kind: DefKind,
497497
span: Span,
498498
) -> LocalDefId {
@@ -772,7 +772,7 @@ impl<'a, 'hir> LoweringContext<'a, 'hir> {
772772
let _def_id = self.create_def(
773773
self.current_hir_id_owner.def_id,
774774
param,
775-
kw::UnderscoreLifetime,
775+
Some(kw::UnderscoreLifetime),
776776
DefKind::LifetimeParam,
777777
ident.span,
778778
);
@@ -2088,8 +2088,7 @@ impl<'a, 'hir> LoweringContext<'a, 'hir> {
20882088
// We're lowering a const argument that was originally thought to be a type argument,
20892089
// so the def collector didn't create the def ahead of time. That's why we have to do
20902090
// it here.
2091-
let def_id =
2092-
self.create_def(parent_def_id, node_id, kw::Empty, DefKind::AnonConst, span);
2091+
let def_id = self.create_def(parent_def_id, node_id, None, DefKind::AnonConst, span);
20932092
let hir_id = self.lower_node_id(node_id);
20942093

20952094
let path_expr = Expr {

compiler/rustc_const_eval/src/interpret/intern.rs

+1-1
Original file line numberDiff line numberDiff line change
@@ -104,7 +104,7 @@ fn intern_as_new_static<'tcx>(
104104
) {
105105
let feed = tcx.create_def(
106106
static_id,
107-
sym::nested,
107+
Some(sym::nested),
108108
DefKind::Static { safety: hir::Safety::Safe, mutability: alloc.0.mutability, nested: true },
109109
);
110110
tcx.set_nested_alloc_id_static(alloc_id, feed.def_id());

compiler/rustc_hir/src/def.rs

+7-5
Original file line numberDiff line numberDiff line change
@@ -253,7 +253,9 @@ impl DefKind {
253253
}
254254
}
255255

256-
pub fn def_path_data(self, name: Symbol) -> DefPathData {
256+
// Some `DefKind`s require a name, some don't. Panics if one is needed but
257+
// not provided.
258+
pub fn def_path_data(self, name: Option<Symbol>) -> DefPathData {
257259
match self {
258260
DefKind::Mod
259261
| DefKind::Struct
@@ -266,7 +268,7 @@ impl DefKind {
266268
| DefKind::TraitAlias
267269
| DefKind::AssocTy
268270
| DefKind::TyParam
269-
| DefKind::ExternCrate => DefPathData::TypeNs(name),
271+
| DefKind::ExternCrate => DefPathData::TypeNs(name.unwrap()),
270272
// It's not exactly an anon const, but wrt DefPathData, there
271273
// is no difference.
272274
DefKind::Static { nested: true, .. } => DefPathData::AnonConst,
@@ -276,9 +278,9 @@ impl DefKind {
276278
| DefKind::Static { .. }
277279
| DefKind::AssocFn
278280
| DefKind::AssocConst
279-
| DefKind::Field => DefPathData::ValueNs(name),
280-
DefKind::Macro(..) => DefPathData::MacroNs(name),
281-
DefKind::LifetimeParam => DefPathData::LifetimeNs(name),
281+
| DefKind::Field => DefPathData::ValueNs(name.unwrap()),
282+
DefKind::Macro(..) => DefPathData::MacroNs(name.unwrap()),
283+
DefKind::LifetimeParam => DefPathData::LifetimeNs(name.unwrap()),
282284
DefKind::Ctor(..) => DefPathData::Ctor,
283285
DefKind::Use => DefPathData::Use,
284286
DefKind::ForeignMod => DefPathData::ForeignMod,

compiler/rustc_hir_analysis/src/collect/resolve_bound_vars.rs

+2-1
Original file line numberDiff line numberDiff line change
@@ -1462,7 +1462,8 @@ impl<'a, 'tcx> BoundVarContext<'a, 'tcx> {
14621462
for &(opaque_def_id, captures) in opaque_capture_scopes.iter().rev() {
14631463
let mut captures = captures.borrow_mut();
14641464
let remapped = *captures.entry(lifetime).or_insert_with(|| {
1465-
let feed = self.tcx.create_def(opaque_def_id, ident.name, DefKind::LifetimeParam);
1465+
let feed =
1466+
self.tcx.create_def(opaque_def_id, Some(ident.name), DefKind::LifetimeParam);
14661467
feed.def_span(ident.span);
14671468
feed.def_ident_span(Some(ident.span));
14681469
feed.def_id()

compiler/rustc_middle/src/ty/context.rs

+2-2
Original file line numberDiff line numberDiff line change
@@ -1885,7 +1885,7 @@ impl<'tcx> TyCtxtAt<'tcx> {
18851885
pub fn create_def(
18861886
self,
18871887
parent: LocalDefId,
1888-
name: Symbol,
1888+
name: Option<Symbol>,
18891889
def_kind: DefKind,
18901890
) -> TyCtxtFeed<'tcx, LocalDefId> {
18911891
let feed = self.tcx.create_def(parent, name, def_kind);
@@ -1900,7 +1900,7 @@ impl<'tcx> TyCtxt<'tcx> {
19001900
pub fn create_def(
19011901
self,
19021902
parent: LocalDefId,
1903-
name: Symbol,
1903+
name: Option<Symbol>,
19041904
def_kind: DefKind,
19051905
) -> TyCtxtFeed<'tcx, LocalDefId> {
19061906
let data = def_kind.def_path_data(name);

compiler/rustc_mir_transform/src/coroutine/by_move_body.rs

+1-2
Original file line numberDiff line numberDiff line change
@@ -78,7 +78,6 @@ use rustc_middle::hir::place::{Projection, ProjectionKind};
7878
use rustc_middle::mir::visit::MutVisitor;
7979
use rustc_middle::mir::{self, dump_mir};
8080
use rustc_middle::ty::{self, InstanceKind, Ty, TyCtxt, TypeVisitableExt};
81-
use rustc_span::kw;
8281

8382
pub(crate) fn coroutine_by_move_body_def_id<'tcx>(
8483
tcx: TyCtxt<'tcx>,
@@ -214,7 +213,7 @@ pub(crate) fn coroutine_by_move_body_def_id<'tcx>(
214213
MakeByMoveBody { tcx, field_remapping, by_move_coroutine_ty }.visit_body(&mut by_move_body);
215214

216215
// This will always be `{closure#1}`, since the original coroutine is `{closure#0}`.
217-
let body_def = tcx.create_def(parent_def_id, kw::Empty, DefKind::SyntheticCoroutineBody);
216+
let body_def = tcx.create_def(parent_def_id, None, DefKind::SyntheticCoroutineBody);
218217
by_move_body.source =
219218
mir::MirSource::from_instance(InstanceKind::Item(body_def.def_id().to_def_id()));
220219
dump_mir(tcx, false, "built", &"after", &by_move_body, |_, _| Ok(()));

compiler/rustc_resolve/src/def_collector.rs

+21-31
Original file line numberDiff line numberDiff line change
@@ -9,7 +9,7 @@ use rustc_hir as hir;
99
use rustc_hir::def::{CtorKind, CtorOf, DefKind};
1010
use rustc_hir::def_id::LocalDefId;
1111
use rustc_span::hygiene::LocalExpnId;
12-
use rustc_span::{Span, Symbol, kw, sym};
12+
use rustc_span::{Span, Symbol, sym};
1313
use tracing::debug;
1414

1515
use crate::{ImplTraitContext, InvocationParent, Resolver};
@@ -38,7 +38,7 @@ impl<'a, 'ra, 'tcx> DefCollector<'a, 'ra, 'tcx> {
3838
fn create_def(
3939
&mut self,
4040
node_id: NodeId,
41-
name: Symbol,
41+
name: Option<Symbol>,
4242
def_kind: DefKind,
4343
span: Span,
4444
) -> LocalDefId {
@@ -89,7 +89,7 @@ impl<'a, 'ra, 'tcx> DefCollector<'a, 'ra, 'tcx> {
8989
self.visit_macro_invoc(field.id);
9090
} else {
9191
let name = field.ident.map_or_else(|| sym::integer(index(self)), |ident| ident.name);
92-
let def = self.create_def(field.id, name, DefKind::Field, field.span);
92+
let def = self.create_def(field.id, Some(name), DefKind::Field, field.span);
9393
self.with_parent(def, |this| visit::walk_field_def(this, field));
9494
}
9595
}
@@ -161,7 +161,7 @@ impl<'a, 'ra, 'tcx> visit::Visitor<'a> for DefCollector<'a, 'ra, 'tcx> {
161161
return self.visit_macro_invoc(i.id);
162162
}
163163
};
164-
let def_id = self.create_def(i.id, i.ident.name, def_kind, i.span);
164+
let def_id = self.create_def(i.id, Some(i.ident.name), def_kind, i.span);
165165

166166
if let Some(macro_data) = opt_macro_data {
167167
self.resolver.macro_map.insert(def_id.to_def_id(), macro_data);
@@ -175,7 +175,7 @@ impl<'a, 'ra, 'tcx> visit::Visitor<'a> for DefCollector<'a, 'ra, 'tcx> {
175175
if let Some((ctor_kind, ctor_node_id)) = CtorKind::from_ast(struct_def) {
176176
this.create_def(
177177
ctor_node_id,
178-
kw::Empty,
178+
None,
179179
DefKind::Ctor(CtorOf::Struct, ctor_kind),
180180
i.span,
181181
);
@@ -211,20 +211,15 @@ impl<'a, 'ra, 'tcx> visit::Visitor<'a> for DefCollector<'a, 'ra, 'tcx> {
211211
}
212212

213213
let (return_id, return_span) = coroutine_kind.return_id();
214-
let return_def =
215-
self.create_def(return_id, kw::Empty, DefKind::OpaqueTy, return_span);
214+
let return_def = self.create_def(return_id, None, DefKind::OpaqueTy, return_span);
216215
self.with_parent(return_def, |this| this.visit_fn_ret_ty(output));
217216

218217
// If this async fn has no body (i.e. it's an async fn signature in a trait)
219218
// then the closure_def will never be used, and we should avoid generating a
220219
// def-id for it.
221220
if let Some(body) = body {
222-
let closure_def = self.create_def(
223-
coroutine_kind.closure_id(),
224-
kw::Empty,
225-
DefKind::Closure,
226-
span,
227-
);
221+
let closure_def =
222+
self.create_def(coroutine_kind.closure_id(), None, DefKind::Closure, span);
228223
self.with_parent(closure_def, |this| this.visit_block(body));
229224
}
230225
}
@@ -235,15 +230,15 @@ impl<'a, 'ra, 'tcx> visit::Visitor<'a> for DefCollector<'a, 'ra, 'tcx> {
235230
// Async closures desugar to closures inside of closures, so
236231
// we must create two defs.
237232
let coroutine_def =
238-
self.create_def(coroutine_kind.closure_id(), kw::Empty, DefKind::Closure, span);
233+
self.create_def(coroutine_kind.closure_id(), None, DefKind::Closure, span);
239234
self.with_parent(coroutine_def, |this| this.visit_expr(body));
240235
}
241236
_ => visit::walk_fn(self, fn_kind),
242237
}
243238
}
244239

245240
fn visit_use_tree(&mut self, use_tree: &'a UseTree, id: NodeId, _nested: bool) {
246-
self.create_def(id, kw::Empty, DefKind::Use, use_tree.span);
241+
self.create_def(id, None, DefKind::Use, use_tree.span);
247242
visit::walk_use_tree(self, use_tree, id);
248243
}
249244

@@ -262,7 +257,7 @@ impl<'a, 'ra, 'tcx> visit::Visitor<'a> for DefCollector<'a, 'ra, 'tcx> {
262257
ForeignItemKind::MacCall(_) => return self.visit_macro_invoc(fi.id),
263258
};
264259

265-
let def = self.create_def(fi.id, fi.ident.name, def_kind, fi.span);
260+
let def = self.create_def(fi.id, Some(fi.ident.name), def_kind, fi.span);
266261

267262
self.with_parent(def, |this| visit::walk_item(this, fi));
268263
}
@@ -271,12 +266,12 @@ impl<'a, 'ra, 'tcx> visit::Visitor<'a> for DefCollector<'a, 'ra, 'tcx> {
271266
if v.is_placeholder {
272267
return self.visit_macro_invoc(v.id);
273268
}
274-
let def = self.create_def(v.id, v.ident.name, DefKind::Variant, v.span);
269+
let def = self.create_def(v.id, Some(v.ident.name), DefKind::Variant, v.span);
275270
self.with_parent(def, |this| {
276271
if let Some((ctor_kind, ctor_node_id)) = CtorKind::from_ast(&v.data) {
277272
this.create_def(
278273
ctor_node_id,
279-
kw::Empty,
274+
None,
280275
DefKind::Ctor(CtorOf::Variant, ctor_kind),
281276
v.span,
282277
);
@@ -304,7 +299,7 @@ impl<'a, 'ra, 'tcx> visit::Visitor<'a> for DefCollector<'a, 'ra, 'tcx> {
304299
GenericParamKind::Type { .. } => DefKind::TyParam,
305300
GenericParamKind::Const { .. } => DefKind::ConstParam,
306301
};
307-
self.create_def(param.id, param.ident.name, def_kind, param.ident.span);
302+
self.create_def(param.id, Some(param.ident.name), def_kind, param.ident.span);
308303

309304
// impl-Trait can happen inside generic parameters, like
310305
// ```
@@ -327,7 +322,7 @@ impl<'a, 'ra, 'tcx> visit::Visitor<'a> for DefCollector<'a, 'ra, 'tcx> {
327322
}
328323
};
329324

330-
let def = self.create_def(i.id, i.ident.name, def_kind, i.span);
325+
let def = self.create_def(i.id, Some(i.ident.name), def_kind, i.span);
331326
self.with_parent(def, |this| visit::walk_assoc_item(this, i, ctxt));
332327
}
333328

@@ -339,27 +334,22 @@ impl<'a, 'ra, 'tcx> visit::Visitor<'a> for DefCollector<'a, 'ra, 'tcx> {
339334
}
340335

341336
fn visit_anon_const(&mut self, constant: &'a AnonConst) {
342-
let parent =
343-
self.create_def(constant.id, kw::Empty, DefKind::AnonConst, constant.value.span);
337+
let parent = self.create_def(constant.id, None, DefKind::AnonConst, constant.value.span);
344338
self.with_parent(parent, |this| visit::walk_anon_const(this, constant));
345339
}
346340

347341
fn visit_expr(&mut self, expr: &'a Expr) {
348342
let parent_def = match expr.kind {
349343
ExprKind::MacCall(..) => return self.visit_macro_invoc(expr.id),
350344
ExprKind::Closure(..) | ExprKind::Gen(..) => {
351-
self.create_def(expr.id, kw::Empty, DefKind::Closure, expr.span)
345+
self.create_def(expr.id, None, DefKind::Closure, expr.span)
352346
}
353347
ExprKind::ConstBlock(ref constant) => {
354348
for attr in &expr.attrs {
355349
visit::walk_attribute(self, attr);
356350
}
357-
let def = self.create_def(
358-
constant.id,
359-
kw::Empty,
360-
DefKind::InlineConst,
361-
constant.value.span,
362-
);
351+
let def =
352+
self.create_def(constant.id, None, DefKind::InlineConst, constant.value.span);
363353
self.with_parent(def, |this| visit::walk_anon_const(this, constant));
364354
return;
365355
}
@@ -383,7 +373,7 @@ impl<'a, 'ra, 'tcx> visit::Visitor<'a> for DefCollector<'a, 'ra, 'tcx> {
383373
ImplTraitContext::Existential => DefKind::OpaqueTy,
384374
ImplTraitContext::InBinding => return visit::walk_ty(self, ty),
385375
};
386-
let id = self.create_def(*id, name, kind, ty.span);
376+
let id = self.create_def(*id, Some(name), kind, ty.span);
387377
match self.impl_trait_context {
388378
// Do not nest APIT, as we desugar them as `impl_trait: bounds`,
389379
// so the `impl_trait` node is not a parent to `bounds`.
@@ -487,7 +477,7 @@ impl<'a, 'ra, 'tcx> visit::Visitor<'a> for DefCollector<'a, 'ra, 'tcx> {
487477
InlineAsmOperand::Const { anon_const } => {
488478
let def = self.create_def(
489479
anon_const.id,
490-
kw::Empty,
480+
None,
491481
DefKind::InlineConst,
492482
anon_const.value.span,
493483
);

compiler/rustc_resolve/src/lib.rs

+1-1
Original file line numberDiff line numberDiff line change
@@ -1340,7 +1340,7 @@ impl<'tcx> Resolver<'_, 'tcx> {
13401340
&mut self,
13411341
parent: LocalDefId,
13421342
node_id: ast::NodeId,
1343-
name: Symbol,
1343+
name: Option<Symbol>,
13441344
def_kind: DefKind,
13451345
expn_id: ExpnId,
13461346
span: Span,

compiler/rustc_ty_utils/src/assoc.rs

+5-2
Original file line numberDiff line numberDiff line change
@@ -252,7 +252,8 @@ fn associated_type_for_impl_trait_in_trait(
252252
assert_eq!(tcx.def_kind(trait_def_id), DefKind::Trait);
253253

254254
let span = tcx.def_span(opaque_ty_def_id);
255-
let trait_assoc_ty = tcx.at(span).create_def(trait_def_id, kw::Empty, DefKind::AssocTy);
255+
// FIXME: `kw::Empty` gets special treatment by `DefPathData`'s methods.
256+
let trait_assoc_ty = tcx.at(span).create_def(trait_def_id, Some(kw::Empty), DefKind::AssocTy);
256257

257258
let local_def_id = trait_assoc_ty.def_id();
258259
let def_id = local_def_id.to_def_id();
@@ -304,7 +305,9 @@ fn associated_type_for_impl_trait_in_impl(
304305
hir::FnRetTy::DefaultReturn(_) => tcx.def_span(impl_fn_def_id),
305306
hir::FnRetTy::Return(ty) => ty.span,
306307
};
307-
let impl_assoc_ty = tcx.at(span).create_def(impl_local_def_id, kw::Empty, DefKind::AssocTy);
308+
// FIXME: `kw::Empty` gets special treatment by `DefPathData`'s methods.
309+
let impl_assoc_ty =
310+
tcx.at(span).create_def(impl_local_def_id, Some(kw::Empty), DefKind::AssocTy);
308311

309312
let local_def_id = impl_assoc_ty.def_id();
310313
let def_id = local_def_id.to_def_id();

0 commit comments

Comments
 (0)