| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566 | /*= StarPU-Top for StarPU =Copyright (C) 2011 William BraikYann CourtoisJean-Marie CouteyenAnthony RoyThis library is free software; you can redistribute it and/ormodify it under the terms of the GNU Lesser General PublicLicense as published by the Free Software Foundation; eitherversion 2.1 of the License, or (at your option) any later version.This library is distributed in the hope that it will be useful,but WITHOUT ANY WARRANTY; without even the implied warranty ofMERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNULesser General Public License for more details.You should have received a copy of the GNU Lesser General PublicLicense along with this library; if not, write to the Free SoftwareFoundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA*/#include "communicationmanager.h"// Protocol messages delimitersconst char COM_MSG_SEPARATOR = ';';const char COM_MSG_ENDL = '\n';CommunicationManager::CommunicationManager(QObject *parent) :	QTcpSocket(parent){    static bool instanciated = false;    Q_ASSERT_X(instanciated == false, "CommunicationManager's' constructor",               "Singleton pattern violated - "               "CommunicationManager instanciated more than once");    qDebug() << "CommunicationManager : initializing";    // Init incoming messages    initInMessageStrings();    // Init outgoing messages    initOutMessageStrings();    // Init session data and communication states    initializeSession();    QObject::connect(this, SIGNAL(readyRead()), this,                     SLOT(messageReceived()));    QObject::connect(this, SIGNAL(disconnected()), this,                     SLOT(clearDescriptions()));    QObject::connect(this, SIGNAL(disconnected()), this,                     SLOT(initializeSession()));    instanciated = true;}CommunicationManager::~CommunicationManager(){    qDebug() << "CommunicationManager : terminating";    delete _dataDescriptions;    delete _paramDescriptions;    delete _serverDevices;}void CommunicationManager::initializeSession(){    _dataDescriptions = new QList<DataDescription*> ();    _paramDescriptions = new QList<ParamDescription*> ();    _serverDevices = new QList<starpu_top_device> ;    _serverInfoMsgCount = 0;    _state = COM_STATE_INIT;    _initServerInfoCompleted = _initDataCompleted = _initParamsCompleted                                                    = _initDevCompleted = false;}/* -------------------------------------------------------------------------- *//* Receive messages                                                           *//* -------------------------------------------------------------------------- */void CommunicationManager::messageReceived(){    while (canReadLine())    {        QByteArray message = readLine();        QString messageString = QString(message).trimmed();        switch (_state)        {        case COM_STATE_INIT:            {                if (_beginEndMessageStrings.contains(messageString))                {                    parseInitMessage(messageString);                }                else                {                    emit protocolError(                            "Unexpected message received in INIT ("                            + messageString                            + ")");                }                break;            }        case COM_STATE_INIT_SERVERINFO:            parseInitServerInfoMessage(messageString);            break;        case COM_STATE_INIT_DATA:            parseInitDataMessage(messageString);            break;        case COM_STATE_INIT_PARAMS:            parseInitParamsMessage(messageString);            break;        case COM_STATE_INIT_DEV:            parseInitDevMessage(messageString);            break;        case COM_STATE_READY:            parseReadyMessage(messageString);            break;        case COM_STATE_LOOP:            parseLoopMessage(messageString);            break;        }    }}/* -------------------------------------------------------------------------- *//* Parse messages                                                             *//* -------------------------------------------------------------------------- */void CommunicationManager::parseInitMessage(QString messageString){    switch (_inMessageStrings.value(messageString))    {    case COM_MSG_IN_SERVERINFO_BEGIN:        qDebug() << "CommunicationManager : SERVERINFO BEGIN received in INIT";        _state = COM_STATE_INIT_SERVERINFO;        break;    case COM_MSG_IN_DATA_BEGIN:        qDebug() << "CommunicationManager : DATA BEGIN received in INIT";        _state = COM_STATE_INIT_DATA;        break;    case COM_MSG_IN_PARAMS_BEGIN:        qDebug() << "CommunicationManager : PARAMS BEGIN received in INIT";        _state = COM_STATE_INIT_PARAMS;        break;    case COM_MSG_IN_DEV_BEGIN:        qDebug() << "CommunicationManager : DEV BEGIN received in INIT";        _state = COM_STATE_INIT_DEV;        break;    default:        ;    }}void CommunicationManager::parseInitServerInfoMessage(QString messageString){    if (_beginEndMessageStrings.contains(messageString))    {        if (_inMessageStrings.value(messageString) == COM_MSG_IN_SERVERINFO_END)        {            qDebug()                    << "CommunicationManager : "                    "SERVERINFO END received in INIT SERVERINFO";            _initServerInfoCompleted = true;	    emit protoConnected();            if (isInitCompleted())            {                _state = COM_STATE_READY;            }            else            {                _state = COM_STATE_INIT;            }        }        else        {            emit protocolError(                    "Bogus message received in INIT SERVERINFO ("                    + messageString + ")");        }    }    else if (_serverInfoMsgCount == 0)    { // First server info : Server ID        qDebug()                << "CommunicationManager : "                "SERVERINFO received in INIT SERVERINFO ("                << messageString + ")";        _serverID = messageString;        _serverInfoMsgCount++;    }    else if (_serverInfoMsgCount == 1)    { // Second server info : Server timestamp        qDebug()                << "CommunicationManager : "                "SERVERTIMESTAMP received in INIT SERVERINFO ("                << messageString + ")";        QString serverTimestampString = messageString;        bool ok = false;        qlonglong serverTimestamp = serverTimestampString.toLongLong(&ok);        Q_ASSERT_X(ok == true,                   "CommunicationManager::parseInitServerInfoMessage()",                   "Bogus SERVERTIMESTAMP received in INIT SERVERINFO");        emit(sessionTimeSynchronized(serverTimestamp));        _serverTimestamp = serverTimestamp;        _serverInfoMsgCount++;    }}void CommunicationManager::parseInitDataMessage(QString messageString){    if (_beginEndMessageStrings.contains(messageString))    {        if (_inMessageStrings.value(messageString) == COM_MSG_IN_DATA_END)        {            qDebug() << "CommunicationManager : DATA END received in INIT DATA";            _initDataCompleted = true;            if (isInitCompleted())            {                _state = COM_STATE_READY;            }            else            {                _state = COM_STATE_INIT;            }        }        else        {            emit protocolError(                    "Bogus message received in INIT DATA (" + messageString                    + ")");        }    }    else    {        QStringList messageParts = messageString.split(COM_MSG_SEPARATOR);        QString typeString = messageParts.at(0);        QString idString = messageParts.at(1);        bool ok = false;        int id = idString.toInt(&ok); // Data ID        Q_ASSERT_X(ok == true, "CommunicationManager::parseInitDataMessage()",                   "Bogus message received in INIT DATA");        QString description = messageParts.at(2); // Data description        DataType type;        DataWidgetType widget; // Data widget        double valMax = 0., valMin = 0.;        bool active;        Q_ASSERT_X(_typeMessageStrings.contains(typeString),                   "CommunicationManager::parseInitDataMessage()",                   "Bogus message received in INIT DATA");        switch (_inMessageStrings.value(typeString))        {        case COM_MSG_IN_TYPE_BOOL:            {                Q_ASSERT_X(messageParts.count() == 4,                           "CommunicationManager::parseInitDataMessage()",                           "Bogus message received in INIT DATA");                QString activeString = messageParts.at(3);                Q_ASSERT_X(                        (activeString.compare("0") == 0)                        || (activeString.compare("1") == 0),                        "CommunicationManager::parseInitDataMessage()",                        "Bogus message received in INIT DATA");                if (activeString.compare("1") == 0)                {                    active = true;                }                else                {                    active = false;                }                type = DATA_TYPE_BOOL;                widget = DEFAULT_DATA_WIDGET_BOOL;                break;            }        case COM_MSG_IN_TYPE_INT:            {                Q_ASSERT_X(messageParts.count() == 6,                           "CommunicationManager::parseInitDataMessage()",                           "Bogus message received in INIT DATA");                QString activeString = messageParts.at(5);                bool ok = false;                int activeInt = activeString.toInt(&ok);                Q_ASSERT_X(ok == true && (activeInt == 0 || activeInt == 1),                           "CommunicationManager::parseInitDataMessage()",                           "Bogus message received in INIT DATA");                if (activeInt == 1)                {                    active = true;                }                else                {                    active = false;                }                QString valMinString = messageParts.at(3);                valMin = valMinString.toDouble(&ok); // Data ID                Q_ASSERT_X(ok == true,                           "CommunicationManager::parseInitDataMessage()",                           "Bogus message received in INIT DATA");                QString valMaxString = messageParts.at(4);                valMax = valMaxString.toDouble(&ok);                Q_ASSERT_X(ok == true,                           "CommunicationManager::parseInitDataMessage()",                           "Bogus message received in INIT DATA");                type = DATA_TYPE_INT;                widget = DEFAULT_DATA_WIDGET_INT;                break;            }        case COM_MSG_IN_TYPE_FLOAT:            {                Q_ASSERT_X(messageParts.count() == 6,                           "CommunicationManager::parseInitDataMessage()",                           "Bogus message received in INIT DATA");                QString activeString = messageParts.at(5);                bool ok = false;                int activeInt = activeString.toInt(&ok);                Q_ASSERT_X(ok == true && (activeInt == 0 || activeInt == 1),                           "CommunicationManager::parseInitDataMessage()",                           "Bogus message received in INIT DATA");                if (activeInt == 1)                {                    active = true;                }                else                {                    active = false;                }                QString valMinString = messageParts.at(3);                valMin = valMinString.toDouble(&ok);                Q_ASSERT_X(ok == true,                           "CommunicationManager::parseInitDataMessage()",                           "Bogus message received in INIT DATA");                QString valMaxString = messageParts.at(4);                valMax = valMaxString.toDouble(&ok);                Q_ASSERT_X(ok == true,                           "CommunicationManager::parseInitDataMessage()",                           "Bogus message received in INIT DATA");                type = DATA_TYPE_FLOAT;                widget = DEFAULT_DATA_WIDGET_FLOAT;                break;            }        default:            emit protocolError(                    "Bogus message received in INIT DATA (" + messageString                    + ")");            return;        }        // Build the data description corresponding to this message        if (active == false)        {            widget = DATA_WIDGET_NONE;        }        DataDescription *dataWidgetDescription = new DataDescription;        dataWidgetDescription->id = id;        dataWidgetDescription->descriptionString = description;        dataWidgetDescription->type = type;        dataWidgetDescription->widget = widget;        dataWidgetDescription->valMin = valMin;        dataWidgetDescription->valMax = valMax;        _dataDescriptions->append(dataWidgetDescription);        qDebug()                << "CommunicationManager : "                "DATA MSG successfully parsed in INIT DATA ("                << messageString + ")";    }}void CommunicationManager::parseInitParamsMessage(QString messageString){    if (_beginEndMessageStrings.contains(messageString))    {        if (_inMessageStrings.value(messageString) == COM_MSG_IN_PARAMS_END)        {            qDebug()                    << "CommunicationManager : "                    "PARAMS END received in INIT PARAMS";            _initParamsCompleted = true;            if (isInitCompleted())            {                _state = COM_STATE_READY;            }            else            {                _state = COM_STATE_INIT;            }        }        else        {            emit protocolError(                    "Bogus message received in INIT PARAMS (" + messageString                    + ")");        }    }    else    {        QStringList messageParts = messageString.split(COM_MSG_SEPARATOR);        QString typeString = messageParts.at(0);        QString idString = messageParts.at(1);        bool ok = false;        int id = idString.toInt(&ok); // Param ID        Q_ASSERT_X(ok == true,                   "CommunicationManager::parseInitParamsMessage()",                   "Bogus message received in INIT PARAMS");        QString description = messageParts.at(2); // Param description        ParamType type;        InteractiveWidgetType widget;        bool valInitBool = false;        int valInitInt = 0;        double valInitDouble = 0.;        int valInitEnum = 0;        double valMax = 0., valMin = 0.;        QStringList enumValues;        Q_ASSERT_X(_typeMessageStrings.contains(typeString),                   "CommunicationManager::parseInitParamsMessage()",                   "Bogus message received in INIT PARAMS");        switch (_inMessageStrings.value(typeString))        {        case COM_MSG_IN_TYPE_BOOL:            {                QString valInitString = messageParts.at(3);                Q_ASSERT_X(                        messageParts.count() == 4                        && (valInitString.compare("0") == 0                        || valInitString.compare("1") == 1),                        "CommunicationManager::parseInitParamsMessage()",                        "Bogus message received in INIT PARAMS");                if (valInitString.compare("0") == 0)                {                    valInitBool = false;                }                else                {                    valInitBool = true;                }                type = PARAM_TYPE_BOOL;                widget = DEFAULT_INTERACTIVE_WIDGET_BOOL;                break;            }        case COM_MSG_IN_TYPE_INT:            {                Q_ASSERT_X(messageParts.count() == 6,                           "CommunicationManager::parseInitParamsMessage()",                           "Bogus message received in INIT PARAMS");                QString valInitString = messageParts.at(5);                bool ok = false;                valInitInt = valInitString.toInt(&ok);                Q_ASSERT_X(ok == true,                           "CommunicationManager::parseInitParamsMessage()",                           "Bogus message received in INIT PARAMS");                QString valMinString = messageParts.at(3);                valMin = valMinString.toDouble(&ok);                Q_ASSERT_X(ok == true,                           "CommunicationManager::parseInitParamsMessage()",                           "Bogus message received in INIT PARAMS");                QString valMaxString = messageParts.at(4);                valMax = valMaxString.toDouble(&ok);                Q_ASSERT_X(ok == true,                           "CommunicationManager::parseInitParamsMessage()",                           "Bogus message received in INIT PARAMS");                type = PARAM_TYPE_INT;                widget = DEFAULT_INTERACTIVE_WIDGET_INT;                break;            }        case COM_MSG_IN_TYPE_FLOAT:            {                Q_ASSERT_X(messageParts.count() == 6,                           "CommunicationManager::parseInitParamsMessage()",                           "Bogus message received in INIT PARAMS");                QString valInitString = messageParts.at(5);                bool ok = false;                valInitDouble = valInitString.toDouble(&ok);                Q_ASSERT_X(ok == true,                           "CommunicationManager::parseInitParamsMessage()",                           "Bogus message received in INIT PARAMS");                QString valMinString = messageParts.at(3);                valMin = valMinString.toDouble(&ok);                Q_ASSERT_X(ok == true,                           "CommunicationManager::parseInitParamsMessage()",                           "Bogus message received in INIT PARAMS");                QString valMaxString = messageParts.at(4);                valMax = valMaxString.toDouble(&ok);                Q_ASSERT_X(ok == true,                           "CommunicationManager::parseInitParamsMessage()",                           "Bogus message received in INIT PARAMS");                type = PARAM_TYPE_FLOAT;                widget = DEFAULT_INTERACTIVE_WIDGET_FLOAT;                break;            }        case COM_MSG_IN_TYPE_ENUM:            {                Q_ASSERT_X(messageParts.count() > 4,                           "CommunicationManager::parseInitParamsMessage()",                           "Bogus message received in INIT PARAMS");                QString valInitString = messageParts.at(messageParts.count()-1);                bool ok = false;                valInitEnum = valInitString.toInt(&ok);                Q_ASSERT_X(ok == true,                           "CommunicationManager::parseInitParamsMessage()",                           "Bogus message received in INIT PARAMS");                QStringList values;                for (int i = 3; i < messageParts.count() - 1; i++)                {                    values << messageParts.at(i);                }                valMin = 0.0;                valMax = messageParts.count() - 3 - 1;                enumValues = values;                type = PARAM_TYPE_ENUM;                widget = DEFAULT_INTERACTIVE_WIDGET_ENUM;                break;            }        default:            emit protocolError(                    "Bogus message received in INIT PARAMS (" + messageString                    + ")");            return;        }        // Build the param description corresponding to this message        ParamDescription *interactiveWidgetDescription = new ParamDescription;        interactiveWidgetDescription->id = id;        interactiveWidgetDescription->descriptionString = description;        interactiveWidgetDescription->type = type;        interactiveWidgetDescription->widget = widget;        interactiveWidgetDescription->valInitBool = valInitBool;        interactiveWidgetDescription->valInitInt = valInitInt;        interactiveWidgetDescription->valInitDouble = valInitDouble;        interactiveWidgetDescription->valInitEnum = valInitEnum;        interactiveWidgetDescription->valMin = valMin;        interactiveWidgetDescription->valMax = valMax;        interactiveWidgetDescription->enumValues = enumValues;        _paramDescriptions->append(interactiveWidgetDescription);        qDebug()                << "CommunicationManager : "                "PARAMS MSG successfully parsed in INIT PARAMS ("                << messageString + ")";    }}void CommunicationManager::parseInitDevMessage(QString messageString){    if (_beginEndMessageStrings.contains(messageString))    {        if (_inMessageStrings.value(messageString) == COM_MSG_IN_DEV_END)        {            qDebug() << "CommunicationManager : DEV END received in INIT DEV";            _initDevCompleted = true;            if (isInitCompleted())            {                _state = COM_STATE_READY;            }            else            {                _state = COM_STATE_INIT;            }        }        else        {            emit protocolError(                    "Bogus message received in INIT DEV (" + messageString                    + ")");        }    }    else    {        QStringList messageParts = messageString.split(COM_MSG_SEPARATOR);        Q_ASSERT_X(messageParts.count() == 3,                   "CommunicationManager::parseInitDevMessage()",                   "Bogus message received in INIT DEV");        QString deviceIdString = messageParts.at(0);        QString deviceTypeString = messageParts.at(1);        QString deviceNameString = messageParts.at(2);        bool ok = false;        int deviceId = deviceIdString.toInt(&ok);        Q_ASSERT_X(ok == true, "CommunicationManager::parseInitDevMessage()",                   "Bogus message received in INIT DEV");        starpu_top_device_type deviceType;        Q_ASSERT_X(                deviceTypeString.compare(                        _inMessageStrings.key(COM_MSG_IN_DEV_CPU)) == 0                || deviceTypeString.compare(                        _inMessageStrings.key(COM_MSG_IN_DEV_CUDA))                == 0 || deviceTypeString.compare(                        _inMessageStrings.key(COM_MSG_IN_DEV_OPENCL)) == 0		,                "CommunicationManager::parseInitDevMessage()",                "Bogus message received in INIT DEV");        if (deviceTypeString.compare(_inMessageStrings.key(COM_MSG_IN_DEV_CPU))            == 0)            {            deviceType = SERVERDEVICE_CPU;        }        else if (deviceTypeString.compare(                _inMessageStrings.key(COM_MSG_IN_DEV_CUDA)) == 0)        {            deviceType = SERVERDEVICE_CUDA;        }        else if (deviceTypeString.compare(                _inMessageStrings.key(COM_MSG_IN_DEV_OPENCL)) == 0)        {            deviceType = SERVERDEVICE_OPENCL;        }        starpu_top_device device;        device.id = deviceId;        device.type = deviceType;        device.name = deviceNameString;        _serverDevices->append(device);        qDebug()                << "CommunicationManager : "                "DEV MSG successfully parsed in INIT DEV ("                << messageString + ")";    }}void CommunicationManager::parseReadyMessage(QString messageString){    if (_inMessageStrings.value(messageString) == COM_MSG_IN_READY)    {        qDebug() << "CommunicationManager : READY received in READY ("                << messageString + ")";        emit serverInitCompleted(_serverID, _dataDescriptions,                                 _paramDescriptions, _serverDevices);        _state = COM_STATE_LOOP;    }    else    {        QStringList messageParts = messageString.split(COM_MSG_SEPARATOR);        QString head = messageParts.at(0);        Q_ASSERT_X(_widgetStatusChangeMessageStrings.contains(head),                   "CommunicationManager::parseReadyMessage()",                   "Bogus message received in READY");        switch (_inMessageStrings.value(head))        {        case COM_MSG_IN_SET:            parseParamNotificationMessage(messageString);            break;        default:            ;        }    }}void CommunicationManager::parseLoopMessage(QString messageString){    QStringList messageParts = messageString.split(COM_MSG_SEPARATOR);    QString head = messageParts.at(0);    if (_widgetStatusChangeMessageStrings.contains(head))    {        switch (_inMessageStrings.value(head))        {        case COM_MSG_IN_SET:            parseParamNotificationMessage(messageString);            break;        default:            ;        }    }    else if (_loopMessageStrings.contains(head))    {        switch (_inMessageStrings.value(head))        {        case COM_MSG_IN_PREV:            parseTaskPrevMessage(messageString);            break;        case COM_MSG_IN_SHORT_PREV:            parseTaskPrevMessage(messageString);            break;        case COM_MSG_IN_START:            parseTaskStartMessage(messageString);            break;        case COM_MSG_IN_SHORT_START:            parseTaskStartMessage(messageString);            break;        case COM_MSG_IN_END:            parseTaskEndMessage(messageString);            break;        case COM_MSG_IN_SHORT_END:            parseTaskEndMessage(messageString);            break;        case COM_MSG_IN_UPDATE:            parseDataUpdateMessage(messageString);            break;        case COM_MSG_IN_SHORT_UPDATE:            parseDataUpdateMessage(messageString);            break;        default:            ;        }    }    else if (_debugMessageStrings.contains(head))    {        switch (_inMessageStrings.value(head))        {        case COM_MSG_IN_DEBUG:            parseDebugEnabledMessage(messageString);            break;        case COM_MSG_IN_DEBUG_MESSAGE:            parseDebugMessageMessage(messageString);            break;        case COM_MSG_IN_DEBUG_LOCK:            parseDebugLockMessage(messageString);            break;        default:            ;        }    }    else    {        emit protocolError(                "Unexpected message received in LOOP (" + messageString + ")");    }}void CommunicationManager::parseTaskPrevMessage(QString messageString){    QStringList messageParts = messageString.split(COM_MSG_SEPARATOR);    if (messageParts.count() == 6)    {        QString taskIdString = messageParts.at(1);        QString deviceIdString = messageParts.at(2);        QString timestampString = messageParts.at(3);        QString timestampStartString = messageParts.at(4);        QString timestampEndString = messageParts.at(5);        int taskId;        int deviceId;        qlonglong timestamp;        qlonglong timestampStart;        qlonglong timestampEnd;        bool ok = false;        taskId = taskIdString.toInt(&ok);        if (ok == false)        {            emit protocolError(                    "Unexpected TASK PREV message received in LOOP ("                    + messageString + ")");            return;        }        deviceId = deviceIdString.toInt(&ok);        if (ok == false)        {            emit protocolError(                    "Unexpected TASK PREV message received in LOOP ("                    + messageString + ")");            return;        }        timestamp = timestampString.toLongLong(&ok);        if (ok == false)        {            emit protocolError(                    "Unexpected TASK PREV message received in LOOP ("                    + messageString + ")");            return;        }        timestampStart = timestampStartString.toLongLong(&ok);        if (ok == false)        {            emit protocolError(                    "Unexpected TASK PREV message received in LOOP ("                    + messageString + ")");            return;        }        timestampEnd = timestampEndString.toLongLong(&ok);        if (ok == false)        {            emit protocolError(                    "Unexpected TASK PREV message received in LOOP ("                    + messageString + ")");            return;        }        emit notifyTaskPrevUpdate(taskId, deviceId, timestamp, timestampStart,                                  timestampEnd);        qDebug()                << "CommunicationManager : "                "TASK PREV message successfully parsed in LOOP ("                << messageString + ")";    }    else    {        emit protocolError(                "Unexpected TASK PREV message received in LOOP ("                + messageString + ")");    }}void CommunicationManager::parseTaskStartMessage(QString messageString){    QStringList messageParts = messageString.split(COM_MSG_SEPARATOR);    if (messageParts.count() == 4)    {        QString taskIdString = messageParts.at(1);        QString deviceIdString = messageParts.at(2);        QString timestampString = messageParts.at(3);        int taskId;        int deviceId;        qlonglong timestamp;        bool ok = false;        taskId = taskIdString.toInt(&ok);        if (ok == false)        {            emit protocolError(                    "Bogus TASK START message received in LOOP ("                    + messageString + ")");            return;        }        deviceId = deviceIdString.toInt(&ok);        if (ok == false)        {            emit protocolError(                    "Bogus TASK START message received in LOOP ("                    + messageString + ")");            return;        }        timestamp = timestampString.toLongLong(&ok);        if (ok == false)        {            emit protocolError(                    "Bogus TASK START message received in LOOP ("                    + messageString + ")");            return;        }        emit notifyTaskStartUpdate(taskId, deviceId, timestamp);        qDebug()                << "CommunicationManager : "                "TASK START message succesfully parsed in LOOP ("                << messageString + ")";    }    else    {        emit protocolError(                "Bogus TASK START message received in LOOP (" + messageString                + ")");    }}void CommunicationManager::parseTaskEndMessage(QString messageString){    QStringList messageParts = messageString.split(COM_MSG_SEPARATOR);    if (messageParts.count() == 3)    {        QString taskIdString = messageParts.at(1);        QString timestampString = messageParts.at(2);        int taskId;        qlonglong timestamp;        bool ok = false;        taskId = taskIdString.toInt(&ok);        if (ok == false)        {            emit protocolError(                    "Bogus TASK END message received in LOOP (" + messageString                    + ")");            return;        }        timestamp = timestampString.toLongLong(&ok);        if (ok == false)        {            emit protocolError(                    "Bogus TASK END message received in LOOP (" + messageString                    + ")");            return;        }        emit notifyTaskEndUpdate(taskId, timestamp);        qDebug()                << "CommunicationManager : "                "TASK END message successfully parsed in LOOP ("                << messageString + ")";    }    else    {        emit protocolError(                "Bogus TASK END message received in LOOP (" + messageString                + ")");    }}void CommunicationManager::parseDataUpdateMessage(QString messageString){    QStringList messageParts = messageString.split(COM_MSG_SEPARATOR);    if (messageParts.count() == 4)    {        QString dataIdString = messageParts.at(1);        QString timestampString = messageParts.at(3);        QString dataValueString = messageParts.at(2);        int dataId;        qlonglong timestamp;        bool ok = false;        dataId = dataIdString.toInt(&ok);        if (ok == false || (dataDescriptionFromId(dataId) == 0))        {            emit protocolError(                    "Bogus UPDATE message received in LOOP (" + messageString                    + ")");            return;        }        timestamp = timestampString.toLongLong(&ok);        if (ok == false)        {            emit protocolError(                    "Bogus UPDATE message received in LOOP (" + messageString                    + ")");            return;        }        switch (dataDescriptionFromId(dataId)->type)        {        case DATA_TYPE_BOOL:            {                bool dataVal;                if (dataValueString.compare("0") == 0)                {                    dataVal = false;                }                else if (dataValueString.compare("1") == 0)                {                    dataVal = true;                }                else                {                    emit protocolError(                            "Bogus UPDATE message received in LOOP ("                            + messageString + ")");                    return;                }                emit notifyDataUpdate(dataId, dataVal, timestamp);                break;            }        case DATA_TYPE_INT:            {                int dataVal = dataValueString.toInt(&ok);                if (ok == false)                {                    emit protocolError(                            "Bogus UPDATE message received in LOOP ("                            + messageString + ")");                    return;                }                emit notifyDataUpdate(dataId, dataVal, timestamp);                break;            }        case DATA_TYPE_FLOAT:            {                double dataVal = dataValueString.toDouble(&ok);                if (ok == false)                {                    emit protocolError(                            "Bogus UPDATE message received in LOOP ("                            + messageString + ")");                    return;                }                emit notifyDataUpdate(dataId, dataVal, timestamp);                break;            }        default:            emit protocolError(                    "Bogus UPDATE message received in LOOP (" + messageString                    + ")");        }        qDebug()                << "CommunicationManager : "                "UPDATE message successfully parsed in LOOP ("                << messageString + ")";    }    else    {        emit                protocolError(                        "Bogus UPDATE message received in LOOP ("                        + messageString + ")");    }}void CommunicationManager::parseParamNotificationMessage(QString messageString){    QStringList messageParts = messageString.split(COM_MSG_SEPARATOR);    if (messageParts.count() != 4)    {        emit                protocolError(                        "Bogus SET message received (" + messageString + ")");        return;    }    QString paramIdString = messageParts.at(1);    QString paramValueString = messageParts.at(2);    QString timestampString = messageParts.at(3);    int paramId;    qlonglong timestamp;    bool ok = false;    paramId = paramIdString.toInt(&ok);    if (ok == false || (paramDescriptionFromId(paramId) == 0))    {        emit                protocolError(                        "Bogus SET message received (" + messageString + ")");        return;    }    timestamp = timestampString.toLongLong(&ok);    if (ok == false)    {        emit                protocolError(                        "Bogus SET message received (" + messageString + ")");        return;    }    switch (paramDescriptionFromId(paramId)->type)    {    case PARAM_TYPE_BOOL:	{            bool paramVal;            if (paramValueString.compare("0") == 0)            {                paramVal = false;            }            else if (paramValueString.compare("1") == 0)            {                paramVal = true;            }            else            {                emit protocolError(                        "Bogus SET message received (" + messageString + ")");                return;            }            emit notifyParamUpdate(paramId, paramVal, timestamp);            break;	}    case PARAM_TYPE_INT:	{            int paramVal = paramValueString.toInt(&ok);            if (ok == false)            {                emit protocolError(                        "Bogus SET message received (" + messageString + ")");                return;            }            emit notifyParamUpdate(paramId, paramVal, timestamp);            break;	}    case PARAM_TYPE_FLOAT:	{            double paramVal = paramValueString.toDouble(&ok);            if (ok == false)            {                emit protocolError(                        "Bogus SET message received (" + messageString + ")");                return;            }            emit notifyParamUpdate(paramId, paramVal, timestamp);            break;	}    case PARAM_TYPE_ENUM:	{            int paramVal = paramValueString.toInt(&ok);            if (ok == false)            {                emit protocolError(                        "Bogus SET message received (" + messageString + ")");                return;            }            emit notifyParamUpdate(paramId, paramVal, timestamp);            break;	}    default:        emit                protocolError(                        "Bogus SET message received (" + messageString + ")");    }    qDebug() << "CommunicationManager : SET successfully parsed in LOOP ("            << messageString + ")";}void CommunicationManager::parseDebugEnabledMessage(QString messageString){    QStringList messageParts = messageString.split(COM_MSG_SEPARATOR);    if (messageParts.count() != 2)    {        emit protocolError(                "Bogus DEBUG message received (" + messageString + ")");        return;    }    QString debugEnabledString = messageParts.at(1);    if (debugEnabledString.compare(_inMessageStrings.key(COM_MSG_IN_DEBUG_ON))        == 0)	{        qDebug() << "CommunicationManager : DEBUG ON received ("                << messageString + ")";        emit notifyDebugEnabled(true);    }    else if (debugEnabledString.compare(            _inMessageStrings.key(COM_MSG_IN_DEBUG_OFF)) == 0)    {        qDebug() << "CommunicationManager : DEBUG OFF received ("                << messageString + ")";        emit notifyDebugEnabled(false);    }    else    {        emit protocolError(                "Bogus DEBUG message received (" + messageString + ")");    }}void CommunicationManager::parseDebugMessageMessage(QString messageString){    QStringList messageParts = messageString.split(COM_MSG_SEPARATOR);    if (messageParts.count() != 2)    {        emit protocolError(                "Bogus DEBUG message received (" + messageString + ")");        return;    }    QString debugMessageString = messageParts.at(1);    emit notifyDebugMessage(debugMessageString);    qDebug() << "CommunicationManager : DEBUG MESSAGE received ("            << messageString + ")";}void CommunicationManager::parseDebugLockMessage(QString messageString){    QStringList messageParts = messageString.split(COM_MSG_SEPARATOR);    if (messageParts.count() != 2)    {        emit protocolError(                "Bogus DEBUG message received (" + messageString + ")");        return;    }    QString lockMessageString = messageParts.at(1);    emit notifyDebugLock(lockMessageString);    qDebug() << "CommunicationManager : DEBUG LOCK received (" << messageString            + ")";}/* -------------------------------------------------------------------------- *//* Send messages                                                              *//* -------------------------------------------------------------------------- */void CommunicationManager::sendMessage(QString messageString){    messageString.append(COM_MSG_ENDL);    write(messageString.toAscii());}void CommunicationManager::sendGoMessage(){    sendMessage( buildGoMessage());}void CommunicationManager::sendDataEnableMessage(int dataId){    sendMessage(buildDataEnableMessage(dataId));}void CommunicationManager::sendDataDisableMessage(int dataId){    sendMessage(buildDataDisableMessage(dataId));}void CommunicationManager::sendParamSetMessage(int paramId, bool paramValue){    sendMessage(buildParamSetMessage(paramId, paramValue));}void CommunicationManager::sendParamSetMessage(int paramId, int paramValue){    sendMessage(buildParamSetMessage(paramId, paramValue));}void CommunicationManager::sendParamSetMessage(int paramId, double paramValue){    sendMessage(buildParamSetMessage(paramId, paramValue));}void CommunicationManager::sendDebugEnabledMessage(bool enabled){    sendMessage(buildDebugEnabledMessage(enabled));}void CommunicationManager::sendStepMessage(){    sendMessage( buildStepMessage());}/* -------------------------------------------------------------------------- *//* Getters                                                                    *//* -------------------------------------------------------------------------- */CommunicationState CommunicationManager::state() const{    return _state;}bool CommunicationManager::isInitCompleted() const{    return (_initServerInfoCompleted && _initDataCompleted            && _initParamsCompleted && _initDevCompleted);}/* -------------------------------------------------------------------------- *//* Build messages                                                             *//* -------------------------------------------------------------------------- */QString CommunicationManager::buildGoMessage(){    QString messageString = _outMessageStrings.value(COM_MSG_OUT_GO);    return messageString;}QString CommunicationManager::buildDataEnableMessage(int dataId){    QString head = _outMessageStrings.value(COM_MSG_OUT_ENABLE);    QString dataIdString = QString::number(dataId);    QString messageString = head.append(COM_MSG_SEPARATOR).append(dataIdString);    return messageString;}QString CommunicationManager::buildDataDisableMessage(int dataId){    QString head = _outMessageStrings.value(COM_MSG_OUT_DISABLE);    QString dataIdString = QString::number(dataId);    QString messageString = head.append(COM_MSG_SEPARATOR).append(dataIdString);    return messageString;}QString CommunicationManager::buildParamSetMessage(int paramId, bool paramValue){    QString head = _outMessageStrings.value(COM_MSG_OUT_SET);    QString paramIdString = QString::number(paramId);    QString paramValueString = QString::number(paramValue ? 1 : 0);    QString messageString =            head.append(COM_MSG_SEPARATOR).append(paramIdString).append(                    COM_MSG_SEPARATOR) .append(paramValueString);    return messageString;}QString CommunicationManager::buildParamSetMessage(int paramId, int paramValue){    QString head = _outMessageStrings.value(COM_MSG_OUT_SET);    QString paramIdString = QString::number(paramId);    QString paramValueString = QString::number(paramValue);    QString messageString =            head.append(COM_MSG_SEPARATOR).append(paramIdString).append(                    COM_MSG_SEPARATOR) .append(paramValueString);    return messageString;}QString CommunicationManager::buildParamSetMessage(int paramId,                                                   double paramValue){    QString head = _outMessageStrings.value(COM_MSG_OUT_SET);    QString paramIdString = QString::number(paramId);    QString paramValueString = QString::number(paramValue);    QString messageString =            head.append(COM_MSG_SEPARATOR).append(paramIdString).append(                    COM_MSG_SEPARATOR) .append(paramValueString);    return messageString;}QString CommunicationManager::buildDebugEnabledMessage(bool enabled){    QString head = _outMessageStrings.value(COM_MSG_OUT_DEBUG);    QString debugEnabledString = (enabled ? _outMessageStrings.value(            COM_MSG_OUT_DEBUG_ON) : _outMessageStrings.value(                    COM_MSG_OUT_DEBUG_OFF));    QString messageString = head.append(COM_MSG_SEPARATOR).append(            debugEnabledString);    return messageString;}QString CommunicationManager::buildStepMessage(){    QString messageString = _outMessageStrings.value(COM_MSG_OUT_DEBUG_STEP);    return messageString;}DataDescription *CommunicationManager::dataDescriptionFromId(int dataId) const{    for (int i = 0; i < _dataDescriptions->count(); i++)    {        if (_dataDescriptions->at(i)->id == dataId)            return _dataDescriptions->at(i);    }    return 0;}ParamDescription         *CommunicationManager::paramDescriptionFromId(int paramId) const{    for (int i = 0; i < _paramDescriptions->count(); i++)    {        if (_paramDescriptions->at(i)->id == paramId)            return _paramDescriptions->at(i);    }    return 0;}void CommunicationManager::clearDescriptions(){    _dataDescriptions->clear();    _paramDescriptions->clear();}/* -------------------------------------------------------------------------- *//* Init message strings                                                       *//* -------------------------------------------------------------------------- */void CommunicationManager::initInMessageStrings(){    // Types    _inMessageStrings.insert("BOOL", COM_MSG_IN_TYPE_BOOL);    _inMessageStrings.insert("INT", COM_MSG_IN_TYPE_INT);    _inMessageStrings.insert("FLOAT", COM_MSG_IN_TYPE_FLOAT);    _inMessageStrings.insert("ENUM", COM_MSG_IN_TYPE_ENUM);    _typeMessageStrings.insert("BOOL");    _typeMessageStrings.insert("INT");    _typeMessageStrings.insert("FLOAT");    _typeMessageStrings.insert("ENUM");    // Init server ID    _inMessageStrings.insert("SERVERINFO", COM_MSG_IN_SERVERINFO_BEGIN);    _inMessageStrings.insert("/SERVERINFO", COM_MSG_IN_SERVERINFO_END);    _beginEndMessageStrings.insert("SERVERINFO");    _beginEndMessageStrings.insert("/SERVERINFO");    // Init data    _inMessageStrings.insert("DATA", COM_MSG_IN_DATA_BEGIN);    _inMessageStrings.insert("/DATA", COM_MSG_IN_DATA_END);    _beginEndMessageStrings.insert("DATA");    _beginEndMessageStrings.insert("/DATA");    // Init parameters    _inMessageStrings.insert("PARAMS", COM_MSG_IN_PARAMS_BEGIN);    _inMessageStrings.insert("/PARAMS", COM_MSG_IN_PARAMS_END);    _beginEndMessageStrings.insert("PARAMS");    _beginEndMessageStrings.insert("/PARAMS");    // Init devices    _inMessageStrings.insert("DEV", COM_MSG_IN_DEV_BEGIN);    _inMessageStrings.insert("/DEV", COM_MSG_IN_DEV_END);    _inMessageStrings.insert("CPU", COM_MSG_IN_DEV_CPU);    _inMessageStrings.insert("GPU", COM_MSG_IN_DEV_CUDA);    _inMessageStrings.insert("OPENCL", COM_MSG_IN_DEV_OPENCL);    _beginEndMessageStrings.insert("DEV");    _beginEndMessageStrings.insert("/DEV");    // Server ready    _inMessageStrings.insert("READY", COM_MSG_IN_READY);    // Widget status    _inMessageStrings.insert("SET", COM_MSG_IN_SET);    _widgetStatusChangeMessageStrings.insert("SET");    // Loop messages    // Complete versions    _inMessageStrings.insert("PREV", COM_MSG_IN_PREV);    _inMessageStrings.insert("START", COM_MSG_IN_START);    _inMessageStrings.insert("END", COM_MSG_IN_END);    _inMessageStrings.insert("UPDATE", COM_MSG_IN_UPDATE);    // Short versions    _inMessageStrings.insert("P", COM_MSG_IN_SHORT_PREV);    _inMessageStrings.insert("S", COM_MSG_IN_SHORT_START);    _inMessageStrings.insert("E", COM_MSG_IN_SHORT_END);    _inMessageStrings.insert("U", COM_MSG_IN_SHORT_UPDATE);    // Complete versions    _loopMessageStrings.insert("PREV");    _loopMessageStrings.insert("START");    _loopMessageStrings.insert("END");    _loopMessageStrings.insert("UPDATE");    // Short versions    _loopMessageStrings.insert("P");    _loopMessageStrings.insert("S");    _loopMessageStrings.insert("E");    _loopMessageStrings.insert("U");    // Debug messages    _inMessageStrings.insert("DEBUG", COM_MSG_IN_DEBUG);    _inMessageStrings.insert("ON", COM_MSG_IN_DEBUG_ON);    _inMessageStrings.insert("OFF", COM_MSG_IN_DEBUG_OFF);    _inMessageStrings.insert("MESSAGE", COM_MSG_IN_DEBUG_MESSAGE);    _inMessageStrings.insert("LOCK", COM_MSG_IN_DEBUG_LOCK);    _debugMessageStrings.insert("DEBUG");    _debugMessageStrings.insert("MESSAGE");    _debugMessageStrings.insert("LOCK");}void CommunicationManager::initOutMessageStrings(){    // Launch session on server    _outMessageStrings.insert(COM_MSG_OUT_GO, "GO");    // Widget status change    _outMessageStrings.insert(COM_MSG_OUT_ENABLE, "ENABLE");    _outMessageStrings.insert(COM_MSG_OUT_DISABLE, "DISABLE");    _outMessageStrings.insert(COM_MSG_OUT_SET, "SET");    // Debug mode    _outMessageStrings.insert(COM_MSG_OUT_DEBUG, "DEBUG");    _outMessageStrings.insert(COM_MSG_OUT_DEBUG_ON, "ON");    _outMessageStrings.insert(COM_MSG_OUT_DEBUG_OFF, "OFF");    _outMessageStrings.insert(COM_MSG_OUT_DEBUG_STEP, "STEP");}
 |