mirror of
https://github.com/roc-lang/roc.git
synced 2025-10-03 08:34:33 +00:00
parent
d05f9e67e7
commit
1d5943ccff
1 changed files with 5 additions and 7 deletions
|
@ -634,6 +634,8 @@ impl<'a> Env<'a> {
|
||||||
self.add_type(var, &mut types);
|
self.add_type(var, &mut types);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
self.resolve_pending_recursive_types(&mut types);
|
||||||
|
|
||||||
types
|
types
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -643,16 +645,12 @@ impl<'a> Env<'a> {
|
||||||
.from_var(self.arena, var, self.subs)
|
.from_var(self.arena, var, self.subs)
|
||||||
.expect("Something weird ended up in the content");
|
.expect("Something weird ended up in the content");
|
||||||
|
|
||||||
let type_id = add_type_help(self, layout, var, None, types);
|
add_type_help(self, layout, var, None, types)
|
||||||
|
|
||||||
self.resolve_pending_recursive_types(types);
|
|
||||||
|
|
||||||
type_id
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn resolve_pending_recursive_types(&mut self, types: &mut Types) {
|
fn resolve_pending_recursive_types(&mut self, types: &mut Types) {
|
||||||
// TODO if VecMap gets a drain() method, use that instead of doing replace() and into_iter
|
// TODO if VecMap gets a drain() method, use that instead of doing take() and into_iter
|
||||||
let pending = core::mem::replace(&mut self.pending_recursive_types, Default::default());
|
let pending = core::mem::take(&mut self.pending_recursive_types);
|
||||||
|
|
||||||
for (type_id, layout) in pending.into_iter() {
|
for (type_id, layout) in pending.into_iter() {
|
||||||
let actual_type_id = self.known_recursive_types.get(&layout).unwrap_or_else(|| {
|
let actual_type_id = self.known_recursive_types.get(&layout).unwrap_or_else(|| {
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue