|
dune-common 2.10
|
Support for calculating hash values of objects. More...
Go to the source code of this file.
Classes | |
| struct | Dune::hash< T > |
| Functor for hashing objects of type T. More... | |
Namespaces | |
| namespace | Dune |
| Dune namespace. | |
Macros | |
| #define | DUNE_DEFINE_HASH(template_args, type) |
| Defines the required struct specialization to make type hashable via Dune::hash. | |
| #define | DUNE_HASH_TEMPLATE_ARGS(...) |
| Wrapper macro for the template arguments in DUNE_DEFINE_HASH. | |
| #define | DUNE_HASH_TYPE(...) |
| Wrapper macro for the type to be hashed in DUNE_DEFINE_HASH. | |
Functions | |
| template<typename T> | |
| void | Dune::hash_combine (std::size_t &seed, const T &arg) |
| Calculates the hash value of arg and combines it in-place with seed. | |
| template<typename It> | |
| std::size_t | Dune::hash_range (It first, It last) |
| Hashes all elements in the range [first,last) and returns the combined hash. | |
| template<typename It> | |
| void | Dune::hash_range (std::size_t &seed, It first, It last) |
| Hashes all elements in the range [first,last) and combines the hashes in-place with seed. | |
Support for calculating hash values of objects.
This file provides the functor Dune::hash to calculate hash values and some infrastructure to simplify extending Dune::hash for user-defined types, independent of the actual underlying implementation.
| #define DUNE_DEFINE_HASH | ( | template_args, | |
| type ) |
Defines the required struct specialization to make type hashable via Dune::hash.
In order to calculate the hash, operator() of the generated specialization will return the result of an unqualified call to the global function hash_value(const type&). As the call is not qualified, the function will be found using argument-dependent lookup, allowing implementors to conveniently place it inside the class body.
Consider the following type:
In order to add support for Dune::hash, you need to extend the definition like this:
| template_args | The template arguments required by the hash struct specialization, wrapped in a call to DUNE_HASH_TEMPLATE_ARGS. If this is a complete specialization, call DUNE_HASH_TEMPLATE_ARGS without arguments. |
| type | The exact type of the specialization, wrapped in a call to DUNE_HASH_TYPE. |
| #define DUNE_HASH_TEMPLATE_ARGS | ( | ... | ) |
Wrapper macro for the template arguments in DUNE_DEFINE_HASH.
This macro should always be used as a wrapper for the template arguments when calling DUNE_DEFINE_HASH. It works around some preprocessor limitations when the template arguments contain commas or the list is completely empty.
| #define DUNE_HASH_TYPE | ( | ... | ) |
Wrapper macro for the type to be hashed in DUNE_DEFINE_HASH.
This macro should always be used as a wrapper for the type of the specialization when calling DUNE_DEFINE_HASH. It works around some preprocessor limitations when the type contains commas.