Qt
Internal/Contributor docs for the Qt SDK. <b>Note:</b> These are NOT official API docs; those are found <a href='https://doc.qt.io/'>here</a>.
Loading...
Searching...
No Matches
qurl.h
Go to the documentation of this file.
1// Copyright (C) 2020 The Qt Company Ltd.
2// Copyright (C) 2016 Intel Corporation.
3// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only
4
5#ifndef QURL_H
6#define QURL_H
7
8#include <QtCore/qbytearray.h>
9#include <QtCore/qcompare.h>
10#include <QtCore/qobjectdefs.h>
11#include <QtCore/qstring.h>
12#include <QtCore/qlist.h>
13#include <QtCore/qglobal.h>
14
15#if defined(Q_OS_DARWIN) || defined(Q_QDOC)
18#endif
19
21
22
23class QUrlQuery;
24class QUrlPrivate;
25class QDataStream;
26
27template <typename E1, typename E2>
29{
30 int i;
31public:
32 constexpr inline QUrlTwoFlags() : i(0) {}
33 constexpr inline QUrlTwoFlags(E1 f) : i(f) {}
34 constexpr inline QUrlTwoFlags(E2 f) : i(f) {}
35 constexpr inline QUrlTwoFlags(QFlag f) : i(f) {}
36 constexpr inline QUrlTwoFlags(QFlags<E1> f) : i(f.operator typename QFlags<E1>::Int()) {}
37 constexpr inline QUrlTwoFlags(QFlags<E2> f) : i(f.operator typename QFlags<E2>::Int()) {}
38
39 inline QUrlTwoFlags &operator&=(int mask) { i &= mask; return *this; }
40 inline QUrlTwoFlags &operator&=(uint mask) { i &= mask; return *this; }
41 inline QUrlTwoFlags &operator&=(QFlags<E1> mask) { i &= mask.toInt(); return *this; }
42 inline QUrlTwoFlags &operator&=(QFlags<E2> mask) { i &= mask.toInt(); return *this; }
43 inline QUrlTwoFlags &operator|=(QUrlTwoFlags f) { i |= f.i; return *this; }
44 inline QUrlTwoFlags &operator|=(E1 f) { i |= f; return *this; }
45 inline QUrlTwoFlags &operator|=(E2 f) { i |= f; return *this; }
46 inline QUrlTwoFlags &operator|=(QFlags<E1> mask) { i |= mask.toInt(); return *this; }
47 inline QUrlTwoFlags &operator|=(QFlags<E2> mask) { i |= mask.toInt(); return *this; }
48 inline QUrlTwoFlags &operator^=(QUrlTwoFlags f) { i ^= f.i; return *this; }
49 inline QUrlTwoFlags &operator^=(E1 f) { i ^= f; return *this; }
50 inline QUrlTwoFlags &operator^=(E2 f) { i ^= f; return *this; }
51 inline QUrlTwoFlags &operator^=(QFlags<E1> mask) { i ^= mask.toInt(); return *this; }
52 inline QUrlTwoFlags &operator^=(QFlags<E2> mask) { i ^= mask.toInt(); return *this; }
53
54 constexpr inline operator QFlags<E1>() const { return QFlag(i); }
55 constexpr inline operator QFlags<E2>() const { return QFlag(i); }
56 constexpr inline operator int() const { return i; }
57 constexpr inline bool operator!() const { return !i; }
58
59 constexpr inline QUrlTwoFlags operator|(QUrlTwoFlags f) const
60 { return QUrlTwoFlags(QFlag(i | f.i)); }
61 constexpr inline QUrlTwoFlags operator|(E1 f) const
62 { return QUrlTwoFlags(QFlag(i | f)); }
63 constexpr inline QUrlTwoFlags operator|(E2 f) const
64 { return QUrlTwoFlags(QFlag(i | f)); }
65 constexpr inline QUrlTwoFlags operator^(QUrlTwoFlags f) const
66 { return QUrlTwoFlags(QFlag(i ^ f.i)); }
67 constexpr inline QUrlTwoFlags operator^(E1 f) const
68 { return QUrlTwoFlags(QFlag(i ^ f)); }
69 constexpr inline QUrlTwoFlags operator^(E2 f) const
70 { return QUrlTwoFlags(QFlag(i ^ f)); }
71 constexpr inline QUrlTwoFlags operator&(int mask) const
72 { return QUrlTwoFlags(QFlag(i & mask)); }
73 constexpr inline QUrlTwoFlags operator&(uint mask) const
74 { return QUrlTwoFlags(QFlag(i & mask)); }
75 constexpr inline QUrlTwoFlags operator&(E1 f) const
76 { return QUrlTwoFlags(QFlag(i & f)); }
77 constexpr inline QUrlTwoFlags operator&(E2 f) const
78 { return QUrlTwoFlags(QFlag(i & f)); }
79 constexpr inline QUrlTwoFlags operator~() const
80 { return QUrlTwoFlags(QFlag(~i)); }
81
82 constexpr inline bool testFlag(E1 f) const { return (i & f) == f && (f != 0 || i == int(f)); }
83 constexpr inline bool testFlag(E2 f) const { return (i & f) == f && (f != 0 || i == int(f)); }
84};
85
86template<typename E1, typename E2>
87class QTypeInfo<QUrlTwoFlags<E1, E2> > : public QTypeInfoMerger<QUrlTwoFlags<E1, E2>, E1, E2> {};
88
89class QUrl;
90// qHash is a friend, but we can't use default arguments for friends (ยง8.3.6.4)
91Q_CORE_EXPORT size_t qHash(const QUrl &url, size_t seed = 0) noexcept;
92
93class Q_CORE_EXPORT QUrl
94{
95public:
101
102 // encoding / toString values
103 enum UrlFormattingOption : unsigned int {
104 None = 0x0,
113 // 0x100 was a private code in Qt 4, keep unused for a while
117 NormalizePathSegments = 0x1000
118 };
119
120 enum ComponentFormattingOption : unsigned int {
121 PrettyDecoded = 0x000000,
122 EncodeSpaces = 0x100000,
123 EncodeUnicode = 0x200000,
124 EncodeDelimiters = 0x400000 | 0x800000,
125 EncodeReserved = 0x1000000,
126 DecodeReserved = 0x2000000,
127 // 0x4000000 used to indicate full-decode mode
128
131 };
132 Q_DECLARE_FLAGS(ComponentFormattingOptions, ComponentFormattingOption)
133#ifdef Q_QDOC
134private:
135 // We need to let qdoc think that FormattingOptions is a normal QFlags, but
136 // it needs to be a QUrlTwoFlags for compiling default arguments of some functions.
137 template<typename T> struct QFlags : QUrlTwoFlags<T, ComponentFormattingOption>
138 { using QUrlTwoFlags<T, ComponentFormattingOption>::QUrlTwoFlags; };
139public:
140 Q_DECLARE_FLAGS(FormattingOptions, UrlFormattingOption)
141#else
142 typedef QUrlTwoFlags<UrlFormattingOption, ComponentFormattingOption> FormattingOptions;
143#endif
144
145 QUrl();
146 QUrl(const QUrl &copy) noexcept;
147 QUrl &operator =(const QUrl &copy) noexcept;
148#ifdef QT_NO_URL_CAST_FROM_STRING
149 explicit QUrl(const QString &url, ParsingMode mode = TolerantMode);
150#else
151 QUrl(const QString &url, ParsingMode mode = TolerantMode);
152 QUrl &operator=(const QString &url);
153#endif
154 QUrl(QUrl &&other) noexcept : d(other.d)
155 { other.d = nullptr; }
156 QT_MOVE_ASSIGNMENT_OPERATOR_IMPL_VIA_PURE_SWAP(QUrl)
157 ~QUrl();
158
159 void swap(QUrl &other) noexcept { qt_ptr_swap(d, other.d); }
160
161 void setUrl(const QString &url, ParsingMode mode = TolerantMode);
162 QString url(FormattingOptions options = FormattingOptions(PrettyDecoded)) const;
163 QString toString(FormattingOptions options = FormattingOptions(PrettyDecoded)) const;
164 QString toDisplayString(FormattingOptions options = FormattingOptions(PrettyDecoded)) const;
165 [[nodiscard]] QUrl adjusted(FormattingOptions options) const;
166
167 QByteArray toEncoded(FormattingOptions options = FullyEncoded) const;
168#if QT_CORE_REMOVED_SINCE(6, 7)
169 static QUrl fromEncoded(const QByteArray &url, ParsingMode mode = TolerantMode);
170#endif
171 static QUrl fromEncoded(QByteArrayView input, ParsingMode mode = TolerantMode);
172
177 Q_DECLARE_FLAGS(UserInputResolutionOptions, UserInputResolutionOption)
178
179 static QUrl fromUserInput(const QString &userInput, const QString &workingDirectory = QString(),
180 UserInputResolutionOptions options = DefaultResolution);
181
182 bool isValid() const;
183 QString errorString() const;
184
185 bool isEmpty() const;
186 void clear();
187
188 void setScheme(const QString &scheme);
189 QString scheme() const;
190
191 void setAuthority(const QString &authority, ParsingMode mode = TolerantMode);
192 QString authority(ComponentFormattingOptions options = PrettyDecoded) const;
193
194 void setUserInfo(const QString &userInfo, ParsingMode mode = TolerantMode);
195 QString userInfo(ComponentFormattingOptions options = PrettyDecoded) const;
196
197 void setUserName(const QString &userName, ParsingMode mode = DecodedMode);
198 QString userName(ComponentFormattingOptions options = FullyDecoded) const;
199
200 void setPassword(const QString &password, ParsingMode mode = DecodedMode);
201 QString password(ComponentFormattingOptions = FullyDecoded) const;
202
203 void setHost(const QString &host, ParsingMode mode = DecodedMode);
204 QString host(ComponentFormattingOptions = FullyDecoded) const;
205
206 void setPort(int port);
207 int port(int defaultPort = -1) const;
208
209 void setPath(const QString &path, ParsingMode mode = DecodedMode);
210 QString path(ComponentFormattingOptions options = FullyDecoded) const;
211 QString fileName(ComponentFormattingOptions options = FullyDecoded) const;
212
213 bool hasQuery() const;
214 void setQuery(const QString &query, ParsingMode mode = TolerantMode);
215 void setQuery(const QUrlQuery &query);
216 QString query(ComponentFormattingOptions = PrettyDecoded) const;
217
218 bool hasFragment() const;
219 QString fragment(ComponentFormattingOptions options = PrettyDecoded) const;
220 void setFragment(const QString &fragment, ParsingMode mode = TolerantMode);
221
222 [[nodiscard]] QUrl resolved(const QUrl &relative) const;
223
224 bool isRelative() const;
225 bool isParentOf(const QUrl &url) const;
226
227 bool isLocalFile() const;
228 static QUrl fromLocalFile(const QString &localfile);
229 QString toLocalFile() const;
230
231 void detach();
232 bool isDetached() const;
233
234#if QT_CORE_REMOVED_SINCE(6, 8)
235 bool operator <(const QUrl &url) const;
236 bool operator ==(const QUrl &url) const;
237 bool operator !=(const QUrl &url) const;
238#endif
239
240 bool matches(const QUrl &url, FormattingOptions options) const;
241
242 static QString fromPercentEncoding(const QByteArray &);
243 static QByteArray toPercentEncoding(const QString &,
244 const QByteArray &exclude = QByteArray(),
245 const QByteArray &include = QByteArray());
246#if defined(Q_OS_DARWIN) || defined(Q_QDOC)
247 static QUrl fromCFURL(CFURLRef url);
248 CFURLRef toCFURL() const Q_DECL_CF_RETURNS_RETAINED;
249 static QUrl fromNSURL(const NSURL *url);
250 NSURL *toNSURL() const Q_DECL_NS_RETURNS_AUTORELEASED;
251#endif
252
253 enum AceProcessingOption : unsigned int {
254 IgnoreIDNWhitelist = 0x1,
255 AceTransitionalProcessing = 0x2,
256 };
257 Q_DECLARE_FLAGS(AceProcessingOptions, AceProcessingOption)
258
259#if QT_CORE_REMOVED_SINCE(6, 3)
260 static QString fromAce(const QByteArray &);
261 static QByteArray toAce(const QString &);
262#endif
263 static QString fromAce(const QByteArray &domain, AceProcessingOptions options = {});
264 static QByteArray toAce(const QString &domain, AceProcessingOptions options = {});
265
266 static QStringList idnWhitelist();
267 static QStringList toStringList(const QList<QUrl> &uris, FormattingOptions options = FormattingOptions(PrettyDecoded));
268 static QList<QUrl> fromStringList(const QStringList &uris, ParsingMode mode = TolerantMode);
269
270 static void setIdnWhitelist(const QStringList &);
271 friend Q_CORE_EXPORT size_t qHash(const QUrl &url, size_t seed) noexcept;
272
273private:
274 friend Q_CORE_EXPORT bool comparesEqual(const QUrl &lhs, const QUrl &rhs);
275 friend Q_CORE_EXPORT Qt::weak_ordering
276 compareThreeWay(const QUrl &lhs, const QUrl &rhs);
278
279 QUrlPrivate *d;
280 friend class QUrlQuery;
281
282public:
284 inline DataPtr &data_ptr() { return d; }
285};
286
287Q_DECLARE_SHARED(QUrl)
288Q_DECLARE_OPERATORS_FOR_FLAGS(QUrl::ComponentFormattingOptions)
289//Q_DECLARE_OPERATORS_FOR_FLAGS(QUrl::FormattingOptions)
290Q_DECLARE_OPERATORS_FOR_FLAGS(QUrl::AceProcessingOptions)
291
292#ifndef Q_QDOC
298{ return QIncompatibleFlag(uint(f1) | f2); }
299
300// add operators for OR'ing the two types of flags
301inline QUrl::FormattingOptions &operator|=(QUrl::FormattingOptions &i, QUrl::ComponentFormattingOptions f)
302{ i |= QUrl::UrlFormattingOption(f.toInt()); return i; }
305constexpr inline QUrl::FormattingOptions operator|(QUrl::UrlFormattingOption i, QUrl::ComponentFormattingOptions f)
306{ return i | QUrl::UrlFormattingOption(f.toInt()); }
309constexpr inline QUrl::FormattingOptions operator|(QUrl::ComponentFormattingOptions f, QUrl::UrlFormattingOption i)
310{ return i | QUrl::UrlFormattingOption(f.toInt()); }
311constexpr inline QUrl::FormattingOptions operator|(QUrl::FormattingOptions i, QUrl::ComponentFormattingOptions f)
312{ return i | QUrl::UrlFormattingOption(f.toInt()); }
315constexpr inline QUrl::FormattingOptions operator|(QUrl::ComponentFormattingOptions f, QUrl::FormattingOptions i)
316{ return i | QUrl::UrlFormattingOption(f.toInt()); }
317
318//inline QUrl::UrlFormattingOption &operator=(const QUrl::UrlFormattingOption &i, QUrl::ComponentFormattingOptions f)
319//{ i = int(f); f; }
320#endif // Q_QDOC
321
322#ifndef QT_NO_DATASTREAM
323Q_CORE_EXPORT QDataStream &operator<<(QDataStream &, const QUrl &);
325#endif
326
327#ifndef QT_NO_DEBUG_STREAM
328Q_CORE_EXPORT QDebug operator<<(QDebug, const QUrl &);
329#endif
330
332
333#endif // QURL_H
\inmodule QtCore
Definition qbytearray.h:57
\inmodule QtCore\reentrant
Definition qdatastream.h:46
\inmodule QtCore
Definition qflags.h:17
\inmodule QtCore
\macro QT_RESTRICTED_CAST_FROM_ASCII
Definition qstring.h:129
\inmodule QtCore
Definition qtypeinfo.h:100
\inmodule QtCore
Definition qurlquery.h:20
constexpr QUrlTwoFlags(E2 f)
Definition qurl.h:34
constexpr QUrlTwoFlags operator&(uint mask) const
Definition qurl.h:73
QUrlTwoFlags & operator&=(int mask)
Definition qurl.h:39
constexpr QUrlTwoFlags operator^(E2 f) const
Definition qurl.h:69
QUrlTwoFlags & operator|=(QFlags< E1 > mask)
Definition qurl.h:46
constexpr bool testFlag(E2 f) const
Definition qurl.h:83
constexpr QUrlTwoFlags operator^(QUrlTwoFlags f) const
Definition qurl.h:65
QUrlTwoFlags & operator^=(E2 f)
Definition qurl.h:50
QUrlTwoFlags & operator^=(E1 f)
Definition qurl.h:49
QUrlTwoFlags & operator&=(QFlags< E2 > mask)
Definition qurl.h:42
constexpr QUrlTwoFlags(QFlags< E1 > f)
Definition qurl.h:36
constexpr QUrlTwoFlags operator&(int mask) const
Definition qurl.h:71
constexpr QUrlTwoFlags operator&(E1 f) const
Definition qurl.h:75
QUrlTwoFlags & operator^=(QFlags< E2 > mask)
Definition qurl.h:52
constexpr QUrlTwoFlags operator|(QUrlTwoFlags f) const
Definition qurl.h:59
QUrlTwoFlags & operator|=(QFlags< E2 > mask)
Definition qurl.h:47
constexpr QUrlTwoFlags operator&(E2 f) const
Definition qurl.h:77
constexpr bool operator!() const
Definition qurl.h:57
QUrlTwoFlags & operator|=(QUrlTwoFlags f)
Definition qurl.h:43
constexpr QUrlTwoFlags operator|(E2 f) const
Definition qurl.h:63
QUrlTwoFlags & operator^=(QFlags< E1 > mask)
Definition qurl.h:51
constexpr bool testFlag(E1 f) const
Definition qurl.h:82
constexpr QUrlTwoFlags operator|(E1 f) const
Definition qurl.h:61
constexpr QUrlTwoFlags(E1 f)
Definition qurl.h:33
QUrlTwoFlags & operator&=(uint mask)
Definition qurl.h:40
QUrlTwoFlags & operator&=(QFlags< E1 > mask)
Definition qurl.h:41
QUrlTwoFlags & operator|=(E1 f)
Definition qurl.h:44
constexpr QUrlTwoFlags operator^(E1 f) const
Definition qurl.h:67
constexpr QUrlTwoFlags(QFlag f)
Definition qurl.h:35
QUrlTwoFlags & operator^=(QUrlTwoFlags f)
Definition qurl.h:48
QUrlTwoFlags & operator|=(E2 f)
Definition qurl.h:45
constexpr QUrlTwoFlags()
Definition qurl.h:32
constexpr QUrlTwoFlags operator~() const
Definition qurl.h:79
constexpr QUrlTwoFlags(QFlags< E2 > f)
Definition qurl.h:37
\inmodule QtCore
Definition qurl.h:94
void swap(QUrl &other) noexcept
Definition qurl.h:159
friend Q_CORE_EXPORT size_t qHash(const QUrl &url, size_t seed) noexcept
QUrlPrivate * DataPtr
Definition qurl.h:283
DataPtr & data_ptr()
Definition qurl.h:284
QUrl(QUrl &&other) noexcept
Move-constructs a QUrl instance, making it point at the same object that other was pointing to.
Definition qurl.h:154
AceProcessingOption
Definition qurl.h:253
UserInputResolutionOption
Definition qurl.h:173
@ DefaultResolution
Definition qurl.h:174
ParsingMode
The parsing mode controls the way QUrl parses strings.
Definition qurl.h:96
@ DecodedMode
Definition qurl.h:99
@ TolerantMode
Definition qurl.h:97
@ StrictMode
Definition qurl.h:98
QUrlTwoFlags< UrlFormattingOption, ComponentFormattingOption > FormattingOptions
Definition qurl.h:142
UrlFormattingOption
The formatting options define how the URL is formatted when written out as text.
Definition qurl.h:103
@ RemovePassword
Definition qurl.h:106
@ RemoveScheme
Definition qurl.h:105
@ StripTrailingSlash
Definition qurl.h:115
@ RemoveFragment
Definition qurl.h:112
@ RemoveQuery
Definition qurl.h:111
@ RemoveFilename
Definition qurl.h:116
@ PreferLocalFile
Definition qurl.h:114
@ NormalizePathSegments
Definition qurl.h:117
@ RemovePath
Definition qurl.h:110
@ RemoveUserInfo
Definition qurl.h:107
@ RemoveAuthority
Definition qurl.h:109
@ RemovePort
Definition qurl.h:108
ComponentFormattingOption
Definition qurl.h:120
@ PrettyDecoded
Definition qurl.h:121
@ EncodeReserved
Definition qurl.h:125
@ FullyDecoded
Definition qurl.h:130
@ EncodeDelimiters
Definition qurl.h:124
@ EncodeUnicode
Definition qurl.h:123
@ DecodeReserved
Definition qurl.h:126
@ EncodeSpaces
Definition qurl.h:122
@ FullyEncoded
Definition qurl.h:129
\variable Qt::strong_ordering::less
Definition qcompare.h:221
b clear()
void setHost()
Combined button and popup list for selecting options.
static jboolean copy(JNIEnv *, jobject)
#define Q_DECLARE_WEAKLY_ORDERED(...)
#define Q_DECL_NS_RETURNS_AUTORELEASED
#define Q_DECL_CF_RETURNS_RETAINED
constexpr bool operator!=(const timespec &t1, const timespec &t2)
#define Q_FORWARD_DECLARE_CF_TYPE(type)
#define Q_FORWARD_DECLARE_OBJC_CLASS(classname)
bool comparesEqual(const QDir &lhs, const QDir &rhs)
Definition qdir.cpp:1819
typedef QByteArray(EGLAPIENTRYP PFNQGSGETDISPLAYSPROC)()
EGLOutputPortEXT port
#define Q_DECLARE_FLAGS(Flags, Enum)
Definition qflags.h:174
#define Q_DECLARE_OPERATORS_FOR_FLAGS(Flags)
Definition qflags.h:194
@ None
Definition qhash.cpp:531
static bool matches(const QJsonObject &object, const QString &osName, const QVersionNumber &kernelVersion, const QString &osRelease, const QOpenGLConfig::Gpu &gpu)
Definition qopengl.cpp:270
GLenum mode
GLfloat GLfloat f
GLint GLint GLint GLint GLint GLint GLint GLbitfield mask
GLenum query
GLsizei const GLchar *const * path
GLenum GLenum GLenum input
static QString toLocalFile(const QString &url)
Definition qqmlfile.cpp:708
static QT_BEGIN_NAMESPACE bool isRelative(const QString &path)
static Q_CONSTINIT QBasicAtomicInteger< unsigned > seed
Definition qrandom.cpp:196
bool operator==(const QRandomGenerator &rng1, const QRandomGenerator &rng2)
Definition qrandom.cpp:1220
static bool operator<(const QSettingsIniKey &k1, const QSettingsIniKey &k2)
QT_BEGIN_NAMESPACE static Q_LOGGING_CATEGORY(lcStorageInfo, "qt.core.qstorageinfo", QtWarningMsg) class QStorageInfoPrivate bool isParentOf(const String &parent, const QString &dirName)
constexpr void qt_ptr_swap(T *&lhs, T *&rhs) noexcept
Definition qswap.h:29
request setUrl(QUrl("http://qt-project.org"))
static QStringList toStringList(const QJsonArray &jsonArray)
QT_BEGIN_NAMESPACE constexpr std::underlying_type_t< Enum > qToUnderlying(Enum e) noexcept
unsigned int uint
Definition qtypes.h:34
Qt::weak_ordering compareThreeWay(const QUrl &lhs, const QUrl &rhs)
Definition qurl.cpp:3079
Q_CORE_EXPORT size_t qHash(const QUrl &url, size_t seed=0) noexcept
Q_CORE_EXPORT QDataStream & operator>>(QDataStream &, QUrl &)
constexpr QUrl::FormattingOptions operator|(QUrl::UrlFormattingOption f1, QUrl::UrlFormattingOption f2)
Definition qurl.h:293
Q_CORE_EXPORT QDataStream & operator<<(QDataStream &, const QUrl &)
QUrl::FormattingOptions & operator|=(QUrl::FormattingOptions &i, QUrl::ComponentFormattingOptions f)
Definition qurl.h:301
QUrl url("example.com")
[constructor-url-reference]
url setScheme("ftp")
qDebug()<< QUrl("file copy setQuery(copy.query(QUrl::FullyDecoded), QUrl::DecodedMode)
QSharedPointer< T > other(t)
[5]
proxy setPassword("password")
proxy setPort(1080)
char * toString(const MyType &t)
[31]