00001 /*========================================================================= 00002 Program: bbtk 00003 Module: $RCSfile: bbtkXML.h,v $ 00004 Language: C++ 00005 Date: $Date: 2008/10/17 08:18:15 $ 00006 Version: $Revision: 1.4 $ 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 00032 #ifndef __bbtkXML_h_INCLUDED__ 00033 #define __bbtkXML_h_INCLUDED__ 00034 00035 #include "xmlParser.h" 00036 #include <sstream> 00037 00038 namespace bbtk 00039 { 00040 00041 void CleanString_0D(std::string& var) 00042 { 00043 int i,size=var.length(); 00044 for (i=1 ; i<size ; i++ ) 00045 { 00046 if ((var[i-1]==13) && (var[i]==10) ) 00047 { 00048 var[i-1]=32; // space 00049 } //if 00050 } // for 00051 } 00052 00053 //==================================================================== 00054 inline bool GetTextOrClear(const XMLNode& node, std::string& var) 00055 { 00056 if (node.nText()>0) 00057 { 00058 var = node.getText(); 00059 CleanString_0D(var); 00060 return true; 00061 } 00062 else if (node.nClear()>0) 00063 { 00064 var = node.getClear().lpszValue; 00065 CleanString_0D(var); 00066 return true; 00067 } 00068 else 00069 { 00070 return false; 00071 } 00072 } 00073 //==================================================================== 00074 00075 00076 std::string GetErrorMessage(XMLResults* res, const std::string& filename) 00077 { 00078 std::ostringstream str; 00079 str << XMLNode::getError(res->error); 00080 str << " [line " << res->nLine << ", col "<<res->nColumn<<"] "; 00081 str << " file "<<filename; 00082 return str.str(); 00083 } 00084 00085 }; 00086 00087 #endif