From: Richard Sandiford Date: Mon, 27 Nov 2023 13:38:16 +0000 (+0000) Subject: attribs: Use existing traits for excl_hash_traits X-Git-Tag: basepoints/gcc-15~4262 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=5b33cf3a3a2025a4856f90fea8bd04884c2f6b31;p=thirdparty%2Fgcc.git attribs: Use existing traits for excl_hash_traits excl_hash_traits can be defined more simply by reusing existing traits. gcc/ * attribs.cc (excl_hash_traits): Delete. (test_attribute_exclusions): Use pair_hash and nofree_string_hash instead. --- diff --git a/gcc/attribs.cc b/gcc/attribs.cc index f9fd25859891..c7209c26acc9 100644 --- a/gcc/attribs.cc +++ b/gcc/attribs.cc @@ -2649,47 +2649,6 @@ namespace selftest typedef std::pair excl_pair; -struct excl_hash_traits: typed_noop_remove -{ - typedef excl_pair value_type; - typedef value_type compare_type; - - static hashval_t hash (const value_type &x) - { - hashval_t h1 = htab_hash_string (x.first); - hashval_t h2 = htab_hash_string (x.second); - return h1 ^ h2; - } - - static bool equal (const value_type &x, const value_type &y) - { - return !strcmp (x.first, y.first) && !strcmp (x.second, y.second); - } - - static void mark_deleted (value_type &x) - { - x = value_type (NULL, NULL); - } - - static const bool empty_zero_p = false; - - static void mark_empty (value_type &x) - { - x = value_type ("", ""); - } - - static bool is_deleted (const value_type &x) - { - return !x.first && !x.second; - } - - static bool is_empty (const value_type &x) - { - return !*x.first && !*x.second; - } -}; - - /* Self-test to verify that each attribute exclusion is symmetric, meaning that if attribute A is encoded as incompatible with attribute B then the opposite relationship is also encoded. @@ -2699,13 +2658,15 @@ struct excl_hash_traits: typed_noop_remove static void test_attribute_exclusions () { + using excl_hash_traits = pair_hash; + /* Iterate over the array of attribute tables first (with TI0 as the index) and over the array of attribute_spec in each table (with SI0 as the index). */ const size_t ntables = ARRAY_SIZE (attribute_tables); /* Set of pairs of mutually exclusive attributes. */ - typedef hash_set exclusion_set; + typedef hash_set exclusion_set; exclusion_set excl_set; for (size_t ti0 = 0; ti0 != ntables; ++ti0)