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
24 #include <QTextStream>
27 #include "patches/Branch.h"
31 /// creates a simple configuration object which does not check for section specific settings.
34 * Creates a Configuration object which is initialized with settings from for the section.
35 * If the user has settings in his user-wide-profile for the section passed, these will
36 * be read and made available using the contains() and optionArgument() methods.
37 * @param section the command-name which this configuration object will link to.
39 Configuration(const QString
§ion
);
41 QString
section() const { return m_section
; }
44 * returns true if the option was found in the configuration files.
45 * @see optionArgument()
47 bool contains(const QString
& key
) const;
49 * Return the argument passed to an option.
52 QString
optionArgument(const QString
&optionName
, const QString
&defaultValue
= QString()) const;
54 /// return the base directory of this repository.
55 QDir
repository() const;
56 /// returns the directory where the database and other meta data is stored.
57 QDir
repositoryMetaDir() const;
60 * Returns true if the current terminal supports colors.
61 * You normally want to just call colorize() and related methods.
62 * @see colorize(), colorize2(), normalColor()
64 bool colorTerm() const;
68 * In case the current terminal is a colorTerm() this method will make the stream use a color.
71 inline void colorize(QTextStream
&stream
) const {
73 stream
<< QChar(27) << '[' << 34 << 'm'; // to blue
77 * In case the current terminal is a colorTerm() this method will make the stream use a strong color.
80 inline void colorize2(QTextStream
&stream
) const {
82 stream
<< QChar(27) << '[' << 31 << 'm'; // to red
86 * Reset the terminal color to normal.
89 inline void normalColor(QTextStream
&stream
) const {
91 stream
<< QChar(27) << '[' << 0 << 'm'; // reset
94 /// returns true when there is a repository, but it has not had its initial commit yet.
95 bool isEmptyRepo() const;
96 /// return the branches in the current repo.
97 QList
<Branch
> allBranches();
98 /// return the branches in the current repo.
99 QList
<Branch
> branches();
100 /// return the branches in the current repo.
101 QList
<Branch
> remoteBranches();
105 void fetchBranches();
108 QDir m_repoMetaDataDir
;
110 bool m_dirty
, m_emptyRepo
, m_fetchedBranches
;
111 QHash
<QString
, QString
> m_options
;
112 QList
<Branch
> m_localBranches
;
113 QList
<Branch
> m_remoteBranches
;