Module.cpp 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216
  1. #include "Module.h"
  2. #include <QJsonArray>
  3. #include <QJsonObject>
  4. #include <QJsonDocument>
  5. #include <QtCore/QVariant>
  6. #include <QtCore/QDebug>
  7. #include <stdlib.h>
  8. #include <math.h>
  9. #include <thread>
  10. void split(const std::string source,const std::string delim,std::vector<std::string>& dest)
  11. {
  12. long n = delim.length();
  13. long lt = source.length();
  14. long last = 0;
  15. size_t index = source.find_first_of(delim,last);
  16. while(index != std::string::npos)
  17. {
  18. dest.push_back(source.substr(last,index-last));
  19. last = index + n;
  20. index = source.find_first_of(delim,last);
  21. }
  22. long len = source.length();
  23. if( len - last > 0)
  24. {
  25. dest.push_back(source.substr(last,len - last));
  26. }
  27. }
  28. Module::Module()
  29. :RunnableModule()
  30. {
  31. m_pDataConsumer = nullptr;
  32. m_szOutputs.clear();
  33. m_mpParamConfig.clear();
  34. m_mpDataValue.clear();
  35. m_nLoopIntervalMS = 100;//UINT_FAST32_MAX;
  36. }
  37. bool Module::isInheritedFrom(std::string tp)
  38. {
  39. bool bEqual = (strcasecmp(tp.c_str(), "BaseModule") == 0);
  40. bEqual |= (strcasecmp(tp.c_str(), "RunnableModule") == 0);
  41. return bEqual;
  42. }
  43. void Module::regConsumer(DataConsumer* pDC)
  44. {
  45. m_pDataConsumer = pDC;
  46. }
  47. void Module::Setup(ModuleInfo mi)
  48. {
  49. std::list<DataItem>::iterator itrO;
  50. for( itrO = mi.Properties.begin(); itrO != mi.Properties.end(); ++itrO )
  51. {
  52. m_szOutputs.push_back(mi.Code + "_" + itrO->Code);
  53. }
  54. std::vector<Setting>::iterator itr;
  55. for( itr = mi.vSettings.begin(); itr != mi.vSettings.end(); ++itr )
  56. {
  57. QString szConfig = itr->qValue.toString();
  58. QJsonDocument jsonDoc(QJsonDocument::fromJson(szConfig.toLocal8Bit().toStdString().c_str()));
  59. QJsonArray ja = jsonDoc.array();
  60. for(auto i : ja)
  61. {
  62. QString item = i.toString();
  63. m_mpParamConfig[item.toLocal8Bit().toStdString()] = tagParam();
  64. }
  65. }
  66. }
  67. void Module::OnSubData(std::string name,std::string)
  68. {
  69. if( m_mpParamConfig.find(name) == m_mpParamConfig.end())
  70. {
  71. return;
  72. }
  73. // add data
  74. m_objDataLock.lockForWrite();
  75. m_mpDataValue[name] = QDateTime::currentDateTime();
  76. m_objDataLock.unlock();
  77. }
  78. void Module::Check()
  79. {
  80. std::map<std::string,tagParam>::iterator itr;
  81. for( itr = m_mpParamConfig.begin(); itr != m_mpParamConfig.end(); ++itr )
  82. {
  83. pubStatus(itr->first,EAS_Breaked);
  84. }
  85. while(1)
  86. {
  87. if( m_pDataConsumer == nullptr )
  88. {
  89. std::this_thread::sleep_for(std::chrono::milliseconds(m_nLoopIntervalMS));
  90. continue;
  91. }
  92. // get first time
  93. m_objDataLock.lockForRead();
  94. std::map<std::string,QDateTime> mpCache = m_mpDataValue;
  95. m_objDataLock.unlock();
  96. // no data
  97. QDateTime dtNow = QDateTime::currentDateTime();
  98. // status merge
  99. std::map<std::string,QDateTime>::iterator itrR;
  100. for( itrR = mpCache.begin(); itrR != mpCache.end(); ++itrR )
  101. {
  102. std::string szTable = itrR->first;
  103. if( m_mpParamConfig.find(szTable) == m_mpParamConfig.end())
  104. {
  105. continue;
  106. }
  107. uint nIntervalMS = m_mpParamConfig[szTable].uIntervalMS;
  108. qint64 tDiff = itrR->second.msecsTo(dtNow);
  109. if( tDiff > nIntervalMS )
  110. {
  111. if( m_mpParamConfig[szTable].nStatus != EAS_Breaked )
  112. {
  113. m_mpParamConfig[szTable].nStatus = EAS_Breaked;
  114. m_mpParamConfig[szTable].bChanged = true;
  115. pubStatus(szTable,EAS_Breaked);
  116. }
  117. else
  118. {
  119. m_mpParamConfig[szTable].bChanged = false;
  120. }
  121. }
  122. else
  123. {
  124. if( m_mpParamConfig[szTable].nStatus == EAS_Breaked )
  125. {
  126. m_mpParamConfig[szTable].nStatus = EAS_Recover;
  127. m_mpParamConfig[szTable].bChanged = true;
  128. pubStatus(szTable,EAS_Recover);
  129. }
  130. else
  131. {
  132. m_mpParamConfig[szTable].nStatus = EAS_Normal;
  133. m_mpParamConfig[szTable].bChanged = false;
  134. }
  135. }
  136. }
  137. std::this_thread::sleep_for(std::chrono::milliseconds(m_nLoopIntervalMS));
  138. }
  139. }
  140. void Module::pubStatus(std::string name,int nStatus)
  141. {
  142. std::vector<std::string>::iterator itr;
  143. for( itr = m_szOutputs.begin(); itr != m_szOutputs.end(); ++itr )
  144. {
  145. std::string topic = *itr;
  146. QString szStatus;
  147. switch( nStatus )
  148. {
  149. case EAS_Normal:
  150. szStatus = "O";
  151. break;
  152. case EAS_Breaked:
  153. szStatus = "B";
  154. break;
  155. case EAS_Recover:
  156. szStatus = "R";
  157. break;
  158. }
  159. QString szJson;
  160. szJson += "{";
  161. szJson += QString("\"%1\":\"%2\"").arg(name.c_str()).arg(szStatus);
  162. szJson += "}";
  163. emit sigMqttMsg(topic,szJson);
  164. //qDebug() << __FILE__ << __LINE__ << QDateTime::currentDateTime().toString("hh:mm:ss.zzz ") << szMSG;
  165. }
  166. }
  167. void Module::Run()
  168. {
  169. connect(this,SIGNAL(sigMqttMsg(std::string,QString)),this,SLOT(sltMqttMsg(std::string,QString)),Qt::QueuedConnection);
  170. std::thread t(&Module::Check,this);
  171. t.detach();
  172. }
  173. void Module::sltMqttMsg(std::string topic,QString szJson)
  174. {
  175. m_pDataConsumer->OnData(topic,QVariant(szJson));
  176. }
  177. BaseModule* instance()
  178. {
  179. return new Module();
  180. }
  181. void destroy(BaseModule* pInstance)
  182. {
  183. if( pInstance )
  184. {
  185. delete pInstance;
  186. }
  187. }