Skip to content

Latest commit

 

History

History
71 lines (56 loc) · 1.59 KB

SIGNAL_HANDLING.md

File metadata and controls

71 lines (56 loc) · 1.59 KB

Overview

"A signal is a software interrupt delivered to a process. The operating system uses signals to report exceptional situations to an executing program. Some signals report errors such as references to invalid memory addresses; others report asynchronous events, such as disconnection of a phone line." -- GNU

Example

#include <memory>
#include <cstdlib>
#include <restbed>
#include <csignal>
#include <sys/types.h>

#ifdef _WIN32
    #include <process.h>
#else
    #include <unistd.h>
#endif

using namespace std;
using namespace restbed;

void sighup_handler( const int signal_number )
{
    fprintf( stderr, "Received SIGINT signal number '%i'.\n", signal_number );
}

void sigterm_handler( const int signal_number )
{
    fprintf( stderr, "Received SIGTERM signal number '%i'.\n", signal_number );
}

void ready_handler( Service& )
{
#ifdef _WIN32
    fprintf( stderr, "Service PID is '%i'.\n", _getpid( ) );
#else
    fprintf( stderr, "Service PID is '%i'.\n", getpid( ) );
#endif
}

int main( const int, const char** )
{
    auto settings = make_shared< Settings >( );
    settings->set_port( 1984 );
    
    Service service;
    service.set_ready_handler( ready_handler );
    service.set_signal_handler( SIGINT, sighup_handler );
    service.set_signal_handler( SIGTERM, sigterm_handler );
    service.start( settings );
    
    return EXIT_SUCCESS;
}

Build

$ clang++ -o example example.cpp -l restbed

Execution

$ ./example

$ kill -s SIGINT

$ kill -s SIGTERM