1
Fork 0

Auto merge of #111963 - nnethercote:inline-derived-hash, r=lqd

Inline derived `hash`

Because most of the other derived functions are inlined: `clone`, `default`, `eq`, `partial_cmp`, `cmp`. The exception is `fmt`, but it tends to not be on hot paths as much.

r? `@ghost`
This commit is contained in:
bors 2023-05-29 00:25:54 +00:00
commit f8447b9638
8 changed files with 27 additions and 19 deletions

View file

@ -68,7 +68,6 @@ pub fn expand_deriving_clone(
_ => cx.span_bug(span, "`#[derive(Clone)]` on trait item or impl item"), _ => cx.span_bug(span, "`#[derive(Clone)]` on trait item or impl item"),
} }
let attrs = thin_vec![cx.attr_word(sym::inline, span)];
let trait_def = TraitDef { let trait_def = TraitDef {
span, span,
path: path_std!(clone::Clone), path: path_std!(clone::Clone),
@ -82,7 +81,7 @@ pub fn expand_deriving_clone(
explicit_self: true, explicit_self: true,
nonself_args: Vec::new(), nonself_args: Vec::new(),
ret_ty: Self_, ret_ty: Self_,
attributes: attrs, attributes: thin_vec![cx.attr_word(sym::inline, span)],
fieldless_variants_strategy: FieldlessVariantsStrategy::Default, fieldless_variants_strategy: FieldlessVariantsStrategy::Default,
combine_substructure: substructure, combine_substructure: substructure,
}], }],

View file

@ -18,11 +18,6 @@ pub fn expand_deriving_eq(
is_const: bool, is_const: bool,
) { ) {
let span = cx.with_def_site_ctxt(span); let span = cx.with_def_site_ctxt(span);
let attrs = thin_vec![
cx.attr_word(sym::inline, span),
cx.attr_nested_word(sym::doc, sym::hidden, span),
cx.attr_word(sym::no_coverage, span)
];
let trait_def = TraitDef { let trait_def = TraitDef {
span, span,
path: path_std!(cmp::Eq), path: path_std!(cmp::Eq),
@ -36,7 +31,11 @@ pub fn expand_deriving_eq(
explicit_self: true, explicit_self: true,
nonself_args: vec![], nonself_args: vec![],
ret_ty: Unit, ret_ty: Unit,
attributes: attrs, attributes: thin_vec![
cx.attr_word(sym::inline, span),
cx.attr_nested_word(sym::doc, sym::hidden, span),
cx.attr_word(sym::no_coverage, span)
],
fieldless_variants_strategy: FieldlessVariantsStrategy::Unify, fieldless_variants_strategy: FieldlessVariantsStrategy::Unify,
combine_substructure: combine_substructure(Box::new(|a, b, c| { combine_substructure: combine_substructure(Box::new(|a, b, c| {
cs_total_eq_assert(a, b, c) cs_total_eq_assert(a, b, c)

View file

@ -15,7 +15,6 @@ pub fn expand_deriving_ord(
push: &mut dyn FnMut(Annotatable), push: &mut dyn FnMut(Annotatable),
is_const: bool, is_const: bool,
) { ) {
let attrs = thin_vec![cx.attr_word(sym::inline, span)];
let trait_def = TraitDef { let trait_def = TraitDef {
span, span,
path: path_std!(cmp::Ord), path: path_std!(cmp::Ord),
@ -29,7 +28,7 @@ pub fn expand_deriving_ord(
explicit_self: true, explicit_self: true,
nonself_args: vec![(self_ref(), sym::other)], nonself_args: vec![(self_ref(), sym::other)],
ret_ty: Path(path_std!(cmp::Ordering)), ret_ty: Path(path_std!(cmp::Ordering)),
attributes: attrs, attributes: thin_vec![cx.attr_word(sym::inline, span)],
fieldless_variants_strategy: FieldlessVariantsStrategy::Unify, fieldless_variants_strategy: FieldlessVariantsStrategy::Unify,
combine_substructure: combine_substructure(Box::new(|a, b, c| cs_cmp(a, b, c))), combine_substructure: combine_substructure(Box::new(|a, b, c| cs_cmp(a, b, c))),
}], }],

View file

@ -82,14 +82,13 @@ pub fn expand_deriving_partial_eq(
// No need to generate `ne`, the default suffices, and not generating it is // No need to generate `ne`, the default suffices, and not generating it is
// faster. // faster.
let attrs = thin_vec![cx.attr_word(sym::inline, span)];
let methods = vec![MethodDef { let methods = vec![MethodDef {
name: sym::eq, name: sym::eq,
generics: Bounds::empty(), generics: Bounds::empty(),
explicit_self: true, explicit_self: true,
nonself_args: vec![(self_ref(), sym::other)], nonself_args: vec![(self_ref(), sym::other)],
ret_ty: Path(path_local!(bool)), ret_ty: Path(path_local!(bool)),
attributes: attrs, attributes: thin_vec![cx.attr_word(sym::inline, span)],
fieldless_variants_strategy: FieldlessVariantsStrategy::Unify, fieldless_variants_strategy: FieldlessVariantsStrategy::Unify,
combine_substructure: combine_substructure(Box::new(|a, b, c| cs_eq(a, b, c))), combine_substructure: combine_substructure(Box::new(|a, b, c| cs_eq(a, b, c))),
}]; }];

View file

@ -19,8 +19,6 @@ pub fn expand_deriving_partial_ord(
let ret_ty = let ret_ty =
Path(Path::new_(pathvec_std!(option::Option), vec![Box::new(ordering_ty)], PathKind::Std)); Path(Path::new_(pathvec_std!(option::Option), vec![Box::new(ordering_ty)], PathKind::Std));
let attrs = thin_vec![cx.attr_word(sym::inline, span)];
// Order in which to perform matching // Order in which to perform matching
let tag_then_data = if let Annotatable::Item(item) = item let tag_then_data = if let Annotatable::Item(item) = item
&& let ItemKind::Enum(def, _) = &item.kind { && let ItemKind::Enum(def, _) = &item.kind {
@ -48,7 +46,7 @@ pub fn expand_deriving_partial_ord(
explicit_self: true, explicit_self: true,
nonself_args: vec![(self_ref(), sym::other)], nonself_args: vec![(self_ref(), sym::other)],
ret_ty, ret_ty,
attributes: attrs, attributes: thin_vec![cx.attr_word(sym::inline, span)],
fieldless_variants_strategy: FieldlessVariantsStrategy::Unify, fieldless_variants_strategy: FieldlessVariantsStrategy::Unify,
combine_substructure: combine_substructure(Box::new(|cx, span, substr| { combine_substructure: combine_substructure(Box::new(|cx, span, substr| {
cs_partial_cmp(cx, span, substr, tag_then_data) cs_partial_cmp(cx, span, substr, tag_then_data)

View file

@ -20,7 +20,6 @@ pub fn expand_deriving_default(
) { ) {
item.visit_with(&mut DetectNonVariantDefaultAttr { cx }); item.visit_with(&mut DetectNonVariantDefaultAttr { cx });
let attrs = thin_vec![cx.attr_word(sym::inline, span)];
let trait_def = TraitDef { let trait_def = TraitDef {
span, span,
path: Path::new(vec![kw::Default, sym::Default]), path: Path::new(vec![kw::Default, sym::Default]),
@ -34,7 +33,7 @@ pub fn expand_deriving_default(
explicit_self: false, explicit_self: false,
nonself_args: Vec::new(), nonself_args: Vec::new(),
ret_ty: Self_, ret_ty: Self_,
attributes: attrs, attributes: thin_vec![cx.attr_word(sym::inline, span)],
fieldless_variants_strategy: FieldlessVariantsStrategy::Default, fieldless_variants_strategy: FieldlessVariantsStrategy::Default,
combine_substructure: combine_substructure(Box::new(|cx, trait_span, substr| { combine_substructure: combine_substructure(Box::new(|cx, trait_span, substr| {
match substr.fields { match substr.fields {

View file

@ -1,7 +1,7 @@
use crate::deriving::generic::ty::*; use crate::deriving::generic::ty::*;
use crate::deriving::generic::*; use crate::deriving::generic::*;
use crate::deriving::{path_std, pathvec_std}; use crate::deriving::{path_std, pathvec_std};
use rustc_ast::{AttrVec, MetaItem, Mutability}; use rustc_ast::{MetaItem, Mutability};
use rustc_expand::base::{Annotatable, ExtCtxt}; use rustc_expand::base::{Annotatable, ExtCtxt};
use rustc_span::symbol::sym; use rustc_span::symbol::sym;
use rustc_span::Span; use rustc_span::Span;
@ -33,7 +33,7 @@ pub fn expand_deriving_hash(
explicit_self: true, explicit_self: true,
nonself_args: vec![(Ref(Box::new(Path(arg)), Mutability::Mut), sym::state)], nonself_args: vec![(Ref(Box::new(Path(arg)), Mutability::Mut), sym::state)],
ret_ty: Unit, ret_ty: Unit,
attributes: AttrVec::new(), attributes: thin_vec![cx.attr_word(sym::inline, span)],
fieldless_variants_strategy: FieldlessVariantsStrategy::Unify, fieldless_variants_strategy: FieldlessVariantsStrategy::Unify,
combine_substructure: combine_substructure(Box::new(|a, b, c| { combine_substructure: combine_substructure(Box::new(|a, b, c| {
hash_substructure(a, b, c) hash_substructure(a, b, c)

View file

@ -44,6 +44,7 @@ impl ::core::default::Default for Empty {
} }
#[automatically_derived] #[automatically_derived]
impl ::core::hash::Hash for Empty { impl ::core::hash::Hash for Empty {
#[inline]
fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) -> () {} fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) -> () {}
} }
#[automatically_derived] #[automatically_derived]
@ -113,6 +114,7 @@ impl ::core::default::Default for Point {
} }
#[automatically_derived] #[automatically_derived]
impl ::core::hash::Hash for Point { impl ::core::hash::Hash for Point {
#[inline]
fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) -> () { fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) -> () {
::core::hash::Hash::hash(&self.x, state); ::core::hash::Hash::hash(&self.x, state);
::core::hash::Hash::hash(&self.y, state) ::core::hash::Hash::hash(&self.y, state)
@ -198,6 +200,7 @@ impl ::core::default::Default for PackedPoint {
} }
#[automatically_derived] #[automatically_derived]
impl ::core::hash::Hash for PackedPoint { impl ::core::hash::Hash for PackedPoint {
#[inline]
fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) -> () { fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) -> () {
::core::hash::Hash::hash(&{ self.x }, state); ::core::hash::Hash::hash(&{ self.x }, state);
::core::hash::Hash::hash(&{ self.y }, state) ::core::hash::Hash::hash(&{ self.y }, state)
@ -301,6 +304,7 @@ impl ::core::default::Default for Big {
} }
#[automatically_derived] #[automatically_derived]
impl ::core::hash::Hash for Big { impl ::core::hash::Hash for Big {
#[inline]
fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) -> () { fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) -> () {
::core::hash::Hash::hash(&self.b1, state); ::core::hash::Hash::hash(&self.b1, state);
::core::hash::Hash::hash(&self.b2, state); ::core::hash::Hash::hash(&self.b2, state);
@ -478,6 +482,7 @@ impl ::core::fmt::Debug for Unsized {
} }
#[automatically_derived] #[automatically_derived]
impl ::core::hash::Hash for Unsized { impl ::core::hash::Hash for Unsized {
#[inline]
fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) -> () { fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) -> () {
::core::hash::Hash::hash(&self.0, state) ::core::hash::Hash::hash(&self.0, state)
} }
@ -529,6 +534,7 @@ impl ::core::fmt::Debug for PackedUnsizedU8 {
} }
#[automatically_derived] #[automatically_derived]
impl ::core::hash::Hash for PackedUnsizedU8 { impl ::core::hash::Hash for PackedUnsizedU8 {
#[inline]
fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) -> () { fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) -> () {
::core::hash::Hash::hash(&self.0, state) ::core::hash::Hash::hash(&self.0, state)
} }
@ -584,6 +590,7 @@ impl<T: ::core::default::Default + Trait, U: ::core::default::Default>
#[automatically_derived] #[automatically_derived]
impl<T: ::core::hash::Hash + Trait, U: ::core::hash::Hash> ::core::hash::Hash impl<T: ::core::hash::Hash + Trait, U: ::core::hash::Hash> ::core::hash::Hash
for Generic<T, U> where T::A: ::core::hash::Hash { for Generic<T, U> where T::A: ::core::hash::Hash {
#[inline]
fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) -> () { fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) -> () {
::core::hash::Hash::hash(&self.t, state); ::core::hash::Hash::hash(&self.t, state);
::core::hash::Hash::hash(&self.ta, state); ::core::hash::Hash::hash(&self.ta, state);
@ -701,6 +708,7 @@ impl<T: ::core::hash::Hash + ::core::marker::Copy + Trait,
U: ::core::hash::Hash + ::core::marker::Copy> ::core::hash::Hash for U: ::core::hash::Hash + ::core::marker::Copy> ::core::hash::Hash for
PackedGeneric<T, U> where T::A: ::core::hash::Hash + ::core::marker::Copy PackedGeneric<T, U> where T::A: ::core::hash::Hash + ::core::marker::Copy
{ {
#[inline]
fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) -> () { fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) -> () {
::core::hash::Hash::hash(&{ self.0 }, state); ::core::hash::Hash::hash(&{ self.0 }, state);
::core::hash::Hash::hash(&{ self.1 }, state); ::core::hash::Hash::hash(&{ self.1 }, state);
@ -795,6 +803,7 @@ impl ::core::fmt::Debug for Enum0 {
} }
#[automatically_derived] #[automatically_derived]
impl ::core::hash::Hash for Enum0 { impl ::core::hash::Hash for Enum0 {
#[inline]
fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) -> () { fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) -> () {
unsafe { ::core::intrinsics::unreachable() } unsafe { ::core::intrinsics::unreachable() }
} }
@ -861,6 +870,7 @@ impl ::core::fmt::Debug for Enum1 {
} }
#[automatically_derived] #[automatically_derived]
impl ::core::hash::Hash for Enum1 { impl ::core::hash::Hash for Enum1 {
#[inline]
fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) -> () { fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) -> () {
match self { match self {
Enum1::Single { x: __self_0 } => Enum1::Single { x: __self_0 } =>
@ -937,6 +947,7 @@ impl ::core::default::Default for Fieldless1 {
} }
#[automatically_derived] #[automatically_derived]
impl ::core::hash::Hash for Fieldless1 { impl ::core::hash::Hash for Fieldless1 {
#[inline]
fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) -> () {} fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) -> () {}
} }
#[automatically_derived] #[automatically_derived]
@ -1004,6 +1015,7 @@ impl ::core::default::Default for Fieldless {
} }
#[automatically_derived] #[automatically_derived]
impl ::core::hash::Hash for Fieldless { impl ::core::hash::Hash for Fieldless {
#[inline]
fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) -> () { fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) -> () {
let __self_tag = ::core::intrinsics::discriminant_value(self); let __self_tag = ::core::intrinsics::discriminant_value(self);
::core::hash::Hash::hash(&__self_tag, state) ::core::hash::Hash::hash(&__self_tag, state)
@ -1095,6 +1107,7 @@ impl ::core::default::Default for Mixed {
} }
#[automatically_derived] #[automatically_derived]
impl ::core::hash::Hash for Mixed { impl ::core::hash::Hash for Mixed {
#[inline]
fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) -> () { fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) -> () {
let __self_tag = ::core::intrinsics::discriminant_value(self); let __self_tag = ::core::intrinsics::discriminant_value(self);
::core::hash::Hash::hash(&__self_tag, state); ::core::hash::Hash::hash(&__self_tag, state);
@ -1224,6 +1237,7 @@ impl ::core::fmt::Debug for Fielded {
} }
#[automatically_derived] #[automatically_derived]
impl ::core::hash::Hash for Fielded { impl ::core::hash::Hash for Fielded {
#[inline]
fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) -> () { fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) -> () {
let __self_tag = ::core::intrinsics::discriminant_value(self); let __self_tag = ::core::intrinsics::discriminant_value(self);
::core::hash::Hash::hash(&__self_tag, state); ::core::hash::Hash::hash(&__self_tag, state);
@ -1345,6 +1359,7 @@ impl<T: ::core::fmt::Debug, U: ::core::fmt::Debug> ::core::fmt::Debug for
#[automatically_derived] #[automatically_derived]
impl<T: ::core::hash::Hash, U: ::core::hash::Hash> ::core::hash::Hash for impl<T: ::core::hash::Hash, U: ::core::hash::Hash> ::core::hash::Hash for
EnumGeneric<T, U> { EnumGeneric<T, U> {
#[inline]
fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) -> () { fn hash<__H: ::core::hash::Hasher>(&self, state: &mut __H) -> () {
let __self_tag = ::core::intrinsics::discriminant_value(self); let __self_tag = ::core::intrinsics::discriminant_value(self);
::core::hash::Hash::hash(&__self_tag, state); ::core::hash::Hash::hash(&__self_tag, state);