Add signal handling
This commit is contained in:
@@ -12,8 +12,13 @@
|
||||
#include <tuple>
|
||||
#include <utility>
|
||||
#include <complex>
|
||||
#include <csignal>
|
||||
#include <common/callback.hpp>
|
||||
|
||||
|
||||
bool registerSignalHandler(void); // registers a Control-c handler
|
||||
void signalHandler(int signal); // The Control-C handler
|
||||
|
||||
class Info
|
||||
{
|
||||
public:
|
||||
@@ -104,6 +109,11 @@ void Monitor::doCallback(CallbackData<Info> &callbackData)
|
||||
|
||||
int main(int argc, char ** argv)
|
||||
{
|
||||
registerSignalHandler();
|
||||
while(true)
|
||||
{
|
||||
// do stuff
|
||||
}
|
||||
// std::vector<int> myBigVec(10000000, 2011);
|
||||
// std::vector<std::string> s1;
|
||||
// std::vector<std::string> s2;
|
||||
@@ -114,21 +124,42 @@ int main(int argc, char ** argv)
|
||||
// s2 = std::move(s1);
|
||||
|
||||
|
||||
Monitor monitor;
|
||||
// SmartPointer<B> b(::new B(),PointerDisposition::Delete);
|
||||
SmartPointer<B> b(true);
|
||||
Callback<B,Info> callback(&(*b),&B::callback);
|
||||
monitor.setCallback(callback);
|
||||
// Monitor monitor;
|
||||
// SmartPointer<B> b(true);
|
||||
// Callback<B,Info> callback(&(*b),&B::callback);
|
||||
// monitor.setCallback(callback);
|
||||
|
||||
Info info;
|
||||
info.setMessage("Hello");
|
||||
// Info info;
|
||||
// info.setMessage("Hello");
|
||||
|
||||
CallbackData<Info> callbackData(info);
|
||||
monitor.doCallback(callbackData);
|
||||
// CallbackData<Info> callbackData(info);
|
||||
// monitor.doCallback(callbackData);
|
||||
|
||||
}
|
||||
|
||||
/// @brief The signal handler
|
||||
void signalHandler(int signal)
|
||||
{
|
||||
std::cout << "Received signal " << signal << std::endl;
|
||||
exit(signal);
|
||||
}
|
||||
|
||||
/// @brief Method that registers the signal handler
|
||||
/// @param
|
||||
bool registerSignalHandler(void)
|
||||
{
|
||||
struct sigaction sa;
|
||||
sa.sa_handler = signalHandler;
|
||||
sigemptyset(&sa.sa_mask); // Clear the mask of blocked signals
|
||||
sa.sa_flags = 0; // No special flags
|
||||
|
||||
if (-1==sigaction(SIGINT, &sa, nullptr))
|
||||
{
|
||||
std::cerr << "Error registering SIGINT handler." << std::endl;
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user