view src/uiguiIniFileParser.h @ 479:4f7041de0d0e

Replaced QSettings by UiguiIniFileParser to handle the uigui ini files. By this the indenter parameters no longer appear alphabetically ordered but in the same order as they occur in the uigui ini file. git-svn-id: svn://svn.code.sf.net/p/universalindent/code/trunk@719 59b1889a-e5ac-428c-b0c7-476e01d41282
author thomas_-_s <thomas_-_s@59b1889a-e5ac-428c-b0c7-476e01d41282>
date Fri, 06 Jun 2008 10:41:35 +0000
parents 5417f9e5f6e5
children
line wrap: on
line source

/***************************************************************************
 *   Copyright (C) 2006-2008 by Thomas Schweitzer                          *
 *   thomas-schweitzer(at)arcor.de                                         *
 *                                                                         *
 *   This program is free software; you can redistribute it and/or modify  *
 *   it under the terms of the GNU General Public License version 2.0 as   *
 *   published by the Free Software Foundation.                            *
 *                                                                         *
 *   This program is distributed in the hope that it will be useful,       *
 *   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
 *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         *
 *   GNU General Public License for more details.                          *
 *                                                                         *
 *   You should have received a copy of the GNU General Public License     *
 *   along with this program in the file LICENSE.GPL; if not, write to the *
 *   Free Software Foundation, Inc.,                                       *
 *   59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.             *
 ***************************************************************************/

#ifndef UIGUIINIFILEPARSER_H
#define UIGUIINIFILEPARSER_H

#include <QFile>
#include <QString>
#include <QMap>
#include <QVariant>
#include <QStringList>
#include <vector>

/*!
    \class UiguiIniFileParser
    \brief This class can be used to parse and access the contents of well formed ini files, but only readable.
 */

class UiguiIniFileParser
{
public:
    UiguiIniFileParser(void);
    UiguiIniFileParser(const QString &iniFileName);
    ~UiguiIniFileParser(void);
    QVariant value(const QString &keyName, const QString &defaultValue="");
    QStringList childGroups();

private:
    void parseIniFile();

    QString iniFileName;
    std::vector<QString> sections;
    QMap<QString, QVariant> keyValueMap;
};

#endif // UIGUIINIFILEPARSER_H