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 / TimeOut.h < prev    next >
C/C++ Source or Header  |  1998-03-25  |  2KB  |  72 lines

  1. // $Id: TimeOut.h,v 1.4 1998/03/25 12:44:42 zeller Exp $ -*- C++ -*-
  2. // Xt TimeOut debugging routines
  3.  
  4. // Copyright (C) 1997 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_TimeOut_h
  30. #define _DDD_TimeOut_h
  31.  
  32. #ifdef __GNUG__
  33. #pragma interface
  34. #endif
  35.  
  36. #include <X11/Intrinsic.h>
  37.  
  38. // Like XtAppAddTimeOut(), but also register timer in internal list.
  39. extern XtIntervalId MyAppAddTimeOut(XtAppContext app_context,
  40.                     unsigned long interval,
  41.                     XtTimerCallbackProc proc,
  42.                     XtPointer closure,
  43.                     String file = 0,
  44.                     int line = 0);
  45.  
  46. // Like XtRemoveTimeOut(), but unregister TIMER from internal list. 
  47. // Trigger an error if TIMER is not found (i.e. expired or removed)
  48. extern void MyRemoveTimeOut(XtIntervalId timer,
  49.                 String file = 0,
  50.                 int line = 0);
  51.  
  52. // Be sure not to intermix these!  A timer added with MyAppAddTimeOut()
  53. // must be removed with MyRemoveTimeOut(); a timer added with
  54. // XtAppAddTimeOut() must be removed with XtRemoveTimeOut().
  55.  
  56. // Unless NDEBUG is defined (as usually in optimization), use our
  57. // replacement routines instead of the Xt functions.
  58. #if !defined(NDEBUG)
  59. #define XtAppAddTimeOut(a, i, p, c) \
  60.     MyAppAddTimeOut((a), (i), (p), (c), __FILE__, __LINE__)
  61. #define XtRemoveTimeOut(timer) \
  62.     MyRemoveTimeOut((timer), __FILE__, __LINE__)
  63. #endif // !defined(NDEBUG)
  64.  
  65. // Diagnostics
  66.  
  67. // Return number of pending timers
  68. extern int MyPendingTimeOuts();
  69.  
  70. #endif // _DDD_TimeOut_h
  71. // DON'T ADD ANYTHING BEHIND THIS #endif
  72.