ip_hash_test.cpp 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. //
  2. // ip_hash_test.cpp
  3. //
  4. // Copyright 2011 Peter Dimov
  5. //
  6. // Distributed under the Boost Software License, Version 1.0.
  7. // See accompanying file LICENSE_1_0.txt or copy at
  8. // http://www.boost.org/LICENSE_1_0.txt
  9. //
  10. #include <boost/intrusive_ptr.hpp>
  11. #include <boost/functional/hash.hpp>
  12. #include <boost/detail/lightweight_test.hpp>
  13. class base
  14. {
  15. private:
  16. int use_count_;
  17. base(base const &);
  18. base & operator=(base const &);
  19. protected:
  20. base(): use_count_(0)
  21. {
  22. }
  23. virtual ~base()
  24. {
  25. }
  26. public:
  27. long use_count() const
  28. {
  29. return use_count_;
  30. }
  31. inline friend void intrusive_ptr_add_ref(base * p)
  32. {
  33. ++p->use_count_;
  34. }
  35. inline friend void intrusive_ptr_release(base * p)
  36. {
  37. if(--p->use_count_ == 0) delete p;
  38. }
  39. };
  40. struct X: public base
  41. {
  42. };
  43. int main()
  44. {
  45. boost::hash< boost::intrusive_ptr<X> > hasher;
  46. boost::intrusive_ptr<X> p1, p2( p1 ), p3( new X ), p4( p3 ), p5( new X );
  47. BOOST_TEST_EQ( p1, p2 );
  48. BOOST_TEST_EQ( hasher( p1 ), hasher( p2 ) );
  49. BOOST_TEST_NE( p1, p3 );
  50. BOOST_TEST_NE( hasher( p1 ), hasher( p3 ) );
  51. BOOST_TEST_EQ( p3, p4 );
  52. BOOST_TEST_EQ( hasher( p3 ), hasher( p4 ) );
  53. BOOST_TEST_NE( p3, p5 );
  54. BOOST_TEST_NE( hasher( p3 ), hasher( p5 ) );
  55. return boost::report_errors();
  56. }