Removed warning from fixQVariantFromDbusArgument.

@MS: Please crosscheck. In the past function was only called with QDBusArgument.
Now called from CVariant sometimes with standard variant types (QString, int).
Expected?
This commit is contained in:
Klaus Basan
2014-12-17 19:05:45 +01:00
parent bfced2ad42
commit 95df9edd52

View File

@@ -187,12 +187,14 @@ uint BlackMisc::calculateHash(const QList<int> &values, const char *className)
*/ */
QVariant BlackMisc::fixQVariantFromDbusArgument(const QVariant &variant, int localUserType) QVariant BlackMisc::fixQVariantFromDbusArgument(const QVariant &variant, int localUserType)
{ {
if (variant.canConvert<QDBusArgument>()) // my business?
{ if (!variant.canConvert<QDBusArgument>()) { return variant; }
// complex, user type // complex, user type
// it has to be made sure, that the cast works // it has to be made sure, that the cast works
const QDBusArgument arg = variant.value<QDBusArgument>(); const QDBusArgument arg = variant.value<QDBusArgument>();
if (localUserType < static_cast<int>(QVariant::UserType)) const int userType = static_cast<int>(QVariant::UserType);
if (localUserType < userType)
{ {
// complex Qt type, e.g. QDateTime // complex Qt type, e.g. QDateTime
return BlackMisc::complexQtTypeFromDbusArgument(arg, localUserType); return BlackMisc::complexQtTypeFromDbusArgument(arg, localUserType);
@@ -206,10 +208,9 @@ QVariant BlackMisc::fixQVariantFromDbusArgument(const QVariant &variant, int loc
meta->unmarshall(arg, valueVariant.data()); meta->unmarshall(arg, valueVariant.data());
return valueVariant; return valueVariant;
} }
Q_ASSERT_X(false, "fixQVariantFromDbusArgument", "no meta");
return valueVariant;
} }
}
qWarning() << "fixQVariantFromDbusArgument called with unsupported type";
return variant;
} }
/* /*