Index: sources/model/dg/data/MDGLoadCellReadingsData.cpp =================================================================== diff -u -r2ef03b2ce51b4dc507f66e9671953a8e0824bde9 -ra09c1a91b8eaf9d7164ba7f274d4ccd557c05f22 --- sources/model/dg/data/MDGLoadCellReadingsData.cpp (.../MDGLoadCellReadingsData.cpp) (revision 2ef03b2ce51b4dc507f66e9671953a8e0824bde9) +++ sources/model/dg/data/MDGLoadCellReadingsData.cpp (.../MDGLoadCellReadingsData.cpp) (revision a09c1a91b8eaf9d7164ba7f274d4ccd557c05f22) @@ -27,15 +27,17 @@ bool MDGLoadCellReadings::fromByteArray(const QByteArray &vByteArray, int *vIndex) { int index = 0; // message data start position - if (GetValue(vByteArray, index, _data.mReservoir1Prim )) - if (GetValue(vByteArray, index, _data.mReservoir1Bkup )) - if (GetValue(vByteArray, index, _data.mReservoir2Prim )) - if (GetValue(vByteArray, index, _data.mReservoir2Bkup )) - return true ; - else { if(vIndex) *vIndex = index; return false; } - else { if(vIndex) *vIndex = index; return false; } - else { if(vIndex) *vIndex = index; return false; } - else { if(vIndex) *vIndex = index; return false; } + if ( ! GetValue(vByteArray, index, _data.mReservoir1Prim )) goto lError; + if ( ! GetValue(vByteArray, index, _data.mReservoir1Bkup )) goto lError; + if ( ! GetValue(vByteArray, index, _data.mReservoir2Prim )) goto lError; + if ( ! GetValue(vByteArray, index, _data.mReservoir2Bkup )) goto lError; + + return true ; + +lError: + if(vIndex) { *vIndex = index; } + + return false ; } /*!