dtor_pass.cpp 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. //===----------------------------------------------------------------------===//
  2. //
  3. // The LLVM Compiler Infrastructure
  4. //
  5. // This file is dual licensed under the MIT and the University of Illinois Open
  6. // Source Licenses. See LICENSE.TXT for details.
  7. //
  8. //===----------------------------------------------------------------------===//
  9. // Copyright (C) 2011 Vicente J. Botet Escriba
  10. //
  11. // Distributed under the Boost Software License, Version 1.0. (See accompanying
  12. // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
  13. // <boost/thread/future.hpp>
  14. // class shared_future<R>
  15. // ~shared_future();
  16. #define BOOST_THREAD_VERSION 3
  17. #include <boost/exception/exception.hpp>
  18. #include <boost/thread/future.hpp>
  19. #include <boost/detail/lightweight_test.hpp>
  20. #if defined BOOST_THREAD_PROVIDES_FUTURE_CTOR_ALLOCATORS
  21. #include "../test_allocator.hpp"
  22. #endif
  23. int main()
  24. {
  25. #if defined BOOST_THREAD_PROVIDES_FUTURE_CTOR_ALLOCATORS
  26. BOOST_TEST(test_alloc_base::count == 0);
  27. {
  28. typedef int T;
  29. boost::shared_future<T> f;
  30. {
  31. boost::promise<T> p(boost::allocator_arg, test_allocator<T>());
  32. BOOST_TEST(test_alloc_base::count == 1);
  33. f = BOOST_THREAD_MAKE_RV_REF(p.get_future());
  34. BOOST_TEST(test_alloc_base::count == 1);
  35. BOOST_TEST(f.valid());
  36. }
  37. BOOST_TEST(test_alloc_base::count == 1);
  38. BOOST_TEST(f.valid());
  39. }
  40. BOOST_TEST(test_alloc_base::count == 0);
  41. {
  42. typedef int& T;
  43. boost::shared_future<T> f;
  44. {
  45. boost::promise<T> p(boost::allocator_arg, test_allocator<int>());
  46. BOOST_TEST(test_alloc_base::count == 1);
  47. f = BOOST_THREAD_MAKE_RV_REF(p.get_future());
  48. BOOST_TEST(test_alloc_base::count == 1);
  49. BOOST_TEST(f.valid());
  50. }
  51. BOOST_TEST(test_alloc_base::count == 1);
  52. BOOST_TEST(f.valid());
  53. }
  54. BOOST_TEST(test_alloc_base::count == 0);
  55. {
  56. typedef void T;
  57. boost::shared_future<T> f;
  58. {
  59. boost::promise<T> p(boost::allocator_arg, test_allocator<T>());
  60. BOOST_TEST(test_alloc_base::count == 1);
  61. f = BOOST_THREAD_MAKE_RV_REF(p.get_future());
  62. BOOST_TEST(test_alloc_base::count == 1);
  63. BOOST_TEST(f.valid());
  64. }
  65. BOOST_TEST(test_alloc_base::count == 1);
  66. BOOST_TEST(f.valid());
  67. }
  68. BOOST_TEST(test_alloc_base::count == 0);
  69. #endif
  70. {
  71. typedef int T;
  72. boost::shared_future<T> f;
  73. {
  74. boost::promise<T> p;
  75. f = BOOST_THREAD_MAKE_RV_REF(p.get_future());
  76. BOOST_TEST(f.valid());
  77. }
  78. BOOST_TEST(f.valid());
  79. }
  80. {
  81. typedef int& T;
  82. boost::shared_future<T> f;
  83. {
  84. boost::promise<T> p;
  85. f = BOOST_THREAD_MAKE_RV_REF(p.get_future());
  86. BOOST_TEST(f.valid());
  87. }
  88. BOOST_TEST(f.valid());
  89. }
  90. {
  91. typedef void T;
  92. boost::shared_future<T> f;
  93. {
  94. boost::promise<T> p;
  95. f = BOOST_THREAD_MAKE_RV_REF(p.get_future());
  96. BOOST_TEST(f.valid());
  97. }
  98. BOOST_TEST(f.valid());
  99. }
  100. return boost::report_errors();
  101. }