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
qhostaddress.h
Go to the documentation of this file.
1// Copyright (C) 2016 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 QHOSTADDRESS_H
6#define QHOSTADDRESS_H
7
8#include <QtNetwork/qtnetworkglobal.h>
9#include <QtCore/qstring.h>
10#include <QtCore/qshareddata.h>
11#if QT_VERSION < QT_VERSION_CHECK(7, 0, 0)
12#include <QtNetwork/qabstractsocket.h>
13#endif
14
15#include <utility>
16
17struct sockaddr;
18
19QT_BEGIN_NAMESPACE
20
21
22class QHostAddressPrivate;
23QT_DECLARE_QESDP_SPECIALIZATION_DTOR(QHostAddressPrivate)
24
25class QT6_ONLY(Q_NETWORK_EXPORT) QIPv6Address
26{
27public:
28 inline quint8 &operator [](int index) { return c[index]; }
29 inline quint8 operator [](int index) const { return c[index]; }
30 quint8 c[16];
31};
32
34
35class QHostAddress;
36// qHash is a friend, but we can't use default arguments for friends (ยง8.3.6.4)
37Q_NETWORK_EXPORT size_t qHash(const QHostAddress &key, size_t seed = 0) noexcept;
38
39class Q_NETWORK_EXPORT QHostAddress
40{
41 Q_GADGET
42public:
43 enum SpecialAddress {
44 Null,
45 Broadcast,
46 LocalHost,
47 LocalHostIPv6,
48 Any,
49 AnyIPv6,
50 AnyIPv4
51 };
52 enum ConversionModeFlag {
53 ConvertV4MappedToIPv4 = 1,
54 ConvertV4CompatToIPv4 = 2,
55 ConvertUnspecifiedAddress = 4,
56 ConvertLocalHost = 8,
57 TolerantConversion = 0xff,
58
59 StrictConversion = 0
60 };
61 Q_DECLARE_FLAGS(ConversionMode, ConversionModeFlag)
62
63#if QT_VERSION < QT_VERSION_CHECK(7, 0, 0)
64 using NetworkLayerProtocol = QAbstractSocket::NetworkLayerProtocol;
65 static constexpr auto IPv4Protocol = QAbstractSocket::IPv4Protocol;
66 static constexpr auto IPv6Protocol = QAbstractSocket::IPv6Protocol;
67 static constexpr auto AnyIPProtocol = QAbstractSocket::AnyIPProtocol;
68 static constexpr auto UnknownNetworkLayerProtocol = QAbstractSocket::UnknownNetworkLayerProtocol;
69#else
70 enum NetworkLayerProtocol {
71 IPv4Protocol,
72 IPv6Protocol,
73 AnyIPProtocol,
74 UnknownNetworkLayerProtocol = -1
75 };
76 Q_ENUM(NetworkLayerProtocol)
77#endif
78
79 QHostAddress();
80 explicit QHostAddress(quint32 ip4Addr);
81 explicit QHostAddress(const quint8 *ip6Addr);
82 explicit QHostAddress(const Q_IPV6ADDR &ip6Addr);
83 explicit QHostAddress(const sockaddr *address);
84 explicit QHostAddress(const QString &address);
85 QHostAddress(const QHostAddress &copy);
86 QHostAddress(QHostAddress &&other) noexcept = default;
87 QHostAddress(SpecialAddress address);
88 ~QHostAddress();
89
90 QHostAddress &operator=(QHostAddress &&other) noexcept
91 { swap(other); return *this; }
92 QHostAddress &operator=(const QHostAddress &other);
93 QHostAddress &operator=(SpecialAddress address);
94
95 void swap(QHostAddress &other) noexcept { d.swap(other.d); }
96
97 void setAddress(quint32 ip4Addr);
98 void setAddress(const quint8 *ip6Addr);
99 void setAddress(const Q_IPV6ADDR &ip6Addr);
100 void setAddress(const sockaddr *address);
101 bool setAddress(const QString &address);
102 void setAddress(SpecialAddress address);
103
104 NetworkLayerProtocol protocol() const;
105 quint32 toIPv4Address(bool *ok = nullptr) const;
106 Q_IPV6ADDR toIPv6Address() const;
107
108 QString toString() const;
109
110 QString scopeId() const;
111 void setScopeId(const QString &id);
112
113 bool isEqual(const QHostAddress &address, ConversionMode mode = TolerantConversion) const;
114 bool operator ==(const QHostAddress &address) const;
115 bool operator ==(SpecialAddress address) const;
116 inline bool operator !=(const QHostAddress &address) const
117 { return !operator==(address); }
118 inline bool operator !=(SpecialAddress address) const
119 { return !operator==(address); }
120 bool isNull() const;
121 void clear();
122
123 bool isInSubnet(const QHostAddress &subnet, int netmask) const;
124 bool isInSubnet(const std::pair<QHostAddress, int> &subnet) const;
125
126 bool isLoopback() const;
127 bool isGlobal() const;
128 bool isLinkLocal() const;
129 bool isSiteLocal() const;
130 bool isUniqueLocalUnicast() const;
131 bool isMulticast() const;
132 bool isBroadcast() const;
133 bool isPrivateUse() const;
134
135 static std::pair<QHostAddress, int> parseSubnet(const QString &subnet);
136
137 friend Q_NETWORK_EXPORT size_t qHash(const QHostAddress &key, size_t seed) noexcept;
138
139 friend bool operator ==(QHostAddress::SpecialAddress lhs, const QHostAddress &rhs)
140 { return rhs == lhs; }
141 friend bool operator!=(QHostAddress::SpecialAddress lhs, const QHostAddress &rhs)
142 { return rhs != lhs; }
143
144protected:
145 friend class QHostAddressPrivate;
146 QExplicitlySharedDataPointer<QHostAddressPrivate> d;
147};
148Q_DECLARE_OPERATORS_FOR_FLAGS(QHostAddress::ConversionMode)
149Q_DECLARE_SHARED(QHostAddress)
150
151#ifndef QT_NO_DEBUG_STREAM
152Q_NETWORK_EXPORT QDebug operator<<(QDebug, const QHostAddress &);
153#endif
154
155#ifndef QT_NO_DATASTREAM
156Q_NETWORK_EXPORT QDataStream &operator<<(QDataStream &, const QHostAddress &);
157Q_NETWORK_EXPORT QDataStream &operator>>(QDataStream &, QHostAddress &);
158#endif
159
160QT_END_NAMESPACE
161
162#endif // QHOSTADDRESS_H
\inmodule QtCore\reentrant
Definition qdatastream.h:49
void setAddress(quint32 a_=0)
void setAddress(const quint8 *a_)
AddressClassification classify() const
void setAddress(const Q_IPV6ADDR &a_)
The QHostAddress class provides an IP address.
QDataStream & operator>>(QDataStream &in, QHostAddress &address)
Reads a host address into address from the stream in and returns a reference to the stream.
bool setAddress(const QHostAddress &address)
QHostAddress address(QAbstractSocket::NetworkLayerProtocol protocol) const
Combined button and popup list for selecting options.
static bool convertToIpv4(quint32 &a, const Q_IPV6ADDR &a6, const QHostAddress::ConversionMode mode)
size_t qHash(const QHostAddress &key, size_t seed) noexcept
static bool parseIp6(const QString &address, QIPAddressUtils::IPv6Address &addr, QString *scopeId)
static void clearBits(quint8 *where, int start, int end)
QIPv6Address Q_IPV6ADDR
#define AF_INET6