Skip to content

Commit 972f131

Browse files
committed
Auto merge of rust-lang#14526 - rust-lang:revert-14521-dev, r=Veykril
Revert "Add bounds for fields in derive macro" Reverts rust-lang/rust-analyzer#14521 as it introduces too many mismatches
2 parents bca364c + 435d585 commit 972f131

File tree

3 files changed

+27
-66
lines changed

3 files changed

+27
-66
lines changed

crates/hir-def/src/macro_expansion_tests/builtin_derive_macro.rs

+6-6
Original file line numberDiff line numberDiff line change
@@ -16,7 +16,7 @@ struct Foo;
1616
#[derive(Copy)]
1717
struct Foo;
1818
19-
impl < > core::marker::Copy for Foo< > where {}"#]],
19+
impl < > core::marker::Copy for Foo< > {}"#]],
2020
);
2121
}
2222

@@ -41,7 +41,7 @@ macro Copy {}
4141
#[derive(Copy)]
4242
struct Foo;
4343
44-
impl < > crate ::marker::Copy for Foo< > where {}"#]],
44+
impl < > crate ::marker::Copy for Foo< > {}"#]],
4545
);
4646
}
4747

@@ -57,7 +57,7 @@ struct Foo<A, B>;
5757
#[derive(Copy)]
5858
struct Foo<A, B>;
5959
60-
impl <A: core::marker::Copy, B: core::marker::Copy, > core::marker::Copy for Foo<A, B, > where {}"#]],
60+
impl <T0: core::marker::Copy, T1: core::marker::Copy, > core::marker::Copy for Foo<T0, T1, > {}"#]],
6161
);
6262
}
6363

@@ -74,7 +74,7 @@ struct Foo<A, B, 'a, 'b>;
7474
#[derive(Copy)]
7575
struct Foo<A, B, 'a, 'b>;
7676
77-
impl <A: core::marker::Copy, B: core::marker::Copy, > core::marker::Copy for Foo<A, B, > where {}"#]],
77+
impl <T0: core::marker::Copy, T1: core::marker::Copy, > core::marker::Copy for Foo<T0, T1, > {}"#]],
7878
);
7979
}
8080

@@ -90,7 +90,7 @@ struct Foo<A, B>;
9090
#[derive(Clone)]
9191
struct Foo<A, B>;
9292
93-
impl <A: core::clone::Clone, B: core::clone::Clone, > core::clone::Clone for Foo<A, B, > where {}"#]],
93+
impl <T0: core::clone::Clone, T1: core::clone::Clone, > core::clone::Clone for Foo<T0, T1, > {}"#]],
9494
);
9595
}
9696

@@ -106,6 +106,6 @@ struct Foo<const X: usize, T>(u32);
106106
#[derive(Clone)]
107107
struct Foo<const X: usize, T>(u32);
108108
109-
impl <const X: usize, T: core::clone::Clone, > core::clone::Clone for Foo<X, T, > where u32: core::clone::Clone, {}"#]],
109+
impl <const T0: usize, T1: core::clone::Clone, > core::clone::Clone for Foo<T0, T1, > {}"#]],
110110
);
111111
}

crates/hir-expand/src/builtin_derive_macro.rs

+17-56
Original file line numberDiff line numberDiff line change
@@ -1,12 +1,11 @@
11
//! Builtin derives.
22
33
use base_db::{CrateOrigin, LangCrateOrigin};
4-
use either::Either;
54
use tracing::debug;
65

76
use crate::tt::{self, TokenId};
87
use syntax::{
9-
ast::{self, AstNode, HasGenericParams, HasModuleItem, HasName, HasTypeBounds},
8+
ast::{self, AstNode, HasGenericParams, HasModuleItem, HasName},
109
match_ast,
1110
};
1211

@@ -61,11 +60,8 @@ pub fn find_builtin_derive(ident: &name::Name) -> Option<BuiltinDeriveExpander>
6160

6261
struct BasicAdtInfo {
6362
name: tt::Ident,
64-
/// first field is the name, and
65-
/// second field is `Some(ty)` if it's a const param of type `ty`, `None` if it's a type param.
66-
/// third fields is where bounds, if any
67-
param_types: Vec<(tt::Subtree, Option<tt::Subtree>, Option<tt::Subtree>)>,
68-
field_types: Vec<tt::Subtree>,
63+
/// `Some(ty)` if it's a const param of type `ty`, `None` if it's a type param.
64+
param_types: Vec<Option<tt::Subtree>>,
6965
}
7066

7167
fn parse_adt(tt: &tt::Subtree) -> Result<BasicAdtInfo, ExpandError> {
@@ -79,34 +75,17 @@ fn parse_adt(tt: &tt::Subtree) -> Result<BasicAdtInfo, ExpandError> {
7975
ExpandError::Other("no item found".into())
8076
})?;
8177
let node = item.syntax();
82-
let (name, params, fields) = match_ast! {
78+
let (name, params) = match_ast! {
8379
match node {
84-
ast::Struct(it) => {
85-
(it.name(), it.generic_param_list(), it.field_list().into_iter().collect::<Vec<_>>())
86-
},
87-
ast::Enum(it) => (it.name(), it.generic_param_list(), it.variant_list().into_iter().flat_map(|x| x.variants()).filter_map(|x| x.field_list()).collect()),
88-
ast::Union(it) => (it.name(), it.generic_param_list(), it.record_field_list().into_iter().map(|x| ast::FieldList::RecordFieldList(x)).collect()),
80+
ast::Struct(it) => (it.name(), it.generic_param_list()),
81+
ast::Enum(it) => (it.name(), it.generic_param_list()),
82+
ast::Union(it) => (it.name(), it.generic_param_list()),
8983
_ => {
9084
debug!("unexpected node is {:?}", node);
9185
return Err(ExpandError::Other("expected struct, enum or union".into()))
9286
},
9387
}
9488
};
95-
let field_types = fields
96-
.into_iter()
97-
.flat_map(|f| match f {
98-
ast::FieldList::RecordFieldList(x) => Either::Left(
99-
x.fields()
100-
.filter_map(|x| x.ty())
101-
.map(|x| mbe::syntax_node_to_token_tree(x.syntax()).0),
102-
),
103-
ast::FieldList::TupleFieldList(x) => Either::Right(
104-
x.fields()
105-
.filter_map(|x| x.ty())
106-
.map(|x| mbe::syntax_node_to_token_tree(x.syntax()).0),
107-
),
108-
})
109-
.collect::<Vec<_>>();
11089
let name = name.ok_or_else(|| {
11190
debug!("parsed item has no name");
11291
ExpandError::Other("missing name".into())
@@ -118,46 +97,35 @@ fn parse_adt(tt: &tt::Subtree) -> Result<BasicAdtInfo, ExpandError> {
11897
.into_iter()
11998
.flat_map(|param_list| param_list.type_or_const_params())
12099
.map(|param| {
121-
let name = param
122-
.name()
123-
.map(|x| mbe::syntax_node_to_token_tree(x.syntax()).0)
124-
.unwrap_or_else(tt::Subtree::empty);
125-
let bounds = match &param {
126-
ast::TypeOrConstParam::Type(x) => {
127-
x.type_bound_list().map(|x| mbe::syntax_node_to_token_tree(x.syntax()).0)
128-
}
129-
ast::TypeOrConstParam::Const(_) => None,
130-
};
131-
let ty = if let ast::TypeOrConstParam::Const(param) = param {
100+
if let ast::TypeOrConstParam::Const(param) = param {
132101
let ty = param
133102
.ty()
134103
.map(|ty| mbe::syntax_node_to_token_tree(ty.syntax()).0)
135104
.unwrap_or_else(tt::Subtree::empty);
136105
Some(ty)
137106
} else {
138107
None
139-
};
140-
(name, ty, bounds)
108+
}
141109
})
142110
.collect();
143-
Ok(BasicAdtInfo { name: name_token, param_types, field_types })
111+
Ok(BasicAdtInfo { name: name_token, param_types })
144112
}
145113

146114
fn expand_simple_derive(tt: &tt::Subtree, trait_path: tt::Subtree) -> ExpandResult<tt::Subtree> {
147115
let info = match parse_adt(tt) {
148116
Ok(info) => info,
149117
Err(e) => return ExpandResult::with_err(tt::Subtree::empty(), e),
150118
};
151-
let mut where_block = vec![];
152119
let (params, args): (Vec<_>, Vec<_>) = info
153120
.param_types
154121
.into_iter()
155-
.map(|(ident, param_ty, bound)| {
122+
.enumerate()
123+
.map(|(idx, param_ty)| {
124+
let ident = tt::Leaf::Ident(tt::Ident {
125+
span: tt::TokenId::unspecified(),
126+
text: format!("T{idx}").into(),
127+
});
156128
let ident_ = ident.clone();
157-
if let Some(b) = bound {
158-
let ident = ident.clone();
159-
where_block.push(quote! { #ident : #b , });
160-
}
161129
if let Some(ty) = param_ty {
162130
(quote! { const #ident : #ty , }, quote! { #ident_ , })
163131
} else {
@@ -166,16 +134,9 @@ fn expand_simple_derive(tt: &tt::Subtree, trait_path: tt::Subtree) -> ExpandResu
166134
}
167135
})
168136
.unzip();
169-
170-
where_block.extend(info.field_types.iter().map(|x| {
171-
let x = x.clone();
172-
let bound = trait_path.clone();
173-
quote! { #x : #bound , }
174-
}));
175-
176137
let name = info.name;
177138
let expanded = quote! {
178-
impl < ##params > #trait_path for #name < ##args > where ##where_block {}
139+
impl < ##params > #trait_path for #name < ##args > {}
179140
};
180141
ExpandResult::ok(expanded)
181142
}

crates/ide/src/expand_macro.rs

+4-4
Original file line numberDiff line numberDiff line change
@@ -471,7 +471,7 @@ struct Foo {}
471471
"#,
472472
expect![[r#"
473473
Clone
474-
impl < >core::clone::Clone for Foo< >where{}
474+
impl < >core::clone::Clone for Foo< >{}
475475
"#]],
476476
);
477477
}
@@ -488,7 +488,7 @@ struct Foo {}
488488
"#,
489489
expect![[r#"
490490
Copy
491-
impl < >core::marker::Copy for Foo< >where{}
491+
impl < >core::marker::Copy for Foo< >{}
492492
"#]],
493493
);
494494
}
@@ -504,7 +504,7 @@ struct Foo {}
504504
"#,
505505
expect![[r#"
506506
Copy
507-
impl < >core::marker::Copy for Foo< >where{}
507+
impl < >core::marker::Copy for Foo< >{}
508508
"#]],
509509
);
510510
check(
@@ -516,7 +516,7 @@ struct Foo {}
516516
"#,
517517
expect![[r#"
518518
Clone
519-
impl < >core::clone::Clone for Foo< >where{}
519+
impl < >core::clone::Clone for Foo< >{}
520520
"#]],
521521
);
522522
}

0 commit comments

Comments
 (0)