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 / UndoBE.C < prev    next >
C/C++ Source or Header  |  1998-11-17  |  2KB  |  83 lines

  1. // $Id: UndoBE.C,v 1.7 1998/11/17 10:05:34 zeller Exp $ -*- C++ -*-
  2. // Undo Buffer Entry
  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. char UndoBufferEntry_rcsid[] = 
  30.     "$Id: UndoBE.C,v 1.7 1998/11/17 10:05:34 zeller Exp $";
  31.  
  32. #ifdef __GNUG__
  33. #pragma implementation
  34. #pragma implementation "DynArray.h"
  35. #pragma implementation "VarArray.h"
  36. #endif
  37.  
  38. #include "UndoBE.h"
  39.  
  40. bool UndoBufferEntry::operator == (const UndoBufferEntry& entry) const
  41. {
  42.     if (&entry == this)
  43.     return true;
  44.  
  45.     StringStringAssocIter iter1(*this);
  46.     StringStringAssocIter iter2(entry);
  47.  
  48.     // This assumes both Assocs have the same ordering.
  49.     while (iter1.ok() && iter2.ok())
  50.     {
  51.     if (iter1.key() != iter2.key())
  52.         return false;    // Differing keys
  53.     if (iter1.value() != iter2.value())
  54.         return false;    // Differing values
  55.  
  56.     iter1++;
  57.     iter2++;
  58.     }
  59.  
  60.     if (iter1.ok())
  61.     return false;        // Still keys/values in THIS
  62.     if (iter2.ok())
  63.     return false;        // Still keys/values in ENTRY
  64.  
  65.     return true;
  66. }
  67.  
  68. int UndoBufferEntry::allocation() const
  69. {
  70.     StringStringAssocIter iter(*this);
  71.     int alloc = sizeof(*this);
  72.  
  73.     while (iter.ok())
  74.     {
  75.     alloc += iter.key().allocation();
  76.     alloc += iter.value().allocation();
  77.  
  78.     iter++;
  79.     }
  80.  
  81.     return alloc;
  82. }
  83.