]> git.proxmox.com Git - ceph.git/blobdiff - ceph/src/boost/libs/interprocess/test/named_condition_any_test.cpp
update ceph source to reef 18.1.2
[ceph.git] / ceph / src / boost / libs / interprocess / test / named_condition_any_test.cpp
index 9033c4a85ada85252e9bdc5d57a2dad9dd756994..252b511ab5ea096541f5db117643419e5451efd5 100644 (file)
 #include <string>
 #include <sstream>
 #include "get_process_id_name.hpp"
+#include "named_condition_test_helpers.hpp"
 
-using namespace boost::interprocess;
-
-struct condition_deleter
-{
-   std::string name;
-
-   ~condition_deleter()
-   {
-      if(name.empty())
-         named_condition_any::remove(test::add_to_process_id_name("named_condition_any"));
-      else
-         named_condition_any::remove(name.c_str());
-   }
-};
-
-inline std::string num_to_string(int n)
-{  std::stringstream s; s << n; return s.str(); }
-
-//This wrapper is necessary to have a default constructor
-//in generic mutex_test_template functions
-class named_condition_any_test_wrapper
-   : public condition_deleter, public named_condition_any
-{
-   public:
-
-   named_condition_any_test_wrapper()
-      :  named_condition_any(open_or_create,
-             (test::add_to_process_id_name("test_cond") + num_to_string(count)).c_str())
-   {
-      condition_deleter::name += test::add_to_process_id_name("test_cond");
-      condition_deleter::name += num_to_string(count);
-      ++count;
-   }
-
-   ~named_condition_any_test_wrapper()
-   {  --count; }
-
-
-   template <typename L>
-   void wait(L& lock)
-   {
-      ipcdetail::internal_mutex_lock<L> internal_lock(lock);
-      named_condition_any::wait(internal_lock);
-   }
-
-   template <typename L, typename Pr>
-   void wait(L& lock, Pr pred)
-   {
-      ipcdetail::internal_mutex_lock<L> internal_lock(lock);
-      named_condition_any::wait(internal_lock, pred);
-   }
-
-   template <typename L>
-   bool timed_wait(L& lock, const boost::posix_time::ptime &abs_time)
-   {
-      ipcdetail::internal_mutex_lock<L> internal_lock(lock);
-      return named_condition_any::timed_wait(internal_lock, abs_time);
-   }
-
-   template <typename L, typename Pr>
-   bool timed_wait(L& lock, const boost::posix_time::ptime &abs_time, Pr pred)
-   {
-      ipcdetail::internal_mutex_lock<L> internal_lock(lock);
-      return named_condition_any::timed_wait(internal_lock, abs_time, pred);
-   }
-
-   static int count;
-};
-
-int named_condition_any_test_wrapper::count = 0;
-
-//This wrapper is necessary to have a common constructor
-//in generic named_creation_template functions
-class named_condition_any_creation_test_wrapper
-   : public condition_deleter, public named_condition_any
-{
-   public:
-   named_condition_any_creation_test_wrapper(create_only_t)
-      :  named_condition_any(create_only, test::add_to_process_id_name("named_condition_any"))
-   {  ++count_;   }
-
-   named_condition_any_creation_test_wrapper(open_only_t)
-      :  named_condition_any(open_only, test::add_to_process_id_name("named_condition_any"))
-   {  ++count_;   }
-
-   named_condition_any_creation_test_wrapper(open_or_create_t)
-      :  named_condition_any(open_or_create, test::add_to_process_id_name("named_condition_any"))
-   {  ++count_;   }
-
-   ~named_condition_any_creation_test_wrapper()   {
-      if(--count_){
-         ipcdetail::interprocess_tester::
-            dont_close_on_destruction(static_cast<named_condition_any&>(*this));
-      }
-   }
-   static int count_;
-};
-
-int named_condition_any_creation_test_wrapper::count_ = 0;
+#if defined(BOOST_INTERPROCESS_WINDOWS)
+#include <boost/interprocess/sync/windows/named_condition_any.hpp>
+#include <boost/interprocess/sync/windows/named_mutex.hpp>
+#endif
 
-struct mutex_deleter
-{
-   std::string name;
-
-   ~mutex_deleter()
-   {
-      if(name.empty())
-         named_mutex::remove(test::add_to_process_id_name("named_mutex"));
-      else
-         named_mutex::remove(name.c_str());
-   }
-};
-
-//This wrapper is necessary to have a default constructor
-//in generic mutex_test_template functions
-class named_mutex_test_wrapper
-   : public mutex_deleter, public named_mutex
-{
-   public:
-   named_mutex_test_wrapper()
-      :  named_mutex(open_or_create,
-             (test::add_to_process_id_name("test_mutex") + num_to_string(count)).c_str())
-   {
-      mutex_deleter::name += test::add_to_process_id_name("test_mutex");
-      mutex_deleter::name += num_to_string(count);
-      ++count;
-   }
-
-   typedef named_mutex internal_mutex_type;
-
-   internal_mutex_type &internal_mutex()
-   {  return *this;  }
-
-   ~named_mutex_test_wrapper()
-   {  --count; }
-
-   static int count;
-};
-
-int named_mutex_test_wrapper::count = 0;
+using namespace boost::interprocess;
 
-int main ()
+int main()
 {
-   try{
-      //Remove previous mutexes and conditions
-      named_mutex::remove(test::add_to_process_id_name("test_mutex0"));
-      named_condition_any::remove(test::add_to_process_id_name("test_cond0"));
-      named_condition_any::remove(test::add_to_process_id_name("test_cond1"));
-      named_condition_any::remove(test::add_to_process_id_name("named_condition_any"));
-      named_mutex::remove(test::add_to_process_id_name("named_mutex"));
-
-      test::test_named_creation<named_condition_any_creation_test_wrapper>();
-      test::do_test_condition<named_condition_any_test_wrapper
-                             ,named_mutex_test_wrapper>();
-   }
-   catch(std::exception &ex){
-      std::cout << ex.what() << std::endl;
-      return 1;
-   }
-   named_mutex::remove(test::add_to_process_id_name("test_mutex0"));
-   named_condition_any::remove(test::add_to_process_id_name("test_cond0"));
-   named_condition_any::remove(test::add_to_process_id_name("test_cond1"));
-   named_condition_any::remove(test::add_to_process_id_name("named_condition_any"));
-   named_mutex::remove(test::add_to_process_id_name("named_mutex"));
-   return 0;
+   int ret;
+   #if defined(BOOST_INTERPROCESS_WINDOWS)
+   ret = test::test_named_condition<ipcdetail::winapi_named_condition_any, ipcdetail::winapi_named_mutex>();
+   if (ret)
+      return ret;
+   #endif
+   ret = test::test_named_condition<named_condition_any, named_mutex>();
+   
+   return ret;
 }
-