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 / HintGraphN.h < prev    next >
C/C++ Source or Header  |  1998-08-27  |  2KB  |  94 lines

  1. // $Id: HintGraphN.h,v 1.13 1998/08/27 19:46:40 zeller Exp $  -*- C++ -*-
  2. // HintGraphNode class
  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_HintGraphNode_h
  30. #define _DDD_HintGraphNode_h
  31.  
  32. #ifdef __GNUG__
  33. #pragma interface
  34. #endif
  35.  
  36. #include "RegionGN.h"
  37.  
  38. class HintGraphNode: public RegionGraphNode {
  39. public:
  40.     DECLARE_TYPE_INFO
  41.  
  42. protected:
  43.     virtual void forceDraw(Widget w, 
  44.                const BoxRegion& exposed,
  45.                const GraphGC& gc) const;
  46.  
  47.     // Copy Constructor
  48.     HintGraphNode(const HintGraphNode &node):
  49.     RegionGraphNode(node)
  50.     {}
  51.  
  52. public:
  53.     // Constructor
  54.     HintGraphNode(const BoxPoint& initialPos = BoxPoint()):
  55.        RegionGraphNode(initialPos, BoxSize(0,0))
  56.     {}
  57.  
  58.     // Destructor
  59.     virtual ~HintGraphNode() {}
  60.  
  61.     GraphNode *dup() const
  62.     {
  63.     return new HintGraphNode(*this);
  64.     }
  65.  
  66.     virtual bool isHint() const { return true; }
  67.  
  68.     virtual const BoxRegion& region(const GraphGC& gc) const
  69.     {
  70.     if (gc.drawHints)
  71.         return sensitiveRegion(gc);
  72.     else
  73.         return RegionGraphNode::region(gc);
  74.     }
  75.  
  76.     virtual const BoxRegion& sensitiveRegion(const GraphGC& gc) const
  77.     {
  78.     static BoxRegion r;
  79.  
  80.     // return a size-pixel area around the current position
  81.     r = BoxRegion(pos() - gc.hintSize / 2, gc.hintSize);
  82.     return r;
  83.     }
  84.  
  85.     // Print
  86.     virtual void _print(ostream&, const GraphGC&) const 
  87.     {
  88.     // Do nothing
  89.     }
  90. };
  91.  
  92. #endif // _DDD_HintGraphNode_h
  93. // DON'T ADD ANYTHING BEHIND THIS #endif
  94.