| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574 | 
							- /*
 
- = StarPU-Top for StarPU =
 
- Copyright (C) 2011 
 
- William Braik
 
- Yann Courtois
 
- Jean-Marie Couteyen
 
- Anthony Roy
 
- This library is free software; you can redistribute it and/or
 
- modify it under the terms of the GNU Lesser General Public
 
- License as published by the Free Software Foundation; either
 
- version 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 of
 
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 
- Lesser General Public License for more details.
 
- You should have received a copy of the GNU Lesser General Public
 
- License along with this library; if not, write to the Free Software
 
- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
 
- */
 
- #include "communicationmanager.h"
 
- // Protocol messages delimiters
 
- const 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
 
-                 || deviceTypeString.compare(
 
-                         _inMessageStrings.key(COM_MSG_IN_DEV_GORDON))
 
-                 == 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;
 
-         }
 
-         else if (deviceTypeString.compare(
 
-                 _inMessageStrings.key(COM_MSG_IN_DEV_GORDON)) == 0)
 
-         {
 
-             deviceType = SERVERDEVICE_GORDON;
 
-         }
 
-         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);
 
-     _inMessageStrings.insert("GORDON", COM_MSG_IN_DEV_GORDON);
 
-     _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");
 
- }
 
 
  |