Skip to content

Commit

Permalink
Only include direct parent bounds for associated types in traits.
Browse files Browse the repository at this point in the history
  • Loading branch information
maximebuyse committed Dec 17, 2024
1 parent 91e4877 commit ffafb2d
Show file tree
Hide file tree
Showing 3 changed files with 13 additions and 10 deletions.
1 change: 0 additions & 1 deletion frontend/exporter/src/traits.rs
Original file line number Diff line number Diff line change
Expand Up @@ -211,7 +211,6 @@ fn solve_item_traits_inner<'tcx, S: UnderOwnerState<'tcx>>(
use crate::rustc_middle::ty::ToPolyTraitRef;
let tcx = s.base().tcx;
let param_env = s.param_env();

predicates
.filter_map(|clause| clause.as_trait_clause())
.map(|clause| clause.to_poly_trait_ref())
Expand Down
11 changes: 8 additions & 3 deletions frontend/exporter/src/types/hir.rs
Original file line number Diff line number Diff line change
Expand Up @@ -840,10 +840,15 @@ fn region_bounds_at_current_owner<'tcx, S: UnderOwnerState<'tcx>>(s: &S) -> Gene
};

let clauses: Vec<ty::Clause<'tcx>> = if use_item_bounds {
tcx.item_bounds(s.owner_id())
tcx.explicit_item_bounds(s.owner_id())
.map_bound(|clauses| {
clauses
.iter()
.map(|(x, _span)| x)
.copied()
.collect::<Vec<_>>()
})
.instantiate_identity()
.iter()
.collect()
} else {
predicates_defined_on(tcx, s.owner_id())
.predicates
Expand Down
11 changes: 5 additions & 6 deletions test-harness/src/snapshots/toolchain__traits into-fstar.snap
Original file line number Diff line number Diff line change
Expand Up @@ -614,7 +614,6 @@ let use_impl_trait (_: Prims.unit) : Prims.unit =
class t_Foo (v_Self: Type0) = {
f_AssocType:Type0;
f_AssocType_15012754260415912210:t_SuperTrait f_AssocType;
f_AssocType_3242921639065184873:Core.Clone.t_Clone f_AssocType;
f_N:usize;
f_assoc_f_pre:Prims.unit -> Type0;
f_assoc_f_post:Prims.unit -> Prims.unit -> Type0;
Expand All @@ -624,12 +623,12 @@ class t_Foo (v_Self: Type0) = {
f_method_f_post:v_Self -> Prims.unit -> Type0;
f_method_f:x0: v_Self
-> Prims.Pure Prims.unit (f_method_f_pre x0) (fun result -> f_method_f_post x0 result);
f_assoc_type_pre:{| i3: Core.Marker.t_Copy f_AssocType |} -> f_AssocType -> Type0;
f_assoc_type_post:{| i3: Core.Marker.t_Copy f_AssocType |} -> f_AssocType -> Prims.unit -> Type0;
f_assoc_type:{| i3: Core.Marker.t_Copy f_AssocType |} -> x0: f_AssocType
f_assoc_type_pre:{| i2: Core.Marker.t_Copy f_AssocType |} -> f_AssocType -> Type0;
f_assoc_type_post:{| i2: Core.Marker.t_Copy f_AssocType |} -> f_AssocType -> Prims.unit -> Type0;
f_assoc_type:{| i2: Core.Marker.t_Copy f_AssocType |} -> x0: f_AssocType
-> Prims.Pure Prims.unit
(f_assoc_type_pre #i3 x0)
(fun result -> f_assoc_type_post #i3 x0 result)
(f_assoc_type_pre #i2 x0)
(fun result -> f_assoc_type_post #i2 x0 result)
}

class t_Lang (v_Self: Type0) = {
Expand Down

0 comments on commit ffafb2d

Please sign in to comment.