home *** CD-ROM | disk | FTP | other *** search
/ PC World Komputer 1999 mARCH / PCWK3A99.iso / Linux / DDD331 / DDD-3_1_.000 / DDD-3_1_ / ddd-3.1.1 / ddd / SignalB.h < prev    next >
C/C++ Source or Header  |  1998-03-25  |  3KB  |  96 lines

  1. // $Id: SignalB.h,v 1.13 1998/03/25 12:44:12 zeller Exp $ -*- C++ -*-
  2. // Block signals for the lifetime of this object (protect critical sections)
  3.  
  4. // Copyright (C) 1996 Technische Universitaet Braunschweig, Germany.
  5. // Written by Andreas Zeller <zeller@ips.cs.tu-bs.de>.
  6. // 
  7. // This file is part of DDD.
  8. // 
  9. // DDD is free software; you can redistribute it and/or
  10. // modify it under the terms of the GNU General Public
  11. // License as published by the Free Software Foundation; either
  12. // version 2 of the License, or (at your option) any later version.
  13. // 
  14. // DDD is distributed in the hope that it will be useful,
  15. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  16. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  17. // See the GNU General Public License for more details.
  18. // 
  19. // You should have received a copy of the GNU General Public
  20. // License along with DDD -- see the file COPYING.
  21. // If not, write to the Free Software Foundation, Inc.,
  22. // 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
  23. // 
  24. // DDD is the data display debugger.
  25. // For details, see the DDD World-Wide-Web page, 
  26. // `http://www.cs.tu-bs.de/softech/ddd/',
  27. // or send a mail to the DDD developers <ddd@ips.cs.tu-bs.de>.
  28.  
  29. #ifndef _DDD_SignalBlocker_h
  30. #define _DDD_SignalBlocker_h
  31.  
  32. #ifdef __GNUG__
  33. #pragma interface
  34. #endif
  35.  
  36. #include <sys/types.h>
  37. #include <signal.h>
  38. #include "assert.h"
  39.  
  40. // A SignalBlocker is used to protect critical sections:
  41. // 
  42. // {
  43. //     SignalBlocker sb(<signal name>);
  44. //     ... critical section protected against <signal name>...
  45. // }
  46. //
  47. // For instance, to protect a critical section against SIGCHLD signals,
  48. // you would write:
  49. // 
  50. // {
  51. //     SignalBlocker sb(SIGCHLD);
  52. //     ... critical section ...
  53. // }
  54. //
  55. // A SignalBlocker without arguments blocks all signals.
  56.  
  57. class SignalBlocker {
  58. private:
  59. #ifdef SIG_SETMASK
  60.     sigset_t old_set;        // POSIX interface
  61. #else
  62.     int old_mask;               // BSD interface
  63. #endif
  64.  
  65.     // No assignments and copies
  66.     SignalBlocker& operator = (const SignalBlocker&) 
  67.     {
  68.     assert(0);
  69.     return *this;
  70.     }
  71.  
  72.     SignalBlocker(const SignalBlocker& sb) 
  73.     :
  74. #ifdef SIG_SETMASK
  75.     old_set(sb.old_set)
  76. #else
  77.     old_mask(sb.old_mask)
  78. #endif
  79.      {
  80.      assert(0);
  81.      }
  82.  
  83. public:
  84.     // Constructor - block signal SIGNUM
  85.     SignalBlocker(int signum);
  86.  
  87.     // Constructor - block all signals
  88.     SignalBlocker();
  89.  
  90.     // Destructor - restore state
  91.     ~SignalBlocker();
  92. };
  93.   
  94. #endif // _DDD_SignalBlocker_h
  95. // DON'T ADD ANYTHING BEHIND THIS #endif
  96.