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 / ProgressM.h < prev    next >
C/C++ Source or Header  |  1998-09-21  |  3KB  |  99 lines

  1. // $Id: ProgressM.h,v 1.1 1998/09/21 13:33:36 zeller Exp $ -*- C++ -*-
  2. // Data Display progress meter
  3.  
  4. // Copyright (C) 1998 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_ProgressMeter_h
  30. #define _DDD_ProgressMeter_h
  31.  
  32. #ifdef __GNUG__
  33. #pragma interface
  34. #endif
  35.  
  36. #include "bool.h"
  37. #include "strclass.h"
  38. #include "status.h"
  39.  
  40. #include <X11/Intrinsic.h>
  41.  
  42.  
  43. //-----------------------------------------------------------------------------
  44. // Show progress while creating or updating displays
  45. //-----------------------------------------------------------------------------
  46.  
  47. class ProgressMeter {
  48. public:
  49.     int current;        // Current data to be processed
  50.     int base;            // Data already processed
  51.     int total;            // Total of data to be processed
  52.  
  53.     ProgressMeter(const string& msg);
  54.     ~ProgressMeter();
  55.  
  56. private:
  57.     string msg;            // The message shown
  58.     StatusDelay delay;        // The delay shown
  59.     int last_shown;        // Last shown amount
  60.     bool (*old_background)(int); // DispValue bg proc
  61.     bool aborted;        // True iff bg proc aborted
  62.  
  63.     // Update progess meter every UPDATE_THRESHOLD characters.
  64.     static const int UPDATE_THRESHOLD;
  65.  
  66.     // Popup working dialog when updating from at least DIALOG_THRESHOLD chars.
  67.     static const int DIALOG_THRESHOLD;
  68.  
  69.     static Widget dialog;
  70.     static Widget scale;
  71.  
  72.     bool process(int remaining_length);
  73.  
  74.     static ProgressMeter *active; // Currently active object
  75.     static bool _process(int remaining_length);
  76.  
  77.     static void CancelCB(Widget, XtPointer, XtPointer);
  78.  
  79. private:
  80.     // No copy constructor
  81.     ProgressMeter(const ProgressMeter &)
  82.     : current(0), base(0), total(0), msg(),
  83.       delay(""), last_shown(0),
  84.       old_background(0),
  85.       aborted(false)
  86.     {
  87.     assert(0);
  88.     }
  89.  
  90.     // No assignment
  91.     ProgressMeter& operator = (const ProgressMeter &)
  92.     {
  93.     assert(0); return *this;
  94.     }
  95. };
  96.  
  97. #endif // _DDD_ProgressMeter_h
  98. // DON'T ADD ANYTHING BEHIND THIS #endif
  99.