00001 /*========================================================================= 00002 Program: bbtk 00003 Module: $RCSfile: bbtkXML.h,v $ 00004 Language: C++ 00005 Date: $Date: 2010/01/14 13:17:27 $ 00006 Version: $Revision: 1.5 $ 00007 =========================================================================*/ 00008 00009 /* --------------------------------------------------------------------- 00010 00011 * Copyright (c) CREATIS-LRMN (Centre de Recherche en Imagerie Medicale) 00012 * Authors : Eduardo Davila, Laurent Guigues, Jean-Pierre Roux 00013 * 00014 * This software is governed by the CeCILL-B license under French law and 00015 * abiding by the rules of distribution of free software. You can use, 00016 * modify and/ or redistribute the software under the terms of the CeCILL-B 00017 * license as circulated by CEA, CNRS and INRIA at the following URL 00018 * http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html 00019 * or in the file LICENSE.txt. 00020 * 00021 * As a counterpart to the access to the source code and rights to copy, 00022 * modify and redistribute granted by the license, users are provided only 00023 * with a limited warranty and the software's author, the holder of the 00024 * economic rights, and the successive licensors have only limited 00025 * liability. 00026 * 00027 * The fact that you are presently reading this means that you have had 00028 * knowledge of the CeCILL-B license and that you accept its terms. 00029 * ------------------------------------------------------------------------ */ 00030 00031 #ifndef __bbtkXML_h_INCLUDED__ 00032 #define __bbtkXML_h_INCLUDED__ 00033 00034 #include "xmlParser.h" 00035 #include <sstream> 00036 00037 namespace bbtk 00038 { 00039 void CleanString_0D(std::string& var) 00040 { 00041 int i,size=var.length(); 00042 for (i=1 ; i<size ; i++ ) 00043 { 00044 if ((var[i-1]==13) && (var[i]==10) ) 00045 { 00046 var[i-1]=32; // space 00047 } //if 00048 } // for 00049 } 00050 00051 //==================================================================== 00052 inline bool GetTextOrClear(const XMLNode& node, std::string& var) 00053 { 00054 if (node.nText()>0) 00055 { 00056 var = node.getText(); 00057 CleanString_0D(var); 00058 return true; 00059 } 00060 else if (node.nClear()>0) 00061 { 00062 var = node.getClear().lpszValue; 00063 CleanString_0D(var); 00064 return true; 00065 } 00066 else 00067 { 00068 return false; 00069 } 00070 } 00071 //==================================================================== 00072 00073 std::string GetErrorMessage(XMLResults* res, const std::string& filename) 00074 { 00075 std::ostringstream str; 00076 str << XMLNode::getError(res->error); 00077 str << " [line " << res->nLine << ", col "<<res->nColumn<<"] "; 00078 str << " file "<<filename; 00079 return str.str(); 00080 } 00081 }; 00082 00083 #endif