⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 hash_fwd_test.hpp

📁 Boost provides free peer-reviewed portable C++ source libraries. We emphasize libraries that work
💻 HPP
字号:
// Copyright 2006-2008 Daniel James.// Distributed under the Boost Software License, Version 1.0. (See accompanying// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)#include "./config.hpp"#if defined(TEST_EXTENSIONS) && !defined(TEST_STD_INCLUDES)#include <boost/functional/hash_fwd.hpp>#include <boost/config.hpp>#include <cstddef>#include <vector>namespace test {    template <class T>    struct test_type1    {        T value;        test_type1(T const& x) : value(x) {}    };#if !defined(BOOST_NO_ARGUMENT_DEPENDENT_LOOKUP)    template <class T>    std::size_t hash_value(test_type1<T> const& x)    {        HASH_NAMESPACE::hash<T> hasher;        return hasher(x.value);    }#endif    template <class T>    struct test_type2    {        T value1, value2;        test_type2(T const& x, T const& y) : value1(x), value2(y) {}    };#if !defined(BOOST_NO_ARGUMENT_DEPENDENT_LOOKUP)    template <class T>    std::size_t hash_value(test_type2<T> const& x)    {        std::size_t seed = 0;        HASH_NAMESPACE::hash_combine(seed, x.value1);        HASH_NAMESPACE::hash_combine(seed, x.value2);        return seed;    }#endif    template <class T>    struct test_type3    {        std::vector<T> values;        test_type3(typename std::vector<T>::iterator x,                typename std::vector<T>::iterator y) : values(x, y) {}    };#if !defined(BOOST_NO_ARGUMENT_DEPENDENT_LOOKUP)    template <class T>    std::size_t hash_value(test_type3<T> const& x)    {        std::size_t seed = HASH_NAMESPACE::hash_range(x.values.begin(), x.values.end());        HASH_NAMESPACE::hash_range(seed, x.values.begin(), x.values.end());        return seed;    }#endif}#if defined(BOOST_NO_ARGUMENT_DEPENDENT_LOOKUP)namespace boost{    template <class T>    std::size_t hash_value(test::test_type1<T> const& x)    {        HASH_NAMESPACE::hash<T> hasher;        return hasher(x.value);    }    template <class T>    std::size_t hash_value(test::test_type2<T> const& x)    {        std::size_t seed = 0;        HASH_NAMESPACE::hash_combine(seed, x.value1);        HASH_NAMESPACE::hash_combine(seed, x.value2);        return seed;    }    template <class T>    std::size_t hash_value(test::test_type3<T> const& x)    {        std::size_t seed = HASH_NAMESPACE::hash_range(x.values.begin(), x.values.end());        HASH_NAMESPACE::hash_range(seed, x.values.begin(), x.values.end());        return seed;    }}#endif#endif

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -