00001 // This file is part of ff3d - http://www.freefem.org/ff3d 00002 // Copyright (C) 2001, 2002, 2003 Stéphane Del Pino 00003 00004 // This program is free software; you can redistribute it and/or modify 00005 // it under the terms of the GNU General Public License as published by 00006 // the Free Software Foundation; either version 2, or (at your option) 00007 // any later version. 00008 00009 // This program is distributed in the hope that it will be useful, 00010 // but WITHOUT ANY WARRANTY; without even the implied warranty of 00011 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00012 // GNU General Public License for more details. 00013 00014 // You should have received a copy of the GNU General Public License 00015 // along with this program; if not, write to the Free Software Foundation, 00016 // Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. 00017 00018 // $Id: Union.hpp,v 1.5 2006/10/01 23:25:58 delpinux Exp $ 00019 00020 #ifndef UNION_HPP 00021 #define UNION_HPP 00022 00023 #include <Object.hpp> 00024 #include <list> 00025 00034 class Union 00035 : public Shape 00036 { 00037 private: 00038 typedef std::list<ConstReferenceCounting<Object> > ObjectList; 00039 00040 public: 00041 typedef std::list<ConstReferenceCounting<Object> >::iterator iterator; 00042 typedef std::list<ConstReferenceCounting<Object> >::const_iterator const_iterator; 00043 00044 private: 00045 ObjectList __objects; 00047 protected: 00055 inline bool __inShape (const TinyVector<3, real_t>& x) const 00056 { 00057 for (Union::const_iterator i=__objects.begin(); 00058 i != __objects.end(); ++i) { 00059 if((*i)->inside(x)) { 00060 return true; 00061 } 00062 } 00063 return false; 00064 } 00065 00073 std::ostream& __put(std::ostream& os) const; 00074 00080 ReferenceCounting<Shape> __getCopy() const; 00081 00082 public: 00083 const_iterator begin() const 00084 { 00085 return __objects.begin(); 00086 } 00087 00088 iterator begin() 00089 { 00090 return __objects.begin(); 00091 } 00092 00093 const_iterator end() const 00094 { 00095 return __objects.end(); 00096 } 00097 00098 iterator end() 00099 { 00100 return __objects.end(); 00101 } 00102 00108 void push_back(ConstReferenceCounting<Object> O) 00109 { 00110 __objects.push_back(O); 00111 } 00112 00117 Union(); 00118 00124 Union(const Union& U); 00125 00130 ~Union() 00131 { 00132 ; 00133 } 00134 }; 00135 00136 #endif // UNION_HPP
1.5.6