mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-14 22:24:14 +00:00
Implement all the other built-in derives
Since as long as we're not implementing the bodies, they all work the same way.
This commit is contained in:
parent
db8a00bd99
commit
10697041c1
2 changed files with 90 additions and 19 deletions
|
@ -45,7 +45,14 @@ macro_rules! register_builtin {
|
||||||
|
|
||||||
register_builtin! {
|
register_builtin! {
|
||||||
(COPY_TRAIT, Copy) => copy_expand,
|
(COPY_TRAIT, Copy) => copy_expand,
|
||||||
(CLONE_TRAIT, Clone) => clone_expand
|
(CLONE_TRAIT, Clone) => clone_expand,
|
||||||
|
(DEFAULT_TRAIT, Default) => default_expand,
|
||||||
|
(DEBUG_TRAIT, Debug) => debug_expand,
|
||||||
|
(HASH_TRAIT, Hash) => hash_expand,
|
||||||
|
(ORD_TRAIT, Ord) => ord_expand,
|
||||||
|
(PARTIAL_ORD_TRAIT, PartialOrd) => partial_ord_expand,
|
||||||
|
(EQ_TRAIT, Eq) => eq_expand,
|
||||||
|
(PARTIAL_EQ_TRAIT, PartialEq) => partial_eq_expand
|
||||||
}
|
}
|
||||||
|
|
||||||
struct BasicAdtInfo {
|
struct BasicAdtInfo {
|
||||||
|
@ -109,20 +116,29 @@ fn make_type_args(n: usize, bound: Vec<tt::TokenTree>) -> Vec<tt::TokenTree> {
|
||||||
result
|
result
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn expand_simple_derive(
|
||||||
|
tt: &tt::Subtree,
|
||||||
|
trait_path: tt::Subtree,
|
||||||
|
) -> Result<tt::Subtree, mbe::ExpandError> {
|
||||||
|
let info = parse_adt(tt)?;
|
||||||
|
let name = info.name;
|
||||||
|
let trait_path_clone = trait_path.token_trees.clone();
|
||||||
|
let bound = (quote! { : ##trait_path_clone }).token_trees;
|
||||||
|
let type_params = make_type_args(info.type_params, bound);
|
||||||
|
let type_args = make_type_args(info.type_params, Vec::new());
|
||||||
|
let trait_path = trait_path.token_trees;
|
||||||
|
let expanded = quote! {
|
||||||
|
impl ##type_params ##trait_path for #name ##type_args {}
|
||||||
|
};
|
||||||
|
Ok(expanded)
|
||||||
|
}
|
||||||
|
|
||||||
fn copy_expand(
|
fn copy_expand(
|
||||||
_db: &dyn AstDatabase,
|
_db: &dyn AstDatabase,
|
||||||
_id: MacroCallId,
|
_id: MacroCallId,
|
||||||
tt: &tt::Subtree,
|
tt: &tt::Subtree,
|
||||||
) -> Result<tt::Subtree, mbe::ExpandError> {
|
) -> Result<tt::Subtree, mbe::ExpandError> {
|
||||||
let info = parse_adt(tt)?;
|
expand_simple_derive(tt, quote! { std::marker::Copy })
|
||||||
let name = info.name;
|
|
||||||
let bound = (quote! { : std::marker::Copy }).token_trees;
|
|
||||||
let type_params = make_type_args(info.type_params, bound);
|
|
||||||
let type_args = make_type_args(info.type_params, Vec::new());
|
|
||||||
let expanded = quote! {
|
|
||||||
impl ##type_params std::marker::Copy for #name ##type_args {}
|
|
||||||
};
|
|
||||||
Ok(expanded)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn clone_expand(
|
fn clone_expand(
|
||||||
|
@ -130,15 +146,63 @@ fn clone_expand(
|
||||||
_id: MacroCallId,
|
_id: MacroCallId,
|
||||||
tt: &tt::Subtree,
|
tt: &tt::Subtree,
|
||||||
) -> Result<tt::Subtree, mbe::ExpandError> {
|
) -> Result<tt::Subtree, mbe::ExpandError> {
|
||||||
let info = parse_adt(tt)?;
|
expand_simple_derive(tt, quote! { std::clone::Clone })
|
||||||
let name = info.name;
|
}
|
||||||
let bound = (quote! { : std::clone::Clone }).token_trees;
|
|
||||||
let type_params = make_type_args(info.type_params, bound);
|
fn default_expand(
|
||||||
let type_args = make_type_args(info.type_params, Vec::new());
|
_db: &dyn AstDatabase,
|
||||||
let expanded = quote! {
|
_id: MacroCallId,
|
||||||
impl ##type_params std::clone::Clone for #name ##type_args {}
|
tt: &tt::Subtree,
|
||||||
};
|
) -> Result<tt::Subtree, mbe::ExpandError> {
|
||||||
Ok(expanded)
|
expand_simple_derive(tt, quote! { std::default::Default })
|
||||||
|
}
|
||||||
|
|
||||||
|
fn debug_expand(
|
||||||
|
_db: &dyn AstDatabase,
|
||||||
|
_id: MacroCallId,
|
||||||
|
tt: &tt::Subtree,
|
||||||
|
) -> Result<tt::Subtree, mbe::ExpandError> {
|
||||||
|
expand_simple_derive(tt, quote! { std::fmt::Debug })
|
||||||
|
}
|
||||||
|
|
||||||
|
fn hash_expand(
|
||||||
|
_db: &dyn AstDatabase,
|
||||||
|
_id: MacroCallId,
|
||||||
|
tt: &tt::Subtree,
|
||||||
|
) -> Result<tt::Subtree, mbe::ExpandError> {
|
||||||
|
expand_simple_derive(tt, quote! { std::hash::Hash })
|
||||||
|
}
|
||||||
|
|
||||||
|
fn eq_expand(
|
||||||
|
_db: &dyn AstDatabase,
|
||||||
|
_id: MacroCallId,
|
||||||
|
tt: &tt::Subtree,
|
||||||
|
) -> Result<tt::Subtree, mbe::ExpandError> {
|
||||||
|
expand_simple_derive(tt, quote! { std::cmp::Eq })
|
||||||
|
}
|
||||||
|
|
||||||
|
fn partial_eq_expand(
|
||||||
|
_db: &dyn AstDatabase,
|
||||||
|
_id: MacroCallId,
|
||||||
|
tt: &tt::Subtree,
|
||||||
|
) -> Result<tt::Subtree, mbe::ExpandError> {
|
||||||
|
expand_simple_derive(tt, quote! { std::cmp::PartialEq })
|
||||||
|
}
|
||||||
|
|
||||||
|
fn ord_expand(
|
||||||
|
_db: &dyn AstDatabase,
|
||||||
|
_id: MacroCallId,
|
||||||
|
tt: &tt::Subtree,
|
||||||
|
) -> Result<tt::Subtree, mbe::ExpandError> {
|
||||||
|
expand_simple_derive(tt, quote! { std::cmp::Ord })
|
||||||
|
}
|
||||||
|
|
||||||
|
fn partial_ord_expand(
|
||||||
|
_db: &dyn AstDatabase,
|
||||||
|
_id: MacroCallId,
|
||||||
|
tt: &tt::Subtree,
|
||||||
|
) -> Result<tt::Subtree, mbe::ExpandError> {
|
||||||
|
expand_simple_derive(tt, quote! { std::cmp::PartialOrd })
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
|
|
|
@ -163,3 +163,10 @@ pub const STRINGIFY_MACRO: Name = Name::new_inline_ascii(9, b"stringify");
|
||||||
// Builtin derives
|
// Builtin derives
|
||||||
pub const COPY_TRAIT: Name = Name::new_inline_ascii(4, b"Copy");
|
pub const COPY_TRAIT: Name = Name::new_inline_ascii(4, b"Copy");
|
||||||
pub const CLONE_TRAIT: Name = Name::new_inline_ascii(5, b"Clone");
|
pub const CLONE_TRAIT: Name = Name::new_inline_ascii(5, b"Clone");
|
||||||
|
pub const DEFAULT_TRAIT: Name = Name::new_inline_ascii(7, b"Default");
|
||||||
|
pub const DEBUG_TRAIT: Name = Name::new_inline_ascii(5, b"Debug");
|
||||||
|
pub const HASH_TRAIT: Name = Name::new_inline_ascii(4, b"Hash");
|
||||||
|
pub const ORD_TRAIT: Name = Name::new_inline_ascii(3, b"Ord");
|
||||||
|
pub const PARTIAL_ORD_TRAIT: Name = Name::new_inline_ascii(10, b"PartialOrd");
|
||||||
|
pub const EQ_TRAIT: Name = Name::new_inline_ascii(2, b"Eq");
|
||||||
|
pub const PARTIAL_EQ_TRAIT: Name = Name::new_inline_ascii(9, b"PartialEq");
|
||||||
|
|
Loading…
Reference in a new issue