На основе комментария @RossRogers я создал следующий метод:
header:
Q_INVOKABLE static void log(LogLevel l,
QString m,
QVariant v1 = QVariant(),
QVariant v2 = QVariant(),
QVariant v3 = QVariant());
source:
* @brief A QML enabled wrapper function for the logger trace method. It
* allows to use the trace (printf style) in QML with up to 3
* parsable arguments.
* @param l: trace log level.
* @param m: message to be printed.
* @param v1: oprional parsable param 1.
* @param v2: oprional parsable param 2.
* @param v3: oprional parsable param 3.
*/
void CSystem::log(LogLevel l, QString m, QVariant v1, QVariant v2, QVariant v3)
{
CLogger::instance().trace(l, std::move(m),
std::move(v1), std::move(v2), std::move(v3));
}
Это очень грязно, и скорее всего, сейчас очень эффективный обходной путь, который позволяет анализировать до 3 значений. Внутри метода trace
я опускаю недопустимые объекты QVariant
.