Qt
Internal/Contributor docs for the Qt SDK. Note: These are NOT official API docs; those are found at https://doc.qt.io/
Loading...
Searching...
No Matches
qsettings_p.h
Go to the documentation of this file.
1// Copyright (C) 2022 The Qt Company Ltd.
2// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only
3// Qt-Security score:significant reason:default
4
5#ifndef QSETTINGS_P_H
6#define QSETTINGS_P_H
7
8//
9// W A R N I N G
10// -------------
11//
12// This file is not part of the Qt API. It exists purely as an
13// implementation detail. This header file may change from version to
14// version without notice, or even be removed.
15//
16// We mean it.
17//
18
19#include "QtCore/qdatetime.h"
20#include "QtCore/qmap.h"
21#include "QtCore/qmutex.h"
22#include "QtCore/qiodevice.h"
23#include "QtCore/qstack.h"
24#include "QtCore/qstringlist.h"
25
26#include <QtCore/qvariant.h>
27#include "qsettings.h"
28
29#ifndef QT_NO_QOBJECT
30#include "private/qobject_p.h"
31#endif
32
34
35#ifndef Q_OS_WIN
36#define QT_QSETTINGS_ALWAYS_CASE_SENSITIVE_AND_FORGET_ORIGINAL_KEY_ORDER
37#endif
38
39// used in testing framework
40#define QSETTINGS_P_H_VERSION 3
41
43static const Qt::CaseSensitivity IniCaseSensitivity = Qt::CaseSensitive;
44
45class QSettingsKey : public QString
46{
47public:
48 inline QSettingsKey(const QString &key, Qt::CaseSensitivity cs, qsizetype /* position */ = -1)
49 : QString(key) { Q_ASSERT(cs == Qt::CaseSensitive); Q_UNUSED(cs); }
50
51 inline QString originalCaseKey() const { return *this; }
52 inline qsizetype originalKeyPosition() const { return -1; }
53};
54#else
55static const Qt::CaseSensitivity IniCaseSensitivity = Qt::CaseInsensitive;
56
57class QSettingsKey : public QString
58{
59public:
60 inline QSettingsKey(const QString &key, Qt::CaseSensitivity cs, qsizetype position = -1)
61 : QString(key), theOriginalKey(key), theOriginalKeyPosition(position)
62 {
63 if (cs == Qt::CaseInsensitive)
64 QString::operator=(toLower());
65 }
66
67 inline QString originalCaseKey() const { return theOriginalKey; }
68 inline qsizetype originalKeyPosition() const { return theOriginalKeyPosition; }
69
70private:
71 QString theOriginalKey;
72 qsizetype theOriginalKeyPosition;
73};
74#endif
75
77
80
82{
83public:
85 : num(-1), maxNum(-1) {}
86 inline QSettingsGroup(const QString &s)
87 : str(s), num(-1), maxNum(-1) {}
88 inline QSettingsGroup(const QString &s, bool guessArraySize)
89 : str(s), num(0), maxNum(guessArraySize ? 0 : -1) {}
90
91 inline QString name() const { return str; }
92 inline QString toString() const;
93 inline bool isArray() const { return num != -1; }
94 inline qsizetype arraySizeGuess() const { return maxNum; }
95 inline void setArrayIndex(qsizetype i)
96 { num = i + 1; if (maxNum != -1 && num > maxNum) maxNum = num; }
97
101};
103
105{
106 QString result;
107 result = str;
108 if (num > 0) {
109 result += u'/';
110 result += QString::number(num);
111 }
112 return result;
113}
114
116{
117public:
118 ~QConfFile();
119
121 bool isWritable() const;
122
123 static QConfFile *fromName(const QString &name, bool _userPerms);
125 static void clearCache();
126
137
138private:
139#ifdef Q_DISABLE_COPY
140 QConfFile(const QConfFile &);
141 QConfFile &operator=(const QConfFile &);
142#endif
143 QConfFile(const QString &name, bool _userPerms);
144
145 friend class QConfFile_createsItself; // silences compiler warning
146};
147
148class Q_AUTOTEST_EXPORT QSettingsPrivate
149#ifndef QT_NO_QOBJECT
150 : public QObjectPrivate
151#endif
152{
153#ifdef QT_NO_QOBJECT
154 QSettings *q_ptr;
155#endif
156 Q_DECLARE_PUBLIC(QSettings)
157
158public:
159 QSettingsPrivate(QSettings::Format format);
160 QSettingsPrivate(QSettings::Format format, QSettings::Scope scope,
161 const QString &organization, const QString &application);
162 virtual ~QSettingsPrivate();
163
164 virtual void remove(const QString &key) = 0;
165 virtual void set(const QString &key, const QVariant &value) = 0;
166 virtual std::optional<QVariant> get(const QString &key) const = 0;
167
168 enum ChildSpec { AllKeys, ChildKeys, ChildGroups };
169 virtual QStringList children(const QString &prefix, ChildSpec spec) const = 0;
170
171 virtual void clear() = 0;
172 virtual void sync() = 0;
173 virtual void flush() = 0;
174 virtual bool isWritable() const = 0;
175 virtual QString fileName() const = 0;
176
177 QVariant value(QAnyStringView key, const QVariant *defaultValue) const;
178 QString actualKey(QAnyStringView key) const;
179 void beginGroupOrArray(const QSettingsGroup &group);
180 void setStatus(QSettings::Status status) const;
181 void requestUpdate();
182 void update();
183
184 static QString normalizedKey(QAnyStringView key);
185 static QSettingsPrivate *create(QSettings::Format format, QSettings::Scope scope,
186 const QString &organization, const QString &application);
187 static QSettingsPrivate *create(const QString &fileName, QSettings::Format format);
188
189 static void processChild(QStringView key, ChildSpec spec, QStringList &result);
190
191 // Variant streaming functions
192 static QStringList variantListToStringList(const QVariantList &l);
193 static QVariant stringListToVariantList(const QStringList &l);
194
195 // parser functions
196 static QString variantToString(const QVariant &v);
197 static QVariant stringToVariant(const QString &s);
198 static void iniEscapedKey(const QString &key, QByteArray &result);
199 static bool iniUnescapedKey(QByteArrayView key, QString &result);
200 static void iniEscapedString(const QString &str, QByteArray &result);
201 static void iniEscapedStringList(const QStringList &strs, QByteArray &result);
202 static bool iniUnescapedStringList(QByteArrayView str, QString &stringResult,
203 QStringList &stringListResult);
204 static QStringList splitArgs(const QString &s, qsizetype idx);
205
206 QSettings::Format format;
207 QSettings::Scope scope;
208 QString organizationName;
209 QString applicationName;
210
211protected:
212 QStack<QSettingsGroup> groupStack;
213 QString groupPrefix;
214 bool fallbacks;
215 bool pendingChanges;
216 bool atomicSyncOnly = true;
217 mutable QSettings::Status status;
218};
219
221{
222public:
224 const QString &organization, const QString &application);
225 QConfFileSettingsPrivate(const QString &fileName, QSettings::Format format);
227
228 void remove(const QString &key) override;
229 void set(const QString &key, const QVariant &value) override;
230 std::optional<QVariant> get(const QString &key) const override;
231
232 QStringList children(const QString &prefix, ChildSpec spec) const override;
233
234 void clear() override;
235 void sync() override;
236 void flush() override;
237 bool isWritable() const override;
238 QString fileName() const override;
239
240 bool readIniFile(QByteArrayView data, UnparsedSettingsMap *unparsedIniSections);
241 static bool readIniSection(const QSettingsKey &section, QByteArrayView data,
242 ParsedSettingsMap *settingsMap);
243 static bool readIniLine(QByteArrayView data, qsizetype &dataPos,
244 qsizetype &lineStart, qsizetype &lineLen,
245 qsizetype &equalsPos);
246
247protected:
248 const QList<QConfFile *> &getConfFiles() const { return confFiles; }
249
250private:
251 void initFormat();
252 virtual void initAccess();
253 void syncConfFile(QConfFile *confFile);
254 bool writeIniFile(QIODevice &device, const ParsedSettingsMap &map);
255#ifdef Q_OS_DARWIN
258#endif
259 void ensureAllSectionsParsed(QConfFile *confFile) const;
260 void ensureSectionParsed(QConfFile *confFile, const QSettingsKey &key) const;
261
262 QList<QConfFile *> confFiles;
265 QString extension;
266 Qt::CaseSensitivity caseSensitivity;
267 qsizetype nextPosition;
268#ifdef Q_OS_WASM
269 friend class QWasmIDBSettingsPrivate;
270#endif
271};
272
273QT_END_NAMESPACE
274
275#endif // QSETTINGS_P_H
static bool readIniSection(const QSettingsKey &section, QByteArrayView data, ParsedSettingsMap *settingsMap)
void set(const QString &key, const QVariant &value) override
QStringList children(const QString &prefix, ChildSpec spec) const override
virtual void initAccess()
bool readIniFile(QByteArrayView data, UnparsedSettingsMap *unparsedIniSections)
bool isWritable() const override
QString fileName() const override
QConfFileSettingsPrivate(QSettings::Format format, QSettings::Scope scope, const QString &organization, const QString &application)
void remove(const QString &key) override
QConfFileSettingsPrivate(const QString &fileName, QSettings::Format format)
const QList< QConfFile * > & getConfFiles() const
static bool readIniLine(QByteArrayView data, qsizetype &dataPos, qsizetype &lineStart, qsizetype &lineLen, qsizetype &equalsPos)
std::optional< QVariant > get(const QString &key) const override
QString name
QAtomicInt ref
UnparsedSettingsMap unparsedIniSections
ParsedSettingsMap originalKeys
qint64 size
bool userPerms
static Q_AUTOTEST_EXPORT void clearCache()
QDateTime timeStamp
QMutex mutex
ParsedSettingsMap removedKeys
ParsedSettingsMap mergedKeyMap() const
static QConfFile * fromName(const QString &name, bool _userPerms)
bool isWritable() const
ParsedSettingsMap addedKeys
\inmodule QtCore
Definition qfile.h:96
\inmodule QtCore
Definition qlockfile.h:19
QSettingsGroup(const QString &s, bool guessArraySize)
Definition qsettings_p.h:88
qsizetype num
Definition qsettings_p.h:99
QString toString() const
QString name() const
Definition qsettings_p.h:91
bool isArray() const
Definition qsettings_p.h:93
qsizetype arraySizeGuess() const
Definition qsettings_p.h:94
qsizetype maxNum
QSettingsGroup(const QString &s)
Definition qsettings_p.h:86
void setArrayIndex(qsizetype i)
Definition qsettings_p.h:95
qsizetype position
QSettingsIniKey(const QString &str, qsizetype pos=-1)
QSettingsKey(const QString &key, Qt::CaseSensitivity cs, qsizetype=-1)
Definition qsettings_p.h:48
QString originalCaseKey() const
Definition qsettings_p.h:51
qsizetype originalKeyPosition() const
Definition qsettings_p.h:52
\inmodule QtCore
Definition qsettings.h:31
static const char charTraits[256]
QMap< QString, QSettingsIniSection > IniMap
QList< QConfFileCustomFormat > CustomFormatVector
Definition qsettings.cpp:89
static bool operator<(const QSettingsIniKey &k1, const QSettingsIniKey &k2)
static constexpr QChar sep
static Path getPath(QSettings::Format format, QSettings::Scope scope)
QMap< QSettingsIniKey, QVariant > IniKeyMap
static int pathHashKey(QSettings::Format format, QSettings::Scope scope)
static QString make_user_path()
static std::unique_lock< QBasicMutex > initDefaultPaths(std::unique_lock< QBasicMutex > locker)
static QString make_user_path_without_qstandard_paths()
QHash< QString, QConfFile * > ConfFileHash
Definition qsettings.cpp:75
QHash< int, Path > PathHash
Definition qsettings.cpp:88
Q_DECLARE_TYPEINFO(QSettingsIniSection, Q_RELOCATABLE_TYPE)
Q_DECLARE_TYPEINFO(QConfFileCustomFormat, Q_RELOCATABLE_TYPE)
Q_DECLARE_TYPEINFO(QSettingsIniKey, Q_RELOCATABLE_TYPE)
QCache< QString, QConfFile > ConfFileCache
Definition qsettings.cpp:76
#define FLUSH_CURRENT_SECTION()
static void iniChopTrailingSpaces(QString &str, qsizetype limit)
Q_DECLARE_TYPEINFO(QSettingsGroup, Q_RELOCATABLE_TYPE)
static const Qt::CaseSensitivity IniCaseSensitivity
Definition qsettings_p.h:43
Q_DECLARE_TYPEINFO(QSettingsKey, Q_RELOCATABLE_TYPE)
QMap< QSettingsKey, QByteArray > UnparsedSettingsMap
Definition qsettings_p.h:78
QMap< QSettingsKey, QVariant > ParsedSettingsMap
Definition qsettings_p.h:79
#define QT_QSETTINGS_ALWAYS_CASE_SENSITIVE_AND_FORGET_ORIGINAL_KEY_ORDER
Definition qsettings_p.h:36
QSettings settings("MyCompany", "MyApp")
[11]
Qt::CaseSensitivity caseSensitivity
Definition qsettings.cpp:71