// 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 #include "private/qvariant_p.h" #include 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