COTSHardwareMgr.cpp 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275
  1. #include "stdafx.h"
  2. #include "COTSHardwareMgr.h"
  3. #include "Bruker\OTSSEMBruker.h"
  4. #include "Simulate\OTSSemSim.h"
  5. #include "Simulate\OTSEDSSim.h"
  6. #include "Simulate\OTSScanSim.h"
  7. #include "Bruker\OTSEDSBrucker.h"
  8. #include "Bruker\OTSScanBrucker.h"
  9. #include "Oxford\OTSEDSOxford.h"
  10. #include "Oxford\OTSScanOxford.h"
  11. #include "Oxford\OTSSEMOxford.h"
  12. namespace OTSController {
  13. const CString cssSubKeyRegeditPath = "SOFTWARE\\OTSDevName";
  14. const CString csKey_DevName = "SEMName";
  15. const CString csKey_EDSName = "EDSName";
  16. //
  17. char* lpSemName[] = { "OffLine","Bruker","ESEM","ZEISS" ,"Oxford"};
  18. char* lpEdsName[] = { "OffLine","Bruker" ,"Oxford"};
  19. //XMLÎļþÃû
  20. const CString szXMLFileName = "./Config/ProData/HardwareConfig.xml";
  21. CString szSemName=_T(""), szEdsName= _T("");
  22. typedef enum class SemDevID
  23. {
  24. Invalid = -1,
  25. OFFLINE = 0,
  26. BRUKER = 1,
  27. ESEM = 2,
  28. ZEISS = 3,
  29. OXFORD = 4,
  30. }SEM_DEV_ID;
  31. typedef enum class EDSDevID
  32. {
  33. Invalid = -1,
  34. OFFLINE = 0,
  35. BRUKER = 1,
  36. OXFORD = 2,
  37. }EDS_DEV_ID;
  38. COTSHardwareMgr::COTSHardwareMgr()
  39. {
  40. m_SemBasePtr = nullptr;
  41. m_EDSPtr = nullptr;
  42. m_SCanPtr = nullptr;
  43. }
  44. COTSHardwareMgr::~COTSHardwareMgr()
  45. {
  46. }
  47. CSemBasePtr COTSHardwareMgr::GetSemControllerMgrPtr()// this is the same as the constructor of singleton.So we cann't put expensive operation in it,such as the "connect" operation
  48. {
  49. if (nullptr == m_SemBasePtr)
  50. {
  51. int iDevID = -1;
  52. if (szSemName == _T(""))
  53. {
  54. if (!this->GetXMLVal(szXMLFileName, szSemName, szEdsName))
  55. {
  56. return nullptr;
  57. }
  58. }
  59. LogTrace(__FILE__, __LINE__, "(COTSHardwareMgr::GetSemControllerMgrPtr) SemName = %s, EdsName = %s", szSemName, szEdsName);
  60. iDevID = this->GetSemControllerID(szSemName);
  61. switch (iDevID)
  62. {
  63. case (int)SEM_DEV_ID::BRUKER:
  64. {
  65. m_SemBasePtr = CSemBasePtr(new COTSSEMBruker());
  66. break;
  67. }
  68. case (int)SEM_DEV_ID::OFFLINE:
  69. {
  70. m_SemBasePtr = CSemBasePtr(new COTSSemSim());
  71. break;
  72. }
  73. case (int)SEM_DEV_ID::OXFORD:
  74. {
  75. m_SemBasePtr = CSemBasePtr(new COTSSEMOxford());
  76. break;
  77. }
  78. default:
  79. break;
  80. }
  81. }
  82. return m_SemBasePtr;
  83. }
  84. COTSEDSBasePtr COTSHardwareMgr::GetEDSControllerPtr()
  85. {
  86. if (nullptr == m_EDSPtr)
  87. {
  88. int iDevID = -1;
  89. if (szEdsName == _T(""))
  90. {
  91. if (!this->GetXMLVal(szXMLFileName, szSemName, szEdsName))
  92. {
  93. return nullptr;
  94. }
  95. }
  96. iDevID = this->GetEDSControllerID(szEdsName);
  97. switch (iDevID)
  98. {
  99. case (int)EDS_DEV_ID::BRUKER:
  100. {
  101. m_EDSPtr = COTSEDSBasePtr(new COTSEDSBrucker());
  102. break;
  103. }
  104. case (int)EDS_DEV_ID::OFFLINE:
  105. {
  106. m_EDSPtr = COTSEDSBasePtr(new COTSEDSSim());
  107. break;
  108. }
  109. case (int)EDS_DEV_ID::OXFORD:
  110. {
  111. m_EDSPtr = COTSEDSBasePtr(new COTSEDSOxford());
  112. break;
  113. }
  114. default:
  115. break;
  116. }
  117. }
  118. return m_EDSPtr;
  119. }
  120. COTSScanBasePtr COTSHardwareMgr::GetScanControllerPtr()
  121. {
  122. if (nullptr == m_SCanPtr)
  123. {
  124. int iDevID = -1;
  125. if (szEdsName == _T(""))
  126. {
  127. if (!this->GetXMLVal(szXMLFileName, szSemName, szEdsName))
  128. {
  129. return nullptr;
  130. }
  131. }
  132. iDevID = this->GetEDSControllerID(szEdsName);
  133. switch (iDevID)
  134. {
  135. case (int)EDS_DEV_ID::BRUKER:
  136. {
  137. m_SCanPtr = COTSScanBasePtr(new COTSScanBrucker());
  138. break;
  139. }
  140. case (int)EDS_DEV_ID::OFFLINE:
  141. {
  142. m_SCanPtr = COTSScanBasePtr(new COTSScanSim());
  143. break;
  144. }
  145. case (int)EDS_DEV_ID::OXFORD:
  146. {
  147. m_SCanPtr = COTSScanBasePtr(new COTSScanOxford());
  148. break;
  149. }
  150. default:
  151. break;
  152. }
  153. }
  154. return m_SCanPtr;
  155. }
  156. BOOL COTSHardwareMgr::GetXMLVal(const CString& szXmlFileName, CString& szSemName, CString& szEdsName)
  157. {
  158. tinyxml2::XMLDocument doc;
  159. doc.LoadFile(szXMLFileName);//ÔØÈëxmlÎļþ
  160. xmls::xString szS;
  161. xmls::xString szE;
  162. xmls::Slo subClass;
  163. xmls::Slo subClass1;
  164. subClass.Register("Value", &szS);
  165. subClass1.Register ("Value",&szE);
  166. subClass.Register("SemControllerName", &subClass);
  167. subClass.Register("EDSName", &subClass1);
  168. tinyxml2::XMLElement *rootNode;
  169. rootNode = doc.FirstChildElement(RootClassName);
  170. subClass.Serialize(false, &doc, rootNode);
  171. szSemName = szS.value().c_str();
  172. szEdsName = szE.value().c_str();
  173. return true;
  174. }
  175. //return array Index when ControllerName match for name in array
  176. int COTSHardwareMgr::GetSemControllerID(const CString& SemControllerName)
  177. {
  178. int iLen = sizeof(lpSemName) /sizeof(*lpSemName);
  179. int i = 0;
  180. for (i=0; i<iLen; i++)
  181. {
  182. if (0 == strcmp(lpSemName[i], SemControllerName))
  183. {
  184. return i;
  185. }
  186. }
  187. return -1;
  188. }
  189. //return array Index when ControllerName match for name in array
  190. int COTSHardwareMgr::GetEDSControllerID(const CString& EDSControllerName)
  191. {
  192. int iLen = sizeof(lpEdsName) / sizeof(*lpEdsName);
  193. int i = 0;
  194. for (i = 0; i < iLen; i++)
  195. {
  196. if (0 == strcmp(lpEdsName[i], EDSControllerName))
  197. {
  198. return i;
  199. }
  200. }
  201. return -1;
  202. }
  203. }