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 / ConstNode.h < prev    next >
C/C++ Source or Header  |  1998-11-23  |  2KB  |  105 lines

  1. // $Id: ConstNode.h,v 1.11 1998/11/23 17:43:21 zeller Exp $
  2. // Constants
  3.  
  4. // Copyright (C) 1995 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_ConstNode_h
  30. #define _DDD_ConstNode_h
  31.  
  32. #ifdef __GNUG__
  33. #pragma interface
  34. #endif
  35.  
  36.  
  37. // A ConstNode returns a constant box upon run-time
  38.  
  39.  
  40. #include "assert.h"
  41. #include <iostream.h>
  42.  
  43. #include "VSLNode.h"
  44. #include "Box.h"
  45.  
  46. // ConstNode
  47.  
  48. class ConstNode: public VSLNode {
  49. public:
  50.     DECLARE_TYPE_INFO
  51.  
  52. private:
  53.     Box *_box;
  54.  
  55. protected:
  56.     ConstNode(const ConstNode& node):
  57.     VSLNode(node), _box(node._box->link())
  58.     {}
  59.     
  60.     void dump(ostream& s) const;
  61.     void _dumpTree(ostream& s) const;
  62.  
  63.     bool matches(const VSLNode& node) const
  64.     {
  65.     return VSLNode::matches(node) &&
  66.         *_box == *(((ConstNode *)&node)->_box); // dirty trick
  67.     }
  68.  
  69. private:
  70.     ConstNode& operator = (const ConstNode&)
  71.     {
  72.     assert(0); return *this;
  73.     }
  74.  
  75. public:
  76.     // Constructor
  77.     ConstNode(Box *box, char *type = "ConstNode"): 
  78.     VSLNode(type), _box(box)
  79.     {}
  80.  
  81.     // Destructor
  82.     ~ConstNode()
  83.     {
  84.     _box->unlink();
  85.     }
  86.  
  87.     // Copy
  88.     VSLNode *dup() const
  89.     {
  90.     return new ConstNode(*this);
  91.     }
  92.  
  93.     const Box *_eval(ListBox *arglist) const;
  94.  
  95.     bool isConst() const { return true; }
  96.     bool isConstNode() const { return true; }
  97.  
  98.     bool isStraight() const;
  99.  
  100.     // Representation invariant
  101.     bool OK() const;
  102. };
  103.  
  104. #endif
  105.