Skip to content

Commit a9d0d14

Browse files
committed
internal: remove erroneous default impl
1 parent 67a7dfd commit a9d0d14

File tree

3 files changed

+22
-16
lines changed

3 files changed

+22
-16
lines changed

crates/hir_def/src/nameres.rs

Lines changed: 14 additions & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -200,20 +200,19 @@ pub struct ModuleData {
200200
pub origin: ModuleOrigin,
201201
}
202202

203-
impl Default for ModuleData {
204-
fn default() -> Self {
205-
ModuleData::new(ModuleOrigin::CrateRoot { definition: FileId(!0) })
206-
}
207-
}
208-
209203
impl DefMap {
210204
pub(crate) fn crate_def_map_query(db: &dyn DefDatabase, krate: CrateId) -> Arc<DefMap> {
211205
let _p = profile::span("crate_def_map_query").detail(|| {
212206
db.crate_graph()[krate].display_name.as_deref().unwrap_or_default().to_string()
213207
});
214-
let edition = db.crate_graph()[krate].edition;
215-
let def_map = DefMap::empty(krate, edition);
208+
209+
let crate_graph = db.crate_graph();
210+
211+
let edition = crate_graph[krate].edition;
212+
let origin = ModuleOrigin::CrateRoot { definition: crate_graph[krate].root_file_id };
213+
let def_map = DefMap::empty(krate, edition, origin);
216214
let def_map = collector::collect_defs(db, def_map, None);
215+
217216
Arc::new(def_map)
218217
}
219218

@@ -231,16 +230,20 @@ impl DefMap {
231230
let block_info = BlockInfo { block: block_id, parent: block.module };
232231

233232
let parent_map = block.module.def_map(db);
234-
let mut def_map = DefMap::empty(block.module.krate, parent_map.edition);
233+
let mut def_map = DefMap::empty(
234+
block.module.krate,
235+
parent_map.edition,
236+
ModuleOrigin::BlockExpr { block: block.ast_id },
237+
);
235238
def_map.block = Some(block_info);
236239

237240
let def_map = collector::collect_defs(db, def_map, Some(block.ast_id));
238241
Some(Arc::new(def_map))
239242
}
240243

241-
fn empty(krate: CrateId, edition: Edition) -> DefMap {
244+
fn empty(krate: CrateId, edition: Edition, root_module_origin: ModuleOrigin) -> DefMap {
242245
let mut modules: Arena<ModuleData> = Arena::default();
243-
let root = modules.alloc(ModuleData::default());
246+
let root = modules.alloc(ModuleData::new(root_module_origin));
244247
DefMap {
245248
_c: Count::new(),
246249
block: None,

crates/hir_def/src/nameres/collector.rs

Lines changed: 3 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -272,7 +272,6 @@ impl DefCollector<'_> {
272272
let file_id = self.db.crate_graph()[self.def_map.krate].root_file_id;
273273
let item_tree = self.db.file_item_tree(file_id.into());
274274
let module_id = self.def_map.root;
275-
self.def_map.modules[module_id].origin = ModuleOrigin::CrateRoot { definition: file_id };
276275

277276
let attrs = item_tree.top_level_attrs(self.db, self.def_map.krate);
278277
if attrs.cfg().map_or(true, |cfg| self.cfg_options.check(&cfg) != Some(false)) {
@@ -323,7 +322,6 @@ impl DefCollector<'_> {
323322
fn seed_with_inner(&mut self, block: AstId<ast::BlockExpr>) {
324323
let item_tree = self.db.file_item_tree(block.file_id);
325324
let module_id = self.def_map.root;
326-
self.def_map.modules[module_id].origin = ModuleOrigin::BlockExpr { block };
327325
if item_tree
328326
.top_level_attrs(self.db, self.def_map.krate)
329327
.cfg()
@@ -2005,11 +2003,12 @@ mod tests {
20052003
}
20062004

20072005
fn do_resolve(not_ra_fixture: &str) -> DefMap {
2008-
let (db, _file_id) = TestDB::with_single_file(not_ra_fixture);
2006+
let (db, file_id) = TestDB::with_single_file(not_ra_fixture);
20092007
let krate = db.test_crate();
20102008

20112009
let edition = db.crate_graph()[krate].edition;
2012-
let def_map = DefMap::empty(krate, edition);
2010+
let module_origin = ModuleOrigin::CrateRoot { definition: file_id };
2011+
let def_map = DefMap::empty(krate, edition, module_origin);
20132012
do_collect_defs(&db, def_map)
20142013
}
20152014

docs/dev/style.md

Lines changed: 5 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -312,7 +312,7 @@ Even when generality is not required, consistency is important.
312312

313313
## Constructors
314314

315-
Prefer `Default` to zero-argument `new` function
315+
Prefer `Default` to zero-argument `new` function.
316316

317317
```rust
318318
// GOOD
@@ -341,6 +341,10 @@ Use `Vec::new` rather than `vec![]`.
341341

342342
**Rationale:** uniformity, strength reduction.
343343

344+
Avoid using "dummy" states to implement a `Default`.
345+
If a type doesn't have a sensible default, empty value, don't hide it.
346+
Let the caller explicitly decide what's the right initial state is.
347+
344348
## Functions Over Objects
345349

346350
Avoid creating "doer" objects.

0 commit comments

Comments
 (0)