Disentangle string-related headers
It's starting to hinder QStringView development (QString::append(QStringView), e.g.). - qbytearray.h includes qstring.h, but is included by qstring.h -> remove qstring.h include from qbytearray.h - the QStringLiteral definition is used from both qstring.h and qstringview.h -> extract into its own header, move QStringViewLiteral definition there, too - the qCompareStrings(), qConvertTo*() functions are used by QString and QStringView -> also extract into own header, included from qstring.h and qstringview.h - QStringView::toString() depends on QString, which depends on QStringView -> move QStringView::toString() definition to qstring.h, after the definition of QString -> move qstringview.h up to all the other includes in qstring.h This is starting to look like a DAG again, and allows to remove the unholy #ifndef QSTRING_H # include <qstring.h> #endif hack from qstringview.h. [ChangeLog][Potentially Source-Incompatible Changes][QByteArray] qbytearray.h no longer includes qstring.h. In particular, this means that in order to use QStringBuilder with QByteArray, you need to include both qbytearray.h and qstring.h now (or <QByteArray> and <QString>, resp.). Change-Id: I7f8acf9c11bc1731266cd25c6eda9fb36723f364 Reviewed-by: Anton Kudryavtsev <antkudr@mail.ru> Reviewed-by: Edward Welbourne <edward.welbourne@qt.io>
This commit is contained in:
parent
0cfcebb955
commit
164392548e
@ -692,8 +692,4 @@ Q_DECLARE_SHARED(QByteArray)
|
||||
|
||||
QT_END_NAMESPACE
|
||||
|
||||
#ifdef QT_USE_QSTRINGBUILDER
|
||||
#include <QtCore/qstring.h>
|
||||
#endif
|
||||
|
||||
#endif // QBYTEARRAY_H
|
||||
|
@ -49,6 +49,9 @@
|
||||
#include <QtCore/qbytearray.h>
|
||||
#include <QtCore/qrefcount.h>
|
||||
#include <QtCore/qnamespace.h>
|
||||
#include <QtCore/qstringliteral.h>
|
||||
#include <QtCore/qstringalgorithms.h>
|
||||
#include <QtCore/qstringview.h>
|
||||
|
||||
#include <string>
|
||||
#include <iterator>
|
||||
@ -73,10 +76,6 @@ Q_FORWARD_DECLARE_CF_TYPE(CFString);
|
||||
Q_FORWARD_DECLARE_OBJC_CLASS(NSString);
|
||||
#endif
|
||||
|
||||
#ifndef QT_STRINGVIEW_LEVEL
|
||||
# define QT_STRINGVIEW_LEVEL 1
|
||||
#endif
|
||||
|
||||
QT_BEGIN_NAMESPACE
|
||||
|
||||
class QCharRef;
|
||||
@ -87,20 +86,8 @@ class QString;
|
||||
class QStringList;
|
||||
class QTextCodec;
|
||||
class QStringRef;
|
||||
class QStringView;
|
||||
class QLatin1String;
|
||||
template <typename T> class QVector;
|
||||
|
||||
Q_CORE_EXPORT Q_DECL_PURE_FUNCTION int qCompareStrings(QStringView lhs, QStringView rhs, Qt::CaseSensitivity cs = Qt::CaseSensitive) Q_DECL_NOTHROW Q_REQUIRED_RESULT;
|
||||
Q_CORE_EXPORT Q_DECL_PURE_FUNCTION int qCompareStrings(QStringView lhs, QLatin1String rhs, Qt::CaseSensitivity cs = Qt::CaseSensitive) Q_DECL_NOTHROW Q_REQUIRED_RESULT;
|
||||
Q_CORE_EXPORT Q_DECL_PURE_FUNCTION int qCompareStrings(QLatin1String lhs, QStringView rhs, Qt::CaseSensitivity cs = Qt::CaseSensitive) Q_DECL_NOTHROW Q_REQUIRED_RESULT;
|
||||
Q_CORE_EXPORT Q_DECL_PURE_FUNCTION int qCompareStrings(QLatin1String lhs, QLatin1String rhs, Qt::CaseSensitivity cs = Qt::CaseSensitive) Q_DECL_NOTHROW Q_REQUIRED_RESULT;
|
||||
|
||||
Q_CORE_EXPORT QByteArray qConvertToLatin1(QStringView str) Q_REQUIRED_RESULT;
|
||||
Q_CORE_EXPORT QByteArray qConvertToUtf8(QStringView str) Q_REQUIRED_RESULT;
|
||||
Q_CORE_EXPORT QByteArray qConvertToLocal8Bit(QStringView str) Q_REQUIRED_RESULT;
|
||||
Q_CORE_EXPORT QVector<uint> qConvertToUcs4(QStringView str) Q_REQUIRED_RESULT;
|
||||
|
||||
class QLatin1String
|
||||
{
|
||||
public:
|
||||
@ -192,74 +179,6 @@ Q_DECLARE_TYPEINFO(QLatin1String, Q_MOVABLE_TYPE);
|
||||
// Qt 4.x compatibility
|
||||
typedef QLatin1String QLatin1Literal;
|
||||
|
||||
|
||||
typedef QTypedArrayData<ushort> QStringData;
|
||||
|
||||
#if defined(Q_OS_WIN) && !defined(Q_COMPILER_UNICODE_STRINGS)
|
||||
// fall back to wchar_t if the a Windows compiler does not
|
||||
// support Unicode string literals, assuming wchar_t is 2 bytes
|
||||
// on that platform (sanity-checked by static_assert further below)
|
||||
|
||||
#if defined(Q_CC_MSVC)
|
||||
# define QT_UNICODE_LITERAL_II(str) L##str
|
||||
#else
|
||||
# define QT_UNICODE_LITERAL_II(str) L"" str
|
||||
#endif
|
||||
typedef wchar_t qunicodechar;
|
||||
|
||||
#else
|
||||
// all our supported compilers support Unicode string literals,
|
||||
// even if their Q_COMPILER_UNICODE_STRING has been revoked due
|
||||
// to lacking stdlib support. But QStringLiteral only needs the
|
||||
// core language feature, so just use u"" here unconditionally:
|
||||
|
||||
#define QT_UNICODE_LITERAL_II(str) u"" str
|
||||
typedef char16_t qunicodechar;
|
||||
|
||||
#endif
|
||||
|
||||
Q_STATIC_ASSERT_X(sizeof(qunicodechar) == 2,
|
||||
"qunicodechar must typedef an integral type of size 2");
|
||||
|
||||
#define QT_UNICODE_LITERAL(str) QT_UNICODE_LITERAL_II(str)
|
||||
#define QStringLiteral(str) \
|
||||
([]() Q_DECL_NOEXCEPT -> QString { \
|
||||
enum { Size = sizeof(QT_UNICODE_LITERAL(str))/2 - 1 }; \
|
||||
static const QStaticStringData<Size> qstring_literal = { \
|
||||
Q_STATIC_STRING_DATA_HEADER_INITIALIZER(Size), \
|
||||
QT_UNICODE_LITERAL(str) }; \
|
||||
QStringDataPtr holder = { qstring_literal.data_ptr() }; \
|
||||
const QString qstring_literal_temp(holder); \
|
||||
return qstring_literal_temp; \
|
||||
}()) \
|
||||
/**/
|
||||
|
||||
#define Q_STATIC_STRING_DATA_HEADER_INITIALIZER_WITH_OFFSET(size, offset) \
|
||||
{ Q_REFCOUNT_INITIALIZE_STATIC, size, 0, 0, offset } \
|
||||
/**/
|
||||
|
||||
#define Q_STATIC_STRING_DATA_HEADER_INITIALIZER(size) \
|
||||
Q_STATIC_STRING_DATA_HEADER_INITIALIZER_WITH_OFFSET(size, sizeof(QStringData)) \
|
||||
/**/
|
||||
|
||||
template <int N>
|
||||
struct QStaticStringData
|
||||
{
|
||||
QArrayData str;
|
||||
qunicodechar data[N + 1];
|
||||
|
||||
QStringData *data_ptr() const
|
||||
{
|
||||
Q_ASSERT(str.ref.isStatic());
|
||||
return const_cast<QStringData *>(static_cast<const QStringData*>(&str));
|
||||
}
|
||||
};
|
||||
|
||||
struct QStringDataPtr
|
||||
{
|
||||
QStringData *ptr;
|
||||
};
|
||||
|
||||
class Q_CORE_EXPORT QString
|
||||
{
|
||||
public:
|
||||
@ -945,6 +864,15 @@ public:
|
||||
inline DataPtr &data_ptr() { return d; }
|
||||
};
|
||||
|
||||
//
|
||||
// QStringView inline members that require QString:
|
||||
//
|
||||
QString QStringView::toString() const
|
||||
{ return Q_ASSERT(size() == length()), QString(data(), length()); }
|
||||
|
||||
//
|
||||
// QString inline members
|
||||
//
|
||||
inline QString::QString(QLatin1String aLatin1) : d(fromLatin1_helper(aLatin1.latin1(), aLatin1.size()))
|
||||
{ }
|
||||
inline int QString::length() const
|
||||
@ -1623,10 +1551,6 @@ inline QStringRef::QStringRef(const QString *aString, int aPosition, int aSize)
|
||||
inline QStringRef::QStringRef(const QString *aString)
|
||||
:m_string(aString), m_position(0), m_size(aString?aString->size() : 0){}
|
||||
|
||||
QT_BEGIN_INCLUDE_NAMESPACE
|
||||
#include <QtCore/qstringview.h>
|
||||
QT_END_INCLUDE_NAMESPACE
|
||||
|
||||
// QStringRef <> QStringRef
|
||||
Q_CORE_EXPORT bool operator==(const QStringRef &s1, const QStringRef &s2) Q_DECL_NOTHROW;
|
||||
inline bool operator!=(const QStringRef &s1, const QStringRef &s2) Q_DECL_NOTHROW
|
||||
|
68
src/corelib/tools/qstringalgorithms.h
Normal file
68
src/corelib/tools/qstringalgorithms.h
Normal file
@ -0,0 +1,68 @@
|
||||
/****************************************************************************
|
||||
**
|
||||
** Copyright (C) 2017 Klarälvdalens Datakonsult AB, a KDAB Group company, info@kdab.com, author Marc Mutz <marc.mutz@kdab.com>
|
||||
** Contact: https://www.qt.io/licensing/
|
||||
**
|
||||
** This file is part of the QtCore module of the Qt Toolkit.
|
||||
**
|
||||
** $QT_BEGIN_LICENSE:LGPL$
|
||||
** Commercial License Usage
|
||||
** Licensees holding valid commercial Qt licenses may use this file in
|
||||
** accordance with the commercial license agreement provided with the
|
||||
** Software or, alternatively, in accordance with the terms contained in
|
||||
** a written agreement between you and The Qt Company. For licensing terms
|
||||
** and conditions see https://www.qt.io/terms-conditions. For further
|
||||
** information use the contact form at https://www.qt.io/contact-us.
|
||||
**
|
||||
** GNU Lesser General Public License Usage
|
||||
** Alternatively, this file may be used under the terms of the GNU Lesser
|
||||
** General Public License version 3 as published by the Free Software
|
||||
** Foundation and appearing in the file LICENSE.LGPL3 included in the
|
||||
** packaging of this file. Please review the following information to
|
||||
** ensure the GNU Lesser General Public License version 3 requirements
|
||||
** will be met: https://www.gnu.org/licenses/lgpl-3.0.html.
|
||||
**
|
||||
** GNU General Public License Usage
|
||||
** Alternatively, this file may be used under the terms of the GNU
|
||||
** General Public License version 2.0 or (at your option) the GNU General
|
||||
** Public license version 3 or any later version approved by the KDE Free
|
||||
** Qt Foundation. The licenses are as published by the Free Software
|
||||
** Foundation and appearing in the file LICENSE.GPL2 and LICENSE.GPL3
|
||||
** included in the packaging of this file. Please review the following
|
||||
** information to ensure the GNU General Public License requirements will
|
||||
** be met: https://www.gnu.org/licenses/gpl-2.0.html and
|
||||
** https://www.gnu.org/licenses/gpl-3.0.html.
|
||||
**
|
||||
** $QT_END_LICENSE$
|
||||
**
|
||||
****************************************************************************/
|
||||
|
||||
#ifndef QSTRINGALGORITHMS_H
|
||||
#define QSTRINGALGORITHMS_H
|
||||
|
||||
#include <QtCore/qnamespace.h>
|
||||
|
||||
#if 0
|
||||
#pragma qt_class(QStringAlgorithms)
|
||||
#endif
|
||||
|
||||
QT_BEGIN_NAMESPACE
|
||||
|
||||
class QByteArray;
|
||||
class QLatin1String;
|
||||
class QStringView;
|
||||
template <typename T> class QVector;
|
||||
|
||||
Q_CORE_EXPORT Q_DECL_PURE_FUNCTION int qCompareStrings(QStringView lhs, QStringView rhs, Qt::CaseSensitivity cs = Qt::CaseSensitive) Q_DECL_NOTHROW Q_REQUIRED_RESULT;
|
||||
Q_CORE_EXPORT Q_DECL_PURE_FUNCTION int qCompareStrings(QStringView lhs, QLatin1String rhs, Qt::CaseSensitivity cs = Qt::CaseSensitive) Q_DECL_NOTHROW Q_REQUIRED_RESULT;
|
||||
Q_CORE_EXPORT Q_DECL_PURE_FUNCTION int qCompareStrings(QLatin1String lhs, QStringView rhs, Qt::CaseSensitivity cs = Qt::CaseSensitive) Q_DECL_NOTHROW Q_REQUIRED_RESULT;
|
||||
Q_CORE_EXPORT Q_DECL_PURE_FUNCTION int qCompareStrings(QLatin1String lhs, QLatin1String rhs, Qt::CaseSensitivity cs = Qt::CaseSensitive) Q_DECL_NOTHROW Q_REQUIRED_RESULT;
|
||||
|
||||
Q_CORE_EXPORT QByteArray qConvertToLatin1(QStringView str) Q_REQUIRED_RESULT;
|
||||
Q_CORE_EXPORT QByteArray qConvertToUtf8(QStringView str) Q_REQUIRED_RESULT;
|
||||
Q_CORE_EXPORT QByteArray qConvertToLocal8Bit(QStringView str) Q_REQUIRED_RESULT;
|
||||
Q_CORE_EXPORT QVector<uint> qConvertToUcs4(QStringView str) Q_REQUIRED_RESULT;
|
||||
|
||||
QT_END_NAMESPACE
|
||||
|
||||
#endif // QSTRINGALGORTIHMS_H
|
128
src/corelib/tools/qstringliteral.h
Normal file
128
src/corelib/tools/qstringliteral.h
Normal file
@ -0,0 +1,128 @@
|
||||
/****************************************************************************
|
||||
**
|
||||
** Copyright (C) 2016 The Qt Company Ltd.
|
||||
** Copyright (C) 2016 Intel Corporation.
|
||||
** Contact: https://www.qt.io/licensing/
|
||||
**
|
||||
** This file is part of the QtCore module of the Qt Toolkit.
|
||||
**
|
||||
** $QT_BEGIN_LICENSE:LGPL$
|
||||
** Commercial License Usage
|
||||
** Licensees holding valid commercial Qt licenses may use this file in
|
||||
** accordance with the commercial license agreement provided with the
|
||||
** Software or, alternatively, in accordance with the terms contained in
|
||||
** a written agreement between you and The Qt Company. For licensing terms
|
||||
** and conditions see https://www.qt.io/terms-conditions. For further
|
||||
** information use the contact form at https://www.qt.io/contact-us.
|
||||
**
|
||||
** GNU Lesser General Public License Usage
|
||||
** Alternatively, this file may be used under the terms of the GNU Lesser
|
||||
** General Public License version 3 as published by the Free Software
|
||||
** Foundation and appearing in the file LICENSE.LGPL3 included in the
|
||||
** packaging of this file. Please review the following information to
|
||||
** ensure the GNU Lesser General Public License version 3 requirements
|
||||
** will be met: https://www.gnu.org/licenses/lgpl-3.0.html.
|
||||
**
|
||||
** GNU General Public License Usage
|
||||
** Alternatively, this file may be used under the terms of the GNU
|
||||
** General Public License version 2.0 or (at your option) the GNU General
|
||||
** Public license version 3 or any later version approved by the KDE Free
|
||||
** Qt Foundation. The licenses are as published by the Free Software
|
||||
** Foundation and appearing in the file LICENSE.GPL2 and LICENSE.GPL3
|
||||
** included in the packaging of this file. Please review the following
|
||||
** information to ensure the GNU General Public License requirements will
|
||||
** be met: https://www.gnu.org/licenses/gpl-2.0.html and
|
||||
** https://www.gnu.org/licenses/gpl-3.0.html.
|
||||
**
|
||||
** $QT_END_LICENSE$
|
||||
**
|
||||
****************************************************************************/
|
||||
|
||||
#ifndef QSTRINGLITERAL_H
|
||||
#define QSTRINGLITERAL_H
|
||||
|
||||
#include <QtCore/qarraydata.h>
|
||||
|
||||
#if 0
|
||||
#pragma qt_class(QStringLiteral)
|
||||
#endif
|
||||
|
||||
QT_BEGIN_NAMESPACE
|
||||
|
||||
typedef QTypedArrayData<ushort> QStringData;
|
||||
|
||||
#if defined(Q_OS_WIN) && !defined(Q_COMPILER_UNICODE_STRINGS)
|
||||
// fall back to wchar_t if the a Windows compiler does not
|
||||
// support Unicode string literals, assuming wchar_t is 2 bytes
|
||||
// on that platform (sanity-checked by static_assert further below)
|
||||
|
||||
#if defined(Q_CC_MSVC)
|
||||
# define QT_UNICODE_LITERAL_II(str) L##str
|
||||
#else
|
||||
# define QT_UNICODE_LITERAL_II(str) L"" str
|
||||
#endif
|
||||
typedef wchar_t qunicodechar;
|
||||
|
||||
#else
|
||||
// all our supported compilers support Unicode string literals,
|
||||
// even if their Q_COMPILER_UNICODE_STRING has been revoked due
|
||||
// to lacking stdlib support. But QStringLiteral only needs the
|
||||
// core language feature, so just use u"" here unconditionally:
|
||||
|
||||
#define QT_UNICODE_LITERAL_II(str) u"" str
|
||||
typedef char16_t qunicodechar;
|
||||
|
||||
#endif
|
||||
|
||||
Q_STATIC_ASSERT_X(sizeof(qunicodechar) == 2,
|
||||
"qunicodechar must typedef an integral type of size 2");
|
||||
|
||||
#define QT_UNICODE_LITERAL(str) QT_UNICODE_LITERAL_II(str)
|
||||
#define QStringLiteral(str) \
|
||||
([]() Q_DECL_NOEXCEPT -> QString { \
|
||||
enum { Size = sizeof(QT_UNICODE_LITERAL(str))/2 - 1 }; \
|
||||
static const QStaticStringData<Size> qstring_literal = { \
|
||||
Q_STATIC_STRING_DATA_HEADER_INITIALIZER(Size), \
|
||||
QT_UNICODE_LITERAL(str) }; \
|
||||
QStringDataPtr holder = { qstring_literal.data_ptr() }; \
|
||||
const QString qstring_literal_temp(holder); \
|
||||
return qstring_literal_temp; \
|
||||
}()) \
|
||||
/**/
|
||||
|
||||
#define Q_STATIC_STRING_DATA_HEADER_INITIALIZER_WITH_OFFSET(size, offset) \
|
||||
{ Q_REFCOUNT_INITIALIZE_STATIC, size, 0, 0, offset } \
|
||||
/**/
|
||||
|
||||
#define Q_STATIC_STRING_DATA_HEADER_INITIALIZER(size) \
|
||||
Q_STATIC_STRING_DATA_HEADER_INITIALIZER_WITH_OFFSET(size, sizeof(QStringData)) \
|
||||
/**/
|
||||
|
||||
#ifndef QT_NO_UNICODE_LITERAL
|
||||
# ifndef QT_UNICODE_LITERAL
|
||||
# error "If you change QStringLiteral, please change QStringViewLiteral, too"
|
||||
# endif
|
||||
# define QStringViewLiteral(str) QStringView(QT_UNICODE_LITERAL(str))
|
||||
#endif
|
||||
|
||||
template <int N>
|
||||
struct QStaticStringData
|
||||
{
|
||||
QArrayData str;
|
||||
qunicodechar data[N + 1];
|
||||
|
||||
QStringData *data_ptr() const
|
||||
{
|
||||
Q_ASSERT(str.ref.isStatic());
|
||||
return const_cast<QStringData *>(static_cast<const QStringData*>(&str));
|
||||
}
|
||||
};
|
||||
|
||||
struct QStringDataPtr
|
||||
{
|
||||
QStringData *ptr;
|
||||
};
|
||||
|
||||
QT_END_NAMESPACE
|
||||
|
||||
#endif // QSTRINGLITERAL_H
|
@ -36,24 +36,24 @@
|
||||
** $QT_END_LICENSE$
|
||||
**
|
||||
****************************************************************************/
|
||||
|
||||
#ifndef QSTRING_H
|
||||
# include <QtCore/qstring.h>
|
||||
#endif
|
||||
|
||||
#ifndef QSTRINGVIEW_H
|
||||
#define QSTRINGVIEW_H
|
||||
|
||||
#ifndef QT_STRINGVIEW_LEVEL
|
||||
# define QT_STRINGVIEW_LEVEL 1
|
||||
#endif
|
||||
|
||||
#include <QtCore/qchar.h>
|
||||
#include <QtCore/qbytearray.h>
|
||||
#include <QtCore/qstringliteral.h>
|
||||
#include <QtCore/qstringalgorithms.h>
|
||||
|
||||
#include <string>
|
||||
|
||||
QT_BEGIN_NAMESPACE
|
||||
|
||||
#ifndef QT_NO_UNICODE_LITERAL
|
||||
# ifndef QT_UNICODE_LITERAL
|
||||
# error "If you change QStringLiteral, please change QStringViewLiteral, too"
|
||||
# endif
|
||||
# define QStringViewLiteral(str) QStringView(QT_UNICODE_LITERAL(str))
|
||||
#endif
|
||||
class QString;
|
||||
class QStringRef;
|
||||
|
||||
namespace QtPrivate {
|
||||
template <typename Char>
|
||||
@ -205,7 +205,7 @@ public:
|
||||
QStringView(const StdBasicString &str) Q_DECL_NOTHROW
|
||||
: QStringView(str.data(), qssize_t(str.size())) {}
|
||||
|
||||
Q_REQUIRED_RESULT QString toString() const { return Q_ASSERT(size() == length()), QString(data(), length()); }
|
||||
Q_REQUIRED_RESULT inline QString toString() const; // defined in qstring.h
|
||||
|
||||
Q_REQUIRED_RESULT Q_DECL_CONSTEXPR qssize_t size() const Q_DECL_NOTHROW { return m_size; }
|
||||
Q_REQUIRED_RESULT const_pointer data() const Q_DECL_NOTHROW { return reinterpret_cast<const_pointer>(m_data); }
|
||||
@ -221,7 +221,7 @@ public:
|
||||
Q_REQUIRED_RESULT QByteArray toLatin1() const { return qConvertToLatin1(*this); }
|
||||
Q_REQUIRED_RESULT QByteArray toUtf8() const { return qConvertToUtf8(*this); }
|
||||
Q_REQUIRED_RESULT QByteArray toLocal8Bit() const { return qConvertToLocal8Bit(*this); }
|
||||
Q_REQUIRED_RESULT inline QVector<uint> toUcs4() const;
|
||||
Q_REQUIRED_RESULT inline QVector<uint> toUcs4() const; // defined in qvector.h
|
||||
|
||||
Q_REQUIRED_RESULT Q_DECL_CONSTEXPR QChar at(qssize_t n) const { return (*this)[n]; }
|
||||
|
||||
|
@ -57,10 +57,12 @@ HEADERS += \
|
||||
tools/qsize.h \
|
||||
tools/qstack.h \
|
||||
tools/qstring.h \
|
||||
tools/qstringalgorithms.h \
|
||||
tools/qstringalgorithms_p.h \
|
||||
tools/qstringbuilder.h \
|
||||
tools/qstringiterator_p.h \
|
||||
tools/qstringlist.h \
|
||||
tools/qstringliteral.h \
|
||||
tools/qstringmatcher.h \
|
||||
tools/qstringview.h \
|
||||
tools/qtextboundaryfinder.h \
|
||||
|
Loading…
Reference in New Issue
Block a user