qt6-bb10/src/gui/kernel/qguivariant.cpp

146 lines
4.6 KiB
C++

// Copyright (C) 2020 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only
// Gui types
#include "qbitmap.h"
#include "qbrush.h"
#include "qcolor.h"
#include "qcolorspace.h"
#include "qcursor.h"
#include "qfont.h"
#include "qimage.h"
#if QT_CONFIG(shortcut)
# include "qkeysequence.h"
#endif
#include "qtransform.h"
#include "qpalette.h"
#include "qpen.h"
#include "qpixmap.h"
#include "qpolygon.h"
#include "qregion.h"
#include "qtextformat.h"
#include "qmatrix4x4.h"
#include "qvector2d.h"
#include "qvector3d.h"
#include "qvector4d.h"
#include "qquaternion.h"
#include "qicon.h"
// Core types
#include "qvariant.h"
#include "qbitarray.h"
#include "qbytearray.h"
#include "qdatastream.h"
#include "qdebug.h"
#include "qmap.h"
#include "qdatetime.h"
#include "qlist.h"
#include "qstring.h"
#include "qstringlist.h"
#include "qurl.h"
#include "qlocale.h"
#include "quuid.h"
#ifndef QT_NO_GEOM_VARIANT
#include "qsize.h"
#include "qpoint.h"
#include "qrect.h"
#include "qline.h"
#endif
#include <float.h>
#include <private/qmetatype_p.h>
QT_BEGIN_NAMESPACE
namespace {
static const struct : QMetaTypeModuleHelper
{
#define QT_IMPL_METATYPEINTERFACE_GUI_TYPES(MetaTypeName, MetaTypeId, RealName) \
QT_METATYPE_INTERFACE_INIT(RealName),
const QtPrivate::QMetaTypeInterface *interfaceForType(int type) const override {
switch (type) {
QT_FOR_EACH_STATIC_GUI_CLASS(QT_METATYPE_CONVERT_ID_TO_TYPE)
default: return nullptr;
}
}
#undef QT_IMPL_METATYPEINTERFACE_GUI_TYPES
bool convert(const void *from, int fromTypeId, void *to, int toTypeId) const override
{
Q_ASSERT(fromTypeId != toTypeId);
bool onlyCheck = (from == nullptr && to == nullptr);
// either two nullptrs from canConvert, or two valid pointers
Q_ASSERT(onlyCheck || (bool(from) && bool(to)));
using Int = int;
switch (makePair(toTypeId, fromTypeId)) {
QMETATYPE_CONVERTER(QByteArray, QColor,
result = source.name(source.alpha() != 255 ?
QColor::HexArgb : QColor::HexRgb).toLatin1();
return true;
);
QMETATYPE_CONVERTER(QColor, QByteArray,
result = QColor::fromString(QLatin1StringView(source));
return result.isValid();
);
QMETATYPE_CONVERTER(QString, QColor,
result = source.name(source.alpha() != 255 ?
QColor::HexArgb : QColor::HexRgb);
return true;
);
QMETATYPE_CONVERTER(QColor, QString,
result = QColor::fromString(source);
return result.isValid();
);
#if QT_CONFIG(shortcut)
QMETATYPE_CONVERTER(QString, QKeySequence,
result = source.toString(QKeySequence::NativeText);
return true;
);
QMETATYPE_CONVERTER(QKeySequence, QString, result = source; return true;);
QMETATYPE_CONVERTER(Int, QKeySequence,
result = source.isEmpty() ? 0 : source[0].toCombined();
return true;
);
QMETATYPE_CONVERTER(QKeySequence, Int, result = source; return true;);
#endif
QMETATYPE_CONVERTER(QString, QFont, result = source.toString(); return true;);
QMETATYPE_CONVERTER(QFont, QString, return result.fromString(source););
QMETATYPE_CONVERTER(QPixmap, QImage, result = QPixmap::fromImage(source); return true;);
QMETATYPE_CONVERTER(QImage, QPixmap, result = source.toImage(); return true;);
QMETATYPE_CONVERTER(QPixmap, QBitmap, result = source; return true;);
QMETATYPE_CONVERTER(QBitmap, QPixmap, result = QBitmap::fromPixmap(source); return true;);
QMETATYPE_CONVERTER(QImage, QBitmap, result = source.toImage(); return true;);
QMETATYPE_CONVERTER(QBitmap, QImage, result = QBitmap::fromImage(source); return true;);
QMETATYPE_CONVERTER(QPixmap, QBrush, result = source.texture(); return true;);
QMETATYPE_CONVERTER(QBrush, QPixmap, result = source; return true;);
QMETATYPE_CONVERTER(QColor, QBrush,
if (source.style() == Qt::SolidPattern) {
result = source.color();
return true;
}
return false;
);
QMETATYPE_CONVERTER(QBrush, QColor, result = source; return true;);
default:
break;
}
return false;
}
} qVariantGuiHelper;
} // namespace used to hide QVariant handler
void qRegisterGuiVariant()
{
qMetaTypeGuiHelper = &qVariantGuiHelper;
}
Q_CONSTRUCTOR_FUNCTION(qRegisterGuiVariant)
QT_END_NAMESPACE