Use 'record' in debug messages instead of 'commit'. Make record also work when the...
[vng.git] / Configuration.h
blob3430458562f0909e94deb96f007e5f0a7946df53
1 /*
2 * This file is part of the vng project
3 * Copyright (C) 2008 Thomas Zander <tzander@trolltech.com>
5 * This program is free software: you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation, either version 3 of the License, or
8 * (at your option) any later version.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License
16 * along with this program. If not, see <http://www.gnu.org/licenses/>.
18 #ifndef CONFIGURATION_H
19 #define CONFIGURATION_H
21 #include <QString>
22 #include <QDir>
23 #include <QHash>
24 #include <QTextStream>
26 #include "commits/Branch.h"
28 class Configuration {
29 public:
30 Configuration(const QString &section);
32 bool contains(const QString & key) const;
33 QString optionArgument(const QString &optionName, const QString &defaultValue = QString()) const;
35 /// return the base directory of this repository.
36 QDir repository() const;
37 /// returns the directory where the database and other meta data is stored.
38 QDir repositoryMetaDir() const;
40 bool colorTerm() const;
42 inline void colorize(QTextStream &stream) const {
43 if (colorTerm())
44 stream << QChar(27) << '[' << 34 << 'm'; // to blue
47 inline void colorize2(QTextStream &stream) const {
48 if (colorTerm())
49 stream << QChar(27) << '[' << 31 << 'm'; // to red
52 inline void normalColor(QTextStream &stream) const {
53 if (colorTerm())
54 stream << QChar(27) << '[' << 0 << 'm'; // reset
57 /// returns true when there is a repository, but it has not had its initial commit yet.
58 bool isEmptyRepo() const;
60 /// return the branches in the current repo.
61 QList<Branch> allBranches();
62 /// return the branches in the current repo.
63 QList<Branch> branches();
64 /// return the branches in the current repo.
65 QList<Branch> remoteBranches();
67 private:
68 void readConfig();
69 void fetchBranches();
71 QDir m_repoDir;
72 QDir m_repoMetaDataDir;
73 QString m_section;
74 bool m_dirty, m_emptyRepo, m_fetchedBranches;
75 QHash<QString, QString> m_options;
76 QList<Branch> m_localBranches;
77 QList<Branch> m_remoteBranches;
80 #endif