diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-13 12:15:43 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-13 12:15:43 +0000 |
commit | f5f56e1a1c4d9e9496fcb9d81131066a964ccd23 (patch) | |
tree | 49e44c6f87febed37efb953ab5485aa49f6481a7 /src/lib/asiolink/io_service_signal.h | |
parent | Initial commit. (diff) | |
download | isc-kea-upstream.tar.xz isc-kea-upstream.zip |
Adding upstream version 2.4.1.upstream/2.4.1upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/lib/asiolink/io_service_signal.h')
-rw-r--r-- | src/lib/asiolink/io_service_signal.h | 60 |
1 files changed, 60 insertions, 0 deletions
diff --git a/src/lib/asiolink/io_service_signal.h b/src/lib/asiolink/io_service_signal.h new file mode 100644 index 0000000..8fbcbe1 --- /dev/null +++ b/src/lib/asiolink/io_service_signal.h @@ -0,0 +1,60 @@ +// Copyright (C) 2020-2023 Internet Systems Consortium, Inc. ("ISC") +// +// This Source Code Form is subject to the terms of the Mozilla Public +// License, v. 2.0. If a copy of the MPL was not distributed with this +// file, You can obtain one at http://mozilla.org/MPL/2.0/. + +#ifndef IO_SERVICE_SIGNAL_H +#define IO_SERVICE_SIGNAL_H + +#include <asiolink/io_service.h> + +#include <boost/shared_ptr.hpp> + +namespace isc { +namespace asiolink { + +/// @brief Defines a handler function for an IOSignal. +typedef std::function<void(int signum)> IOSignalHandler; + +class IOSignalSetImpl; + +/// @brief Implements an asynchronous "signal" for IOService driven processing +/// +/// This class allows a OS signal such as SIGHUP to propagated to an IOService +/// as a ready event with a callback using boost ASIO. +class IOSignalSet { +public: + /// @brief Constructor. + /// + /// @param io_service IOService to which to send the signal. + /// @param handler Handler to call when a signal is received. + IOSignalSet(asiolink::IOServicePtr io_service, IOSignalHandler handler); + + /// @brief Destructor. + ~IOSignalSet(); + + /// @brief Add a signal to the list of signals to handle. + /// + /// @param signum Signal number. + /// @throw Unexpected on error. + void add(int signum); + + /// @brief Remove a signal from the list of signals to handle. + /// + /// @param signum Signal number. + /// @throw Unexpected on error. + void remove(int signum); + +private: + /// @brief Pointer to the implementation. + boost::shared_ptr<IOSignalSetImpl> impl_; +}; + +/// @brief Defines a pointer to an IOSignalSet. +typedef boost::shared_ptr<IOSignalSet> IOSignalSetPtr; + +} // namespace asiolink +} // namespace isc + +#endif // IO_SERVICE_SIGNAL_H |