00001 /* 00002 00003 This file is part of OpenFLUID software 00004 Copyright(c) 2007, INRA - Montpellier SupAgro 00005 00006 00007 == GNU General Public License Usage == 00008 00009 OpenFLUID is free software: you can redistribute it and/or modify 00010 it under the terms of the GNU General Public License as published by 00011 the Free Software Foundation, either version 3 of the License, or 00012 (at your option) any later version. 00013 00014 OpenFLUID is distributed in the hope that it will be useful, 00015 but WITHOUT ANY WARRANTY; without even the implied warranty of 00016 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00017 GNU General Public License for more details. 00018 00019 You should have received a copy of the GNU General Public License 00020 along with OpenFLUID. If not, see <http://www.gnu.org/licenses/>. 00021 00022 00023 == Other Usage == 00024 00025 Other Usage means a use of OpenFLUID that is inconsistent with the GPL 00026 license, and requires a written agreement between You and INRA. 00027 Licensees for Other Usage of OpenFLUID may use this file in accordance 00028 with the terms contained in the written agreement between You and INRA. 00029 00030 */ 00031 00032 00033 /** 00034 \file QtHelpers.hpp 00035 \brief Header of ... 00036 00037 \author Jean-Christophe FABRE <fabrejc@supagro.inra.fr> 00038 */ 00039 00040 00041 #ifndef __QTHELPERS_HPP__ 00042 #define __QTHELPERS_HPP__ 00043 00044 00045 #include <openfluid/tools/GDALHelpers.hpp> 00046 00047 #include <list> 00048 00049 #include <QVariant> 00050 #include <QString> 00051 #include <QStringList> 00052 00053 #include <openfluid/dllexport.hpp> 00054 00055 namespace openfluid { namespace tools { 00056 00057 /** 00058 Transforms the given string to a string compatible with the INI files managed with QSettings. 00059 @param[in] Str the string to transform 00060 @return The transformed string 00061 */ 00062 QString DLLEXPORT toIniCompatible(const std::string& Str); 00063 00064 00065 /** 00066 Transforms the given variable from an INI file managed with QSettings to a string 00067 @param[in] Var the variable to transform 00068 @return The variable transformed into a string 00069 */ 00070 std::string DLLEXPORT fromIniCompatible(const QVariant& Var); 00071 00072 00073 /** 00074 Transforms a QStringList into a std::list of std::string 00075 @param[in] StrList the QStringList to transform 00076 @return The QStringList transformed into a std::list of std::string 00077 */ 00078 std::list<std::string> DLLEXPORT toStdStringList(const QStringList& StrList); 00079 00080 00081 /** 00082 Returns the available GDAL/OGR formats as a QFileDialog formats string. 00083 The string is built according to GDAL/OGR available drivers. 00084 The OGRRegisterAll() and/or GDALAllRegister() instruction must be called before using this function. 00085 @param[in] Drivers The available extensions list 00086 @param[in] AllFormatsLabel the label displayed for all formats 00087 @return the format string (e.g. "All vector files (*.shp *.mif *.tab);;ESRI Shapefiles (*.shp);;Mapinfo (*.mif *.tab)") 00088 */ 00089 QString DLLEXPORT getOGRGDALFormatsForQFileDialogs(const GDALDriversFilesExts_t& Drivers, 00090 const QString& AllFormatsLabel); 00091 00092 /** 00093 Escapes characters in the given string to be compatible with the XML format. 00094 @param[in] Str the string to escape 00095 @return The escaped string 00096 */ 00097 QString DLLEXPORT escapeXMLEntities(const QString& Str); 00098 00099 00100 } } // namespaces 00101 00102 00103 #endif /* __QTHELPERS_HPP__ */