/usr/include/assa-3.5/assa/SigAction.h is in libassa-3.5-5-dev 3.5.1-6+b1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 | // -*- c++ -*-
//------------------------------------------------------------------------------
// SigAction.h
//------------------------------------------------------------------------------
// Copyright (c) 1997 by Vladislav Grinchenko
//
// This library is free software; you can redistribute it and/or
// modify it under the terms of the GNU Library General Public
// License as published by the Free Software Foundation; either
// version 2 of the License, or (at your option) any later version.
//------------------------------------------------------------------------------
#ifndef _SigAction_h
#define _SigAction_h
// System includes
//
#include <signal.h>
#include <errno.h>
#include "assa/Assure.h"
#include "assa/SigSet.h"
// some convenient typedefs
//
extern "C" {
typedef struct sigaction SIGACTION;
typedef void (*C_SIG_HANDLER)( int );
}
namespace ASSA {
#if !defined(WIN32)
/** @file SigAction.h
SigAction is a C++ wrapper around sigaction structure
Class SigAction implements a C++ wrapper around
struct sigaction. It class also provides a range of all possible
operation that can be performed on it, including sigaction(2) system call.
struct sigaction is defined as:
<pre>
struct sigaction {
void (*sa_handler) ();
sigset_t sa_mask;
int sa_flags;
void (*sa_sigaction) (int, siginfo_t*, void*);
};
</pre>
It is used to set all the details of what your process should do when
a signal arrives. It encapsulates the action to be taken on receipt
of a particular signal.
The most important member is sa_handler, which takes a pointer
to a function. This function will be invoked whenever the process gets
a particular POSIX.1 signal.
Some of the member function of SigAction class take a parameter
of type C_SIG_HANDLER.
It can be one of:
- "C" signal handling function (sa_handler above):\n
void sig_handler (int signum)
- SIG_ERR
- SIG DFL takes default signal action when caught
- SIG_IGN ignores signal (for those that can be ignored)
The sa_mask mask for the signal action specifies a set of signals
to be blocked while the signal handler is active.
On the entry into the signal handler,
that set of signals is added to a set of signals already being
blocked from delivery when the signal is delivered to the process.
In addition, the signal that caused the handler to be executed will also
be blocked (SIGSTOP and SIGKILL cannot be blocked - this is enforced
by the underlying OS).
Flags sa_flags in the set of flags ORed that allows to modify
the delivery of the signal.
POSIX.1 spec. defines only SA_NOCLDSTOP flag. All other
flags are system-dependent. Consult your local sigaction(2)
man page for details.
Because SigAction is a wrapper around sigaction(2),
after sig_handler returns (and before anything else), the OS
will reinstall current disposition for the signal. To reset signal's
disposition to SIG_DFL, SUN Solaris OS uses flag SA_RESETHAND, and Linux OS
uses SA_ONESHOT.
*/
class SigAction
{
public:
/** Default constructor creates SigAction object
with null-action.
*/
SigAction();
/** Construct a SigAction object with "C" signal
handler function. This constructor doesn't install any
actions - it is merely a shell for actiono to be installed
for any signal(s). Thus, you can reuse the same object for
number of differen signals.
@param handler_ "C" signal handler function to call.
@param sig_mask_ Set of signals to block while handler_
is active.
@param flags_ Controls behavior of signal handler (OS-specific:
see Available Options: section of documentation).
*/
SigAction (C_SIG_HANDLER handler_,
SigSet* sig_mask_ = 0,
int flags_ = 0);
/** Construct a SigAction with "C" signal handler function
and change program's disposition for signum_
immediately.<p>
First argument is the "C" function. It cannot be a non-static
C++ class member function. This function pretty much simulates
C-like approach the the signal handling. For C++ member
function approach, see SigHandler & Co.
@param handler_ "C" signal handler function to call.
@param signum_ Signal which disposition is to change.
@param sig_mask_ Set of signals to block while handler_
is active.
@param flags_ Controls behavior of signal handler (OS-specific:
see Available Options: section of documentation).
*/
SigAction (C_SIG_HANDLER handler_,
int signum_,
SigSet* sig_mask_ = 0,
int flags_ = 0);
/** Register this object as current disposition for signal
signum_, and store old disposition in oaction_,
if not NULL. This function installs C_SIG_HANDLER this
object represents, thus simulating C-like approach to signal
handling.
@param signum_ Signal which disposition to install.
@param oaction_ Placeholder for the old disposition.
@return 0 on success, -1 on error, with errno indicating
the error.
*/
int register_action (int signum_, SigAction* oaction_ = 0);
/** Change object's disposition to oaction_, and install
it as current disposition for the signal signum_.
@param signum_ Signal which disposition to restore.
@param oaction_ Disposition to restore.
@return 0 on success, -1 on error, with errno indicating
the error.
*/
int restore_action (int signum_, SigAction& oaction_);
/** Retrieve current disposition for the signal signum_
into this object.
@param signum_ Signal number
@return 0 on success, -1 on error, with errno indicating
the error.
*/
int retrieve_action (int signum_);
/** Set sigaction structure to sa_
@param sa_ New value for internal struct sigaction.
*/
void action (SIGACTION * sa_);
/** Retrieve current sigaction.
@return Pointer to an internal struct sigaction.
*/
SIGACTION * action ();
/** Set signal flags to new_flags_.
@param new_flags_ New flags for this action.
*/
void flags (int new_flags_);
/** Retrieve current flags.
@return Value of current flags for this action.
*/
int flags ();
/** Set new signal mask mask_set_.
*/
void mask (SigSet & mask_set_);
/** Retrieve current signal mask.
*/
SigSet mask ();
/** Set new signal handler to function pointer sha_.
*/
void handler (C_SIG_HANDLER sha_);
/** Retrieve current signal handler function.
*/
C_SIG_HANDLER handler ();
/** Conversion operator that converts SigAction to a
pointer to the internal struct sigaction data
member for direct use with C-library functions.
*/
operator SIGACTION *();
private:
/// sigaction structure itself
SIGACTION m_sa;
};
//-------------------------------------------------------------------------
//------------------------Inline functions---------------------------------
//-------------------------------------------------------------------------
inline
SigAction::
SigAction ()
{
trace_with_mask("SigAction::SigAction", SIGACT);
m_sa.sa_flags = 0;
sigemptyset(&m_sa.sa_mask);
*(C_SIG_HANDLER*) &m_sa.sa_handler = (C_SIG_HANDLER) 0;
}
inline
SigAction::
SigAction (C_SIG_HANDLER handler_,
SigSet* sig_mask_,
int flags_)
{
trace_with_mask("SigAction::SigAction(,,)", SIGACT);
m_sa.sa_flags = flags_;
if (sig_mask_ == NULL) {
sigemptyset(&m_sa.sa_mask);
}
else {
/*---
here, suppose to do bitwise structure assignment,
but does it really do so?
= *sig_mask_
= *(sig_mask_.operator *())
= *(SigSet *tmp = &sig_mask_.m_sa) ????
---*/
m_sa.sa_mask = **sig_mask_;
}
*(C_SIG_HANDLER*) &m_sa.sa_handler = (C_SIG_HANDLER) handler_;
}
inline
SigAction::
SigAction (C_SIG_HANDLER handler_,
int signum_,
SigSet* sig_mask_,
int flags_)
{
trace_with_mask("SigAction::SigAction(,,,)", SIGACT);
m_sa.sa_flags = flags_;
if (sig_mask_ == NULL) {
sigemptyset(&m_sa.sa_mask);
}
else {
/*--- same problem as above... ---*/
m_sa.sa_mask = **sig_mask_;
}
*(C_SIG_HANDLER*) &m_sa.sa_handler = (C_SIG_HANDLER) handler_;
/*--- installing disposition... ---*/
sigaction (signum_, &m_sa, 0);
}
inline void
SigAction::
action (SIGACTION* sa_)
{
trace_with_mask("SigAction::action", SIGACT);
m_sa = *sa_;
}
inline SIGACTION *
SigAction::
action ()
{
trace_with_mask("SigAction::action", SIGACT);
return &m_sa;
}
inline void
SigAction::
flags (int new_flags_)
{
trace_with_mask("void SigAction::flags()", SIGACT);
m_sa.sa_flags = new_flags_;
}
inline int
SigAction::
flags ()
{
trace_with_mask("int SigAction::flags()", SIGACT);
return m_sa.sa_flags;
}
inline void
SigAction::
mask (SigSet & mask_set_)
{
trace_with_mask("void SigAction::mask()", SIGACT);
m_sa.sa_mask = *mask_set_;
}
inline SigSet
SigAction::
mask ()
{
trace_with_mask("SigSet SigAction::mask()", SIGACT);
SigSet tmpset(&m_sa.sa_mask);
return tmpset;
}
inline void
SigAction::
handler (C_SIG_HANDLER sha_)
{
trace_with_mask("void SigAction::handler()", SIGACT);
*(C_SIG_HANDLER*) &m_sa.sa_handler = (C_SIG_HANDLER) sha_;
}
inline C_SIG_HANDLER
SigAction::
handler ()
{
trace_with_mask("C_SIG_HANDLER SigAction::handler()", SIGACT);
return (C_SIG_HANDLER) m_sa.sa_handler;
}
inline
SigAction::operator SIGACTION * ()
{
trace_with_mask("SigAction::operator SIGACTION * ()", SIGACT);
return &m_sa;
}
inline int
SigAction::
register_action (int signum_, SigAction* oaction_)
{
trace_with_mask("SigAction::register_action()", SIGACT);
/*--- place here recursive mutex lock to guard ... ---*/
struct sigaction *osa = oaction_ == 0 ? 0 : oaction_->action();
return sigaction(signum_, &m_sa, osa);
}
inline int
SigAction::
restore_action (int signum_, SigAction& oaction_)
{
trace_with_mask("SigAction::restore_action()", SIGACT);
m_sa = *oaction_.action();
return sigaction(signum_, &m_sa, 0);
}
inline int
SigAction::
retrieve_action (int signum_)
{
trace_with_mask("SigAction::retrieve_action()", SIGACT);
return sigaction(signum_, 0, &m_sa);
}
#endif // !defined(WIN32)
} // end namespace ASSA
#endif /* _SigAction_h */
|