00001 /* _______ __ 00002 / ___/ / ___ __ _ / / ___ 00003 / /__/ _ \/ _ \/ ' \/ _ \/ _ \ 00004 \___/_//_/\___/_/_/_/_.__/\___/ 00005 */ 00006 // 00007 // This software is copyright (C) by the Lawrence Berkeley 00008 // National Laboratory. Permission is granted to reproduce 00009 // this software for non-commercial purposes provided that 00010 // this notice is left intact. 00011 // 00012 // It is acknowledged that the U.S. Government has rights to 00013 // this software under Contract DE-AC03-765F00098 between 00014 // the U.S. Department of Energy and the University of 00015 // California. 00016 // 00017 // This software is provided as a professional and academic 00018 // contribution for joint exchange. Thus it is experimental, 00019 // is provided ``as is'', with no warranties of any kind 00020 // whatsoever, no support, no promise of updates, or printed 00021 // documentation. By using this software, you acknowledge 00022 // that the Lawrence Berkeley National Laboratory and 00023 // Regents of the University of California shall have no 00024 // liability with respect to the infringement of other 00025 // copyrights by any part of this software. 00026 // 00027 // DTGraves 00028 00029 #ifndef _BOX_ITERATOR_H_ 00030 #define _BOX_ITERATOR_H_ 00031 00032 #include <cstdlib> 00033 00034 #include "Box.H" 00035 #include "REAL.H" 00036 #include "SPACE.H" 00037 #include "Tuple.H" 00038 #include "IntVect.H" 00039 00041 00057 class BoxIterator 00058 { 00059 public: 00060 00062 00064 00068 BoxIterator (); 00069 00071 00079 BoxIterator(const Box& bx); 00080 00081 void setBox(const Box& bx); 00082 00084 00092 void define (const Box& bx); 00093 00095 00103 BoxIterator (const BoxIterator& tx); 00104 00106 00109 ~BoxIterator (); 00110 00112 00114 00123 void begin(); 00124 00126 00135 void reset(); 00136 00138 00147 void operator++(); 00148 00149 void next(); 00150 00151 00152 00154 00156 00164 const IntVect& operator() () const; 00165 00167 00175 bool ok(); 00176 00177 protected: 00178 00179 IntVect m_current; 00180 IntVect m_boxLo; 00181 IntVect m_boxHi; 00182 }; 00183 00184 #endif