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 / DispBuffer.h < prev    next >
C/C++ Source or Header  |  1998-12-06  |  3KB  |  88 lines

  1. // $Id: DispBuffer.h,v 1.8.6.1 1998/12/06 12:59:18 zeller Exp $
  2. // Filter display information from GDB output
  3.  
  4. // Copyright (C) 1995 Technische Universitaet Braunschweig, Germany.
  5. // Written by Dorothea Luetkehaus <luetke@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_DispBuffer_h
  30. #define _DDD_DispBuffer_h
  31.  
  32. #ifdef __GNUG__
  33. #pragma interface
  34. #endif
  35.  
  36. //-----------------------------------------------------------------------------
  37. // A `DispBuffer' filters display information from GDB output
  38. //-----------------------------------------------------------------------------
  39.  
  40. // Misc includes
  41. #include "bool.h"
  42. #include "strclass.h"
  43.  
  44. class DispBuffer {
  45.     // What was in the previous answer?
  46.     enum ReadState {Null, DisplayPart, DisplayFound};
  47.     
  48.     string display_buffer;
  49.     string answer_buffer;      // possible parts of display output
  50.     ReadState already_read;
  51.  
  52. public:
  53.     // Constructor
  54.     DispBuffer () :
  55.     display_buffer(""),
  56.     answer_buffer(""),
  57.     already_read(Null)
  58.     {}
  59.  
  60.     // Filter `display' output from ANSWER and buffer them.
  61.     // After returning, ANSWER contains non-display output.
  62.     void filter (string& answer);
  63.  
  64.     // The answer has ended; return buffered output.
  65.     string answer_ended ();
  66.  
  67.     // Were there any displays in the last output?
  68.     bool displays_found () const { return display_buffer != ""; }
  69.     bool partial_displays_found () const
  70.     {
  71.     return !displays_found() && already_read == DisplayPart;
  72.     }
  73.  
  74.     // Return any displays found
  75.     string get_displays () const { return display_buffer; }
  76.  
  77.     // Call before filtering next answer
  78.     void clear () {
  79.     display_buffer = "";
  80.     answer_buffer = "";
  81.     already_read = Null;
  82.     }
  83.  
  84. };
  85.  
  86. #endif // _DDD_DispBuffer_h
  87. // DON'T ADD ANYTHING BEHIND THIS #endif
  88.