#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;
}
-