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 // ANAG, LBNL 00028 00029 #ifndef _CoveredFaceIterator_H_ 00030 #define _CoveredFaceIterator_H_ 00031 00032 #include "IntVect.H" 00033 #include "VolIndex.H" 00034 #include "IntVectSet.H" 00035 #include "EBISBox.H" 00036 #include "Vector.H" 00037 #include "LoHiSide.H" 00038 00040 00043 class CoveredFaceIterator 00044 { 00045 public: 00047 CoveredFaceIterator(const IntVectSet& a_ivs, 00048 const EBISBox& a_ebisBox, 00049 int a_dir, Side::LoHiSide a_side); 00050 00052 CoveredFaceIterator(); 00053 00055 ~CoveredFaceIterator(); 00056 00058 void define(const IntVectSet& a_ivs, 00059 const EBISBox& a_ebisBox, 00060 int a_dir, Side::LoHiSide a_side); 00061 00063 void reset(); 00064 00066 void operator++(); 00067 00069 const VolIndex& operator() () const; 00070 00072 bool ok() const; 00073 00075 bool isDefined() const; 00076 00077 private: 00078 CoveredFaceIterator(const CoveredFaceIterator& a_input) 00079 { 00080 MayDay::Error("Invalid Operator"); 00081 } 00082 void 00083 operator= (const CoveredFaceIterator& a_input) 00084 { 00085 MayDay::Error("Invalid Operator"); 00086 } 00087 Vector<VolIndex> m_vols; 00088 int m_ivol; 00089 00090 bool m_isDefined; 00091 }; 00092 00093 #endif 00094