1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68
|
/*
* Copyright Lingxi Li 2015.
* Copyright Andrey Semashev 2016.
* 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)
*/
#if !defined(BOOST_LOG_WITHOUT_IPC)
#include <iostream>
#include <string>
#include <exception>
#include <boost/log/utility/ipc/reliable_message_queue.hpp>
#include <boost/log/utility/ipc/object_name.hpp>
#include <boost/log/utility/open_mode.hpp>
namespace logging = boost::log;
namespace keywords = boost::log::keywords;
//[ example_sinks_ipc_receiver
int main()
{
try
{
typedef logging::ipc::reliable_message_queue queue_t;
// Create a message_queue_type object that is associated with the interprocess
// message queue named "ipc_message_queue".
queue_t queue
(
keywords::name = logging::ipc::object_name(logging::ipc::object_name::user, "ipc_message_queue"),
keywords::open_mode = logging::open_mode::open_or_create,
keywords::capacity = 256,
keywords::block_size = 1024,
keywords::overflow_policy = queue_t::block_on_overflow
);
std::cout << "Viewer process running..." << std::endl;
// Keep reading log messages from the associated message queue and print them on the console.
// queue.receive() will block if the queue is empty.
std::string message;
while (queue.receive(message) == queue_t::succeeded)
{
std::cout << message << std::endl;
// Clear the buffer for the next message
message.clear();
}
}
catch (std::exception& e)
{
std::cout << "Failure: " << e.what() << std::endl;
}
return 0;
}
//]
#else // !defined(BOOST_LOG_WITHOUT_IPC)
int main()
{
return 0;
}
#endif // !defined(BOOST_LOG_WITHOUT_IPC)
|