Index: sources/applicationcontroller.cpp =================================================================== diff -u -r805119c460b4a266d6401c8705f4427e7fbe270f -r6c59703781373f33cfec27eacf1f7e4ba1374626 --- sources/applicationcontroller.cpp (.../applicationcontroller.cpp) (revision 805119c460b4a266d6401c8705f4427e7fbe270f) +++ sources/applicationcontroller.cpp (.../applicationcontroller.cpp) (revision 6c59703781373f33cfec27eacf1f7e4ba1374626) @@ -109,6 +109,8 @@ connect(&_Logger , SIGNAL(didExport()), this , SLOT( onExport())); + + ACTION_RECEIVE_MODEL_BRIDGE_CONNECTIONS(_MessageDispatcher) } /*! @@ -236,7 +238,124 @@ { #ifndef DISABLE_KEEP_ALIVE QVariantList mData; - mData += static_cast(GuiActionData::NoData); + int mFakeDataLen = gFakeData.length(); + if (mFakeDataLen) { + if (gFakeSeqAtBegin) { + createFakeSeqAtBeginLongMessage(mData, mFakeDataLen); + } else { + createFakeSequencedLongMessage (mData, mFakeDataLen); + } + } else { + mData += static_cast(GuiActionData::NoData); + } onActionTransmit(GuiActionType::KeepAlive, mData); #endif } + +/*! + * \brief ApplicationController::createFakeSequencedLongMessage + * \details This method is creating the fake message with frame sequence + * which we use for Denali Message test + * \param vFakeDataLen + */ +void ApplicationController::createFakeSequencedLongMessage(QVariantList &vData, const int vFakeDataLen) +{ + QByteArray data; + if (vFakeDataLen == 1 && gFakeData == QByteArray::fromHex(gFakeData_default)) { + static quint16 txCount = 0; + Types::U16 seq; + quint8 dataBytesLeft = 0; + const quint8 crcBytesLen = 2; + for (int i = 0; i < 13; i++) { + switch (i) { + case 0: // First frame : HEAD + seq.value = txCount; + data += seq.bytes[0]; + data += seq.bytes[1]; + break; + + case 12: // Last frame with CRC + dataBytesLeft = 8 - sizeof(seq) - crcBytesLen; + for (int j = 0; j < dataBytesLeft; j++) { + data += (char)(0); + } + seq.value = txCount; + data += seq.bytes[0]; + data += seq.bytes[1]; + break; + + default: // Middle Frames + dataBytesLeft = 8 - sizeof(seq); + for (int j = 0; j < dataBytesLeft; j++) { + data += (char)(0); + } + seq.value = txCount; + data += seq.bytes[0]; + data += seq.bytes[1]; + break; + + } + Types::safeIncrement(txCount); + } + vData += QByteArray::fromHex(data.toHex()); + } else { + vData += gFakeData; + } +} + +/*! + * \brief ApplicationController::createFakeSequencedAtBeginLongMessage + * \details This method is creating the fake message with frame sequence + * which we use for Denali Message test + * \param vFakeDataLen + */ +void ApplicationController::createFakeSeqAtBeginLongMessage(QVariantList &vData, const int vFakeDataLen) +{ + QByteArray data; + if (vFakeDataLen == 1 && gFakeData == QByteArray::fromHex(gFakeData_default)) { + static quint32 txCount = 0; + Types::U32 seq; + quint8 dataBytesLeft = 0; + const quint8 crcBytesLen = 2; + for (int i = 0; i < 13; i++) { + switch (i) { + case 0: // First frame : HEAD + seq.value = txCount; + data += seq.bytes[0]; + data += seq.bytes[1]; + //data += seq.bytes[3]; // Chopped off + //data += seq.bytes[4]; // Chopped off + break; + + case 12: // Last frame with CRC + seq.value = txCount; + data += seq.bytes[0]; + data += seq.bytes[1]; + data += seq.bytes[2]; + data += seq.bytes[3]; + dataBytesLeft = 8 - sizeof(seq) - crcBytesLen; + for (int j = 0; j < dataBytesLeft; j++) { + data += (char)(0); + } + break; + + default: // Middle Frames + dataBytesLeft = 8 - sizeof(seq); + seq.value = txCount; + data += seq.bytes[0]; + data += seq.bytes[1]; + data += seq.bytes[2]; + data += seq.bytes[3]; + for (int j = 0; j < dataBytesLeft; j++) { + data += (char)(0); + } + break; + + } + Types::safeIncrement(txCount); + } + vData += QByteArray::fromHex(data.toHex()); + } else { + vData += gFakeData; + } +}