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 _EBFaceFAB_H_ 00030 #define _EBFaceFAB_H_ 00031 00032 #include <cmath> 00033 #include <cstdlib> 00034 #include <cassert> 00035 #include "BaseEBFaceFAB.H" 00036 #include "FArrayBox.H" 00037 00039 00043 class EBFaceFAB: public BaseEBFaceFAB<Real> 00044 { 00045 public: 00047 EBFaceFAB(); 00048 00049 00051 00055 EBFaceFAB(const EBISBox& a_ebisBox, 00056 const Box& a_region, 00057 int a_iDir, int a_nVar); 00058 00059 00061 virtual ~EBFaceFAB(); 00062 00063 00065 const FArrayBox& getFArrayBox() const; 00066 00068 00072 FArrayBox& getFArrayBox(); 00073 00075 00078 EBFaceFAB& operator+=(const EBFaceFAB& a_ebfab); 00079 00081 00084 EBFaceFAB& operator-=(const EBFaceFAB& a_ebfab); 00085 00087 00090 EBFaceFAB& operator*=(const EBFaceFAB& a_ebfab); 00091 00093 00096 EBFaceFAB& operator/=(const EBFaceFAB& a_ebfab); 00097 00099 00102 EBFaceFAB& operator+=(const Real& a_scalar); 00103 00105 00108 EBFaceFAB& operator-=(const Real& a_scalar); 00109 00111 00114 EBFaceFAB& operator*=(const Real& a_scalar); 00115 00117 00120 EBFaceFAB& operator/=(const Real& a_scalar); 00121 00122 //needed for leveldata to compile but invalid 00123 EBFaceFAB(const Box& a_region, int a_nComp) 00124 { 00125 MayDay::Error("bogus constructor"); 00126 } 00127 private: 00128 //verboten for all the usual reasons 00129 EBFaceFAB(const EBFaceFAB& ebcin) 00130 { 00131 MayDay::Error("bogus constructor"); 00132 } 00133 void operator=(const EBFaceFAB& ebcin) 00134 { 00135 MayDay::Error("bogus constructor"); 00136 } 00137 00138 }; 00139 #endif 00140