mirror of
https://github.com/boostorg/functional.git
synced 2026-01-26 08:52:27 +01:00
* Avoid float to int warning. * Work around 'using namespace' bug in Visual C++. * Make `<boost/functional/hash/extensions.hpp> self contained. * Move some of the extension implementation from the main hash header into the exensions header. * Remove BOOST_HASH_CHAR_TRAITS from `container_fwd.hpp`. * Other minor changes. Merged revisions 53828,53924,54024-54025,54033-54034,54139-54145,54399 via svnmerge from https://svn.boost.org/svn/boost/trunk ........ r53828 | danieljames | 2009-06-12 19:24:47 +0100 (Fri, 12 Jun 2009) | 1 line Try to avoid float to int warning when a float function doesn't exist. ........ r53924 | danieljames | 2009-06-15 08:37:42 +0100 (Mon, 15 Jun 2009) | 4 lines Remove hash_complex_test's dependency on Boost.Random. Only test for a few values, but that should be okay as there isn't much to test. ........ r54024 | danieljames | 2009-06-17 22:22:49 +0100 (Wed, 17 Jun 2009) | 1 line Put the minimum amount of implementation in the same namespace as the 'using namespace' directives in order to avoid Visual C++ 8 bug. ........ r54025 | danieljames | 2009-06-17 22:23:42 +0100 (Wed, 17 Jun 2009) | 1 line Try to avoid using special macro handling code. ........ r54033 | danieljames | 2009-06-18 00:24:28 +0100 (Thu, 18 Jun 2009) | 1 line Add copyright to namespace_fail_test.cpp ........ r54034 | danieljames | 2009-06-18 00:25:12 +0100 (Thu, 18 Jun 2009) | 1 line A couple of missing newlines. ........ r54139 | danieljames | 2009-06-21 10:41:11 +0100 (Sun, 21 Jun 2009) | 1 line A few more comments in boost::hash. ........ r54140 | danieljames | 2009-06-21 10:41:30 +0100 (Sun, 21 Jun 2009) | 1 line Move includes to the header which they're used in. ........ r54141 | danieljames | 2009-06-21 10:41:46 +0100 (Sun, 21 Jun 2009) | 1 line Revert [54025] "Try to avoid using special macro handling code." ........ r54142 | danieljames | 2009-06-21 10:42:05 +0100 (Sun, 21 Jun 2009) | 1 line Get <boost/functional/hash/extensions.hpp> to work. ........ r54143 | danieljames | 2009-06-21 10:42:20 +0100 (Sun, 21 Jun 2009) | 1 line Move BOOST_HASH_CHAR_TRAITS from container_fwd into the hash headers, and undefine it. ........ r54144 | danieljames | 2009-06-21 10:42:40 +0100 (Sun, 21 Jun 2009) | 1 line Move the support for hashing containers into the extension header, and improve the standard tests. ........ r54145 | danieljames | 2009-06-21 10:51:59 +0100 (Sun, 21 Jun 2009) | 1 line I didn't mean to comment this out. ........ r54399 | danieljames | 2009-06-27 08:39:12 +0100 (Sat, 27 Jun 2009) | 1 line Add am implementation note about the Visual C++ problems. ........ [SVN r54402]
97 lines
2.6 KiB
C++
97 lines
2.6 KiB
C++
|
|
// Copyright 2005-2009 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)
|
|
|
|
int main() {}
|
|
|
|
#else
|
|
|
|
#ifdef TEST_STD_INCLUDES
|
|
# include <functional>
|
|
#else
|
|
# include <boost/functional/hash.hpp>
|
|
#endif
|
|
|
|
#include <boost/detail/lightweight_test.hpp>
|
|
|
|
#include <complex>
|
|
#include <sstream>
|
|
#include <boost/limits.hpp>
|
|
|
|
#if defined(BOOST_MSVC)
|
|
#pragma warning(push)
|
|
#pragma warning(disable:4244) // conversion from 'unsigned long' to 'unsigned short', possible loss of data
|
|
#pragma warning(disable:4512) // assignment operator could not be generated
|
|
#endif
|
|
|
|
#if defined(BOOST_MSVC)
|
|
#pragma warning(pop)
|
|
#endif
|
|
|
|
template <class T>
|
|
void generic_complex_tests(std::complex<T> v)
|
|
{
|
|
HASH_NAMESPACE::hash<std::complex<T> > complex_hasher;
|
|
|
|
BOOST_TEST(complex_hasher(v) == complex_hasher(v));
|
|
|
|
HASH_NAMESPACE::hash<T> real_hasher;
|
|
T real = v.real();
|
|
T imag = v.imag();
|
|
|
|
BOOST_TEST(real_hasher(real) == complex_hasher(std::complex<T>(real)));
|
|
|
|
if(imag != 0 && real_hasher(real) == complex_hasher(v)) {
|
|
std::ostringstream os;
|
|
os<<"real_hasher("<<real<<") == complex_hasher("
|
|
<<v.real()<<" + "<<v.imag()<<"i) == "
|
|
<<real_hasher(real)<<" (This might not be a bug).";
|
|
BOOST_ERROR(os.str().c_str());
|
|
}
|
|
}
|
|
|
|
template <class Float>
|
|
void complex_float_tests(Float*)
|
|
{
|
|
typedef std::complex<Float> complex;
|
|
generic_complex_tests(complex(0,0));
|
|
generic_complex_tests(complex(0.5,0));
|
|
generic_complex_tests(complex(25,0));
|
|
generic_complex_tests(complex(25,0));
|
|
generic_complex_tests(complex(-67.5324535,56.23578678));
|
|
}
|
|
|
|
template <class Integer>
|
|
void complex_integral_tests(Integer*)
|
|
{
|
|
typedef std::complex<Integer> complex;
|
|
generic_complex_tests(complex(0,0));
|
|
generic_complex_tests(complex(15342,124));
|
|
generic_complex_tests(complex(25,54356));
|
|
generic_complex_tests(complex(5325,2346));
|
|
generic_complex_tests(complex(-243897,-49923874));
|
|
generic_complex_tests(complex(-543,763));
|
|
}
|
|
|
|
int main()
|
|
{
|
|
complex_float_tests((float*) 0);
|
|
complex_float_tests((double*) 0);
|
|
complex_float_tests((long double*) 0);
|
|
complex_integral_tests((short*) 0);
|
|
complex_integral_tests((int*) 0);
|
|
complex_integral_tests((long*) 0);
|
|
complex_integral_tests((unsigned short*) 0);
|
|
complex_integral_tests((unsigned int*) 0);
|
|
complex_integral_tests((unsigned long*) 0);
|
|
|
|
return boost::report_errors();
|
|
}
|
|
|
|
#endif // TEST_EXTENSIONS
|