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 // 00028 // 00029 // an interface for I[NE]Fab data to Vince Beckner's ArrayView 00030 // 00031 #ifndef _EBARRAY_VIEW_CLIENT_H_ 00032 #define _EBARRAY_VIEW_CLIENT_H_ 00033 00034 #include "REAL.H" 00035 #include "LayoutData.H" 00036 #include "LevelData.H" 00037 #include "EBCellFAB.H" 00038 #include "EBFaceFAB.H" 00039 #include "BaseIFFAB.H" 00040 #include "BaseIVFAB.H" 00041 #include "EBArrayViewClient.H" 00042 00043 00044 extern "C" 00045 { 00047 00051 bool IFFABView(const BaseIFFAB<Real>* const fab); 00052 00054 00058 bool IVFABView(const BaseIVFAB<Real>* const fab); 00059 00060 00062 00066 bool EBCellFABView(const EBCellFAB* const fab); 00067 00069 00073 bool EBFaceFABView(const EBFaceFAB* const fab); 00074 bool IrregViewRealPtrArrayNVarDims(Real *data[], int nvar, 00075 const int *lodim, const int *hidim, 00076 const char *format, const char *label); 00077 00079 00083 bool MultiEBCellFABView(const LayoutData<EBCellFAB >* const fab); 00084 00086 00091 bool LDEBCellFABView(const LevelData<EBCellFAB >* const fab, 00092 const Box* const a_domainPtr); 00093 void makeFabFromEBFAB(BaseFab<Real>& fab,const EBCellFAB& ebfab); 00094 }; 00095 00096 #endif