Home | nevrax.com |
|
retriever_bank.cppGo to the documentation of this file.00001 00007 /* Copyright, 2001 Nevrax Ltd. 00008 * 00009 * This file is part of NEVRAX NEL. 00010 * NEVRAX NEL is free software; you can redistribute it and/or modify 00011 * it under the terms of the GNU General Public License as published by 00012 * the Free Software Foundation; either version 2, or (at your option) 00013 * any later version. 00014 00015 * NEVRAX NEL is distributed in the hope that it will be useful, but 00016 * WITHOUT ANY WARRANTY; without even the implied warranty of 00017 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00018 * General Public License for more details. 00019 00020 * You should have received a copy of the GNU General Public License 00021 * along with NEVRAX NEL; see the file COPYING. If not, write to the 00022 * Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, 00023 * MA 02111-1307, USA. 00024 */ 00025 00026 #include "stdpacs.h" 00027 00028 #include "nel/misc/file.h" 00029 #include "nel/misc/path.h" 00030 00031 #include "pacs/retriever_bank.h" 00032 00033 using namespace std; 00034 using namespace NLMISC; 00035 00036 // CRetrieverBank methods implementation 00037 00038 NLPACS::URetrieverBank *NLPACS::URetrieverBank::createRetrieverBank (const char *retrieverBank) 00039 { 00040 NL_ALLOC_CONTEXT( Pacs ) 00041 00042 CIFile file; 00043 if (file.open( CPath::lookup(retrieverBank) )) 00044 { 00045 CRetrieverBank *bank = new CRetrieverBank(); 00046 file.serial(*bank); 00047 00048 return static_cast<URetrieverBank *>(bank); 00049 } 00050 else 00051 return NULL; 00052 } 00053 00054 00055 void NLPACS::URetrieverBank::deleteRetrieverBank (NLPACS::URetrieverBank *retrieverBank) 00056 { 00057 // Cast 00058 // nlassert (dynamic_cast<NLPACS::CRetrieverBank*>(retrieverBank)); 00059 NLPACS::CRetrieverBank* r=static_cast<NLPACS::CRetrieverBank*>(retrieverBank); 00060 00061 // Delete 00062 delete r; 00063 } 00064 00065 void NLPACS::CRetrieverBank::clean() 00066 { 00067 uint i; 00068 for (i=0; i<_Retrievers.size(); ++i) 00069 { 00070 _Retrievers[i].flushFullOrderedChains(); 00071 } 00072 } 00073 00074 // end of CRetrieverBank methods implementation |