tools/QtHelpers.hpp
Go to the documentation of this file.
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__ */
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Defines