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

  1. // $Id: BoxRegion.C,v 1.9 1998/11/23 17:43:17 zeller Exp $  -*- C++ -*-
  2. // BoxRegion 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. char BoxRegion_rcsid[] = 
  30.     "$Id: BoxRegion.C,v 1.9 1998/11/23 17:43:17 zeller Exp $";
  31.  
  32. #ifdef __GNUG__
  33. #pragma implementation
  34. #endif
  35.  
  36. #include "BoxRegion.h"
  37.  
  38. // Compute intersection of two regions
  39. BoxRegion BoxRegion::operator & (const BoxRegion& r) const
  40. {
  41.     if (!origin().isValid())
  42.     return r;
  43.     if (!r.origin().isValid())
  44.     return *this;
  45.  
  46.     BoxPoint nw_corner(max(origin(X), r.origin(X)),
  47.             max(origin(Y), r.origin(Y)));
  48.     BoxPoint se_corner(min(origin(X) + space(X), r.origin(X) + r.space(X)),
  49.             min(origin(Y) + space(Y), r.origin(Y) + r.space(Y)));
  50.  
  51.     return BoxRegion(nw_corner, BoxSize(se_corner - nw_corner));
  52. }
  53.  
  54. // Compute union of two regions
  55. BoxRegion BoxRegion::operator | (const BoxRegion& r) const
  56. {
  57.     if (!origin().isValid())
  58.     return r;
  59.     if (!r.origin().isValid())
  60.     return *this;
  61.  
  62.     BoxPoint nw_corner(min(origin(X), r.origin(X)),
  63.             min(origin(Y), r.origin(Y)));
  64.     BoxPoint se_corner(max(origin(X) + space(X), r.origin(X) + r.space(X)),
  65.             max(origin(Y) + space(Y), r.origin(Y) + r.space(Y)));
  66.  
  67.     return BoxRegion(nw_corner, BoxSize(se_corner - nw_corner));
  68. }
  69.  
  70. // Dump
  71. ostream& operator << (ostream& s, const BoxRegion& r)
  72. {
  73.     return s << r.origin() << r.space();
  74. }
  75.