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 /***************/ 00030 template <class T> inline 00031 BaseIFFactory<T>::~BaseIFFactory() 00032 { 00033 } 00034 /***************/ 00035 /***************/ 00036 template <class T> inline 00037 BaseIFFactory<T>::BaseIFFactory(const EBISLayout& a_ebisl, 00038 const LayoutData<IntVectSet>& a_sets, 00039 const int& a_facedir) 00040 { 00041 m_ebisl = a_ebisl; 00042 m_facedir = a_facedir; 00043 m_sets.define(a_sets.boxLayout()); 00044 for(DataIterator dit = m_sets.dataIterator(); dit.ok(); ++dit) 00045 { 00046 m_sets[dit()] = a_sets[dit()]; 00047 } 00048 } 00049 /***************/ 00050 /***************/ 00051 template <class T> inline 00052 BaseIFFAB<T>* 00053 BaseIFFactory<T>::create(const Box& a_box, int a_ncomps, 00054 const DataIndex& a_dit) const 00055 { 00056 //intersects with input box because leveldata will expect 00057 //that anyway when it tries to do a copy or a linearization. 00058 IntVectSet ivsInter = m_sets[a_dit]; 00059 ivsInter &= a_box; 00060 return new BaseIFFAB<T>(ivsInter, m_ebisl[a_dit].getEBGraph(), m_facedir, a_ncomps); 00061 } 00062 /***************/ 00063 /***************/