VIDManager2.cs 43 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971
  1. using Aitex.Common.Util;
  2. using Aitex.Core.RT.DataCenter;
  3. using Aitex.Core.RT.Event;
  4. using Aitex.Core.RT.Log;
  5. using Aitex.Core.Util;
  6. using Aitex.Core.Utilities;
  7. using MECF.Framework.Common.Equipment;
  8. using MECF.Framework.Common.SCCore;
  9. using MECF.Framework.Common.Utilities;
  10. using System;
  11. using System.Collections.Generic;
  12. using System.IO;
  13. using System.Linq;
  14. using System.Xml;
  15. using System.Xml.Serialization;
  16. namespace MECF.Framework.Common.FAServices
  17. {
  18. /// <summary>
  19. /// 所有ID 的命名规则:
  20. ///
  21. /// Module(1-399) + (Type+Unit)(1-999) + Parameter (1-9999)
  22. ///
  23. /// 最小 1 001 0001 = 10010001
  24. ///
  25. /// 最大 399 999 9999 = 3 999 999 999
  26. ///
  27. /// "PPP" 一部分的就是按参数 module=1, type=1, unit=1, parameter="AAA"
  28. ///
  29. ///
  30. /// </summary>
  31. ///
  32. ///
  33. public class VIDGenerator2
  34. {
  35. public string Type { get; set; }
  36. public string SourceFileName { get; set; }
  37. public List<VIDItem> VIDList = new List<VIDItem>();
  38. public Dictionary<string, int> _moduleIndex = new Dictionary<string, int>();
  39. public Dictionary<string, Dictionary<string, Dictionary<string, long>>> moduleTypeParamIndex = new Dictionary<string, Dictionary<string, Dictionary<string, long>>>();
  40. public Dictionary<string, long> _index = new Dictionary<string, long>();
  41. private string _defaultPathFile;
  42. private string _type;
  43. public VIDGenerator2(string type, string defaultPathFile)
  44. {
  45. _type = type;
  46. _defaultPathFile = defaultPathFile;
  47. }
  48. public void Initialize()
  49. {
  50. XmlDocument xml = new XmlDocument();
  51. try
  52. {
  53. EnumLoop<ModuleName>.ForEach((item) =>
  54. {
  55. moduleTypeParamIndex[item.ToString()] = new Dictionary<string, Dictionary<string, long>>();
  56. });
  57. xml.Load(_defaultPathFile);
  58. VIDList = CustomXmlSerializer.Deserialize<List<VIDItem>>(xml.OuterXml);
  59. foreach (var VIDItem in VIDList)
  60. {
  61. //_moduleTypeIndex[VIDItem.Type] = VIDItem.TypeIndex;
  62. //_moduleTypeUnitIndex[VIDItem.Unit] = VIDItem.UnitIndex;
  63. //_parameterIndex[VIDItem.Parameter] = VIDItem.ParameterIndex;
  64. if (!moduleTypeParamIndex.ContainsKey(VIDItem.Module))
  65. {
  66. moduleTypeParamIndex[VIDItem.Module] = new Dictionary<string, Dictionary<string, long>>();
  67. }
  68. if (!moduleTypeParamIndex[VIDItem.Module].ContainsKey(VIDItem.Type + VIDItem.Unit))
  69. {
  70. moduleTypeParamIndex[VIDItem.Module][VIDItem.Type + VIDItem.Unit] = new Dictionary<string, long>();
  71. }
  72. moduleTypeParamIndex[VIDItem.Module][VIDItem.Type + VIDItem.Unit][VIDItem.Parameter] = VIDItem.Index;
  73. _index[VIDItem.Name] = VIDItem.Index;
  74. }
  75. //XmlNodeList itemNodes = xml.SelectNodes("DataItems/DataItem");
  76. //foreach (var itemNode in itemNodes)
  77. //{
  78. // XmlElement element = itemNode as XmlElement;
  79. // if (element == null)
  80. // continue;
  81. // string name = element.GetAttribute("name").Trim();
  82. // string index = element.GetAttribute("index").Trim();
  83. // if (string.IsNullOrEmpty(name) || string.IsNullOrEmpty(index) || (index.Length != 9 && index.Length != 8))
  84. // continue;
  85. // var item = ParseName(name);
  86. // _moduleTypeIndex[$"{item.Item1}.{item.Item2}"] = int.Parse(index.Substring(index.Length - 7, 2));
  87. // _moduleTypeUnitIndex[$"{item.Item1}.{item.Item2}.{item.Item3}"] = int.Parse(index.Substring(index.Length - 5, 2));
  88. // _parameterIndex[$"{item.Item1}.{item.Item2}.{item.Item3}.{item.Item4}"] =
  89. // int.Parse(index.Substring(index.Length - 3, 3));
  90. // if (!_max.ContainsKey($"{item.Item1}"))
  91. // _max[$"{item.Item1}"] = 0;
  92. // _max[$"{item.Item1}"] =
  93. // Math.Max(_moduleTypeIndex[$"{item.Item1}.{item.Item2}"], _max[$"{item.Item1}"]);
  94. // if (!_max.ContainsKey($"{item.Item1}.{item.Item2}"))
  95. // _max[$"{item.Item1}.{item.Item2}"] = 0;
  96. // _max[$"{item.Item1}.{item.Item2}"] =
  97. // Math.Max(_moduleTypeUnitIndex[$"{item.Item1}.{item.Item2}.{item.Item3}"], _max[$"{item.Item1}.{item.Item2}"]);
  98. // if (!_max.ContainsKey($"{item.Item1}.{item.Item2}.{item.Item3}"))
  99. // _max[$"{item.Item1}.{item.Item2}.{item.Item3}"] = 0;
  100. // _max[$"{item.Item1}.{item.Item2}.{item.Item3}"] =
  101. // Math.Max(_parameterIndex[$"{item.Item1}.{item.Item2}.{item.Item3}.{item.Item4}"], _max[$"{item.Item1}.{item.Item2}.{item.Item3}"]);
  102. // _index[name] = int.Parse(index);
  103. //}
  104. }
  105. catch (Exception ex)
  106. {
  107. LOG.Write(ex);
  108. }
  109. EnumLoop<ModuleName>.ForEach((item) =>
  110. {
  111. _moduleIndex[item.ToString()] = ((int)item) + 1;
  112. });
  113. }
  114. public Tuple<string, string, string, string> ParseName(string name)
  115. {
  116. if (string.IsNullOrEmpty(name))
  117. return null;
  118. string module = ModuleName.System.ToString();
  119. string type = "";
  120. string unit = "";
  121. string parameter = "";
  122. string[] names = name.Split('.');
  123. if (names.Length >= 1)
  124. {
  125. parameter = names[names.Length - 1];
  126. if (names.Length >= 2)
  127. {
  128. if (_moduleIndex.ContainsKey(names[0]))
  129. {
  130. module = names[0];
  131. if (names.Length >= 3)
  132. {
  133. unit = names[names.Length - 2];
  134. if (names.Length >= 4)
  135. {
  136. for (int j = 1; j < names.Length - 2; j++)
  137. {
  138. type += names[j];
  139. if (j != names.Length - 3)
  140. type += ".";
  141. }
  142. }
  143. }
  144. }
  145. else
  146. {
  147. //module = module;
  148. unit = names[names.Length - 2];
  149. if (names.Length >= 3)
  150. {
  151. for (int j = 0; j < names.Length - 2; j++)
  152. {
  153. type += names[j];
  154. if (j != names.Length - 3)
  155. type += ".";
  156. }
  157. }
  158. }
  159. }
  160. }
  161. return Tuple.Create(module, type, unit, parameter);
  162. }
  163. public void GenerateId(List<VIDItem> dataList)
  164. {
  165. List<VIDItem> newList = new List<VIDItem>();
  166. foreach (var data in dataList)
  167. {
  168. if (!_index.ContainsKey(data.Name))
  169. newList.Add(data);
  170. }
  171. if (newList.Count > 0)
  172. {
  173. AssignNewId(newList);
  174. VIDList = VIDList.Concat(newList).OrderBy(x => x.Index).ToList();
  175. CustomXmlSerializer.Serialize(VIDList, _defaultPathFile);
  176. }
  177. }
  178. private void AssignNewId(List<VIDItem> dataList)
  179. {
  180. if (dataList.Count == 0)
  181. return;
  182. dataList = dataList.OrderBy(x => x.Name).ToList();
  183. foreach (var data in dataList)
  184. {
  185. data.Name = data.Name;
  186. if (!moduleTypeParamIndex.ContainsKey(data.Module))
  187. {
  188. moduleTypeParamIndex[data.Module] = new Dictionary<string, Dictionary<string, long>>();
  189. moduleTypeParamIndex[data.Module][data.Type + data.Unit] = new Dictionary<string, long>();
  190. data.ModuleIndex = moduleTypeParamIndex.Keys.ToList().FindIndex(x => x == data.Module) + 1;
  191. data.TypeIndex = 1;
  192. data.UnitIndex = 1;
  193. data.ParameterIndex = 1;
  194. moduleTypeParamIndex[data.Module][data.Type + data.Unit][data.Parameter] = long.Parse($"{data.ModuleIndex}{data.TypeIndex.ToString().PadLeft(3, '0')}{data.ParameterIndex.ToString().PadLeft(4, '0')}");
  195. data.Index = moduleTypeParamIndex[data.Module][data.Type + data.Unit][data.Parameter];
  196. continue;
  197. }
  198. if (!moduleTypeParamIndex[data.Module].ContainsKey(data.Type + data.Unit))
  199. {
  200. moduleTypeParamIndex[data.Module][data.Type + data.Unit] = new Dictionary<string, long>();
  201. data.ModuleIndex = moduleTypeParamIndex.Keys.ToList().FindIndex(x => x == data.Module) + 1;
  202. data.TypeIndex = moduleTypeParamIndex[data.Module].Count;
  203. data.UnitIndex = 1;
  204. data.ParameterIndex = 1;
  205. moduleTypeParamIndex[data.Module][data.Type + data.Unit][data.Parameter] = long.Parse($"{data.ModuleIndex}{data.TypeIndex.ToString().PadLeft(3, '0')}{data.ParameterIndex.ToString().PadLeft(4, '0')}");
  206. data.Index = moduleTypeParamIndex[data.Module][data.Type + data.Unit][data.Parameter];
  207. continue;
  208. }
  209. moduleTypeParamIndex[data.Module][data.Type + data.Unit][data.Parameter] = moduleTypeParamIndex[data.Module][data.Type + data.Unit].Last().Value + 1;
  210. data.Index = moduleTypeParamIndex[data.Module][data.Type + data.Unit][data.Parameter];
  211. }
  212. //XmlDocument xml = new XmlDocument();
  213. //try
  214. //{
  215. // xml.Load(_defaultPathFile);
  216. // XmlNode itemNodes = xml.SelectSingleNode("DataItems");
  217. // itemNodes.RemoveAll();
  218. // Dictionary<int, string> orderedName = _index.OrderBy(o => o.Value).ToDictionary(p => p.Value, o => o.Key);
  219. // foreach (var name in orderedName)
  220. // {
  221. // XmlElement subNode = xml.CreateElement("DataItem");
  222. // subNode.SetAttribute("name", name.Value);
  223. // subNode.SetAttribute("index", name.Key.ToString());
  224. // itemNodes.AppendChild(subNode);
  225. // }
  226. // xml.Save(_defaultPathFile);
  227. //}
  228. //catch (Exception ex)
  229. //{
  230. // LOG.Write(ex);
  231. //}
  232. }
  233. }
  234. public class VIDManager2 : Singleton<VIDManager2>
  235. {
  236. public void Initialize(string equipName, bool enableGem300Events = false, bool needReGenerateGemModelXml = false)
  237. {
  238. if (!System.Diagnostics.Debugger.IsAttached)
  239. return;
  240. //SVID
  241. var svid = new VIDGenerator2("SVID", $"{PathManager.GetCfgDir().Replace("\\bin\\Debug", "")}VIDs\\_SVID.xml");
  242. svid.Initialize();
  243. svid.GenerateId(Singleton<DataManager>.Instance.VidDataList);
  244. //foreach (var item in OriginalSvids)
  245. //{
  246. // svid.VIDList.Add(item);
  247. //}
  248. ExportSvid(svid.VIDList, true, true);
  249. //ECID
  250. var ecid = new VIDGenerator2("ECID", $"{PathManager.GetCfgDir().Replace("\\bin\\Debug", "")}VIDs\\_ECID.xml");
  251. ecid.Initialize();
  252. ecid.GenerateId(SystemConfigManager.Instance.VidConfigList);
  253. ExportEcid(ecid.VIDList);
  254. //CEID
  255. List<VIDItem> ceids = new List<VIDItem>();
  256. foreach (var eventItem in Singleton<EventManager>.Instance.VidEventList)
  257. {
  258. if (UniversalEvents.UniversalEventsDictionary.ContainsKey(eventItem.Name))
  259. {
  260. ceids.Add(UniversalEvents.UniversalEventsDictionary[eventItem.Name]);
  261. }
  262. else if (enableGem300Events && Gem300Events.Gem300EventsDictionary.ContainsKey(eventItem.Name))
  263. {
  264. ceids.Add(Gem300Events.Gem300EventsDictionary[eventItem.Name]);
  265. }
  266. }
  267. ceids = ceids.OrderBy(x => x.Index).ToList();
  268. CustomXmlSerializer.Serialize(ceids, $"{PathManager.GetCfgDir().Replace("\\bin\\Debug", "")}VIDs\\_CEID.xml");
  269. ExportCeid(ceids);
  270. //ALID
  271. var alid = new VIDGenerator2("ALID", $"{PathManager.GetCfgDir().Replace("\\bin\\Debug", "")}VIDs\\_ALID.xml");
  272. alid.Initialize();
  273. alid.GenerateId(Singleton<EventManager>.Instance.VidAlarmList);
  274. ExportAlid(alid.VIDList);
  275. //DVID, to be designed
  276. Dictionary<string, VIDItem> dvids = new Dictionary<string, VIDItem>();
  277. foreach (var eventItem in ceids)
  278. {
  279. if (eventItem.LinkableVid == null)
  280. continue;
  281. foreach (var LinkableVid in eventItem.LinkableVid)
  282. {
  283. string dvidName = ((DataVariables.DataName)LinkableVid).ToString();
  284. if (DataVariables.DataVariablesDictionary.ContainsKey(dvidName))
  285. dvids[dvidName] = DataVariables.DataVariablesDictionary[dvidName];
  286. }
  287. }
  288. var dvidList = dvids.Values.ToList().OrderBy(x => x.Index).ToList();
  289. CustomXmlSerializer.Serialize(dvidList, $"{PathManager.GetCfgDir().Replace("\\bin\\Debug", "")}VIDs\\_DVID.xml");
  290. ExportDvid(dvidList);
  291. //ReGenerate GemModel.Xml
  292. if (needReGenerateGemModelXml)
  293. ReGenerateGemModelXml(svid.VIDList, ecid.VIDList, dvidList, ceids, alid.VIDList, equipName);
  294. }
  295. private List<VIDItem> OriginalSvids = new List<VIDItem>()
  296. {
  297. new VIDItem(){Name = "AlarmsEnabled",Index = 1,DataType = "List"},
  298. new VIDItem(){Name = "AlarmsSet",Index = 2,DataType = "List"},
  299. new VIDItem(){Name = "Clock",Index = 3,DataType = "Ascii"},
  300. new VIDItem(){Name = "ControlState",Index = 4,DataType = "U4"},
  301. new VIDItem(){Name = "EventsEnabled",Index = 5,DataType = "List"},
  302. new VIDItem(){Name = "PPExecName",Index = 6,DataType = "Ascii"},
  303. new VIDItem(){Name = "PreviousProcessState",Index = 7,DataType = "U1"},
  304. new VIDItem(){Name = "ProcessState",Index = 8,DataType = "U1"},
  305. new VIDItem(){Name = "SpoolCountActual",Index = 9,DataType = "U4"},
  306. new VIDItem(){Name = "SpoolCountTotal",Index = 10,DataType = "U4"},
  307. new VIDItem(){Name = "SpoolFullTime",Index = 11,DataType = "Ascii"},
  308. new VIDItem(){Name = "SpoolStartTime",Index = 12,DataType = "Ascii"},
  309. new VIDItem(){Name = "SpoolState",Index = 13,DataType = "Ascii"},
  310. new VIDItem(){Name = "SpoolSubstate",Index = 14,DataType = "Ascii"},
  311. new VIDItem(){Name = DataVariables.BoatCurrentFilmThickness,Index = 20,DataType = "Ascii"},
  312. new VIDItem(){Name = DataVariables.DryClearCount,Index = 21,DataType = "Ascii"},
  313. new VIDItem(){Name = DataVariables.ProcessRecipeStepName,Index = 22,DataType = "Ascii"},
  314. new VIDItem(){Name = DataVariables.SubRecipeStepName,Index = 23,DataType = "Ascii"},
  315. new VIDItem(){Name = DataVariables.SubRecipeStepNumber,Index = 24,DataType = "Ascii"},
  316. new VIDItem(){Name = DataVariables.PJId,Index = 25,DataType = "Ascii"},
  317. new VIDItem(){Name = DataVariables.ProcessRecipeStepNumber,Index = 26,DataType = "Ascii"},
  318. new VIDItem(){Name = DataVariables.IsInSubProcessing,Index = 27,DataType = "Boolean"},
  319. //new VIDItem(){Name = "System.SideDummyAccuThickness",Index = 15,DataType = "List"},
  320. //new VIDItem(){Name = "System.SideDummyUseCount",Index = 16,DataType = "List"},
  321. //new VIDItem(){Name = "System.ExtraDummyAccuThickness",Index = 17,DataType = "List"},
  322. //new VIDItem(){Name = "System.ExtraDummyUseCount",Index = 18,DataType = "List"},
  323. };
  324. private List<VIDItem> OriginalEcids = new List<VIDItem>()
  325. {
  326. new VIDItem(){Name = "EstablishCommunicationsTimeout",Index = 2000,DataType = "U2",Description = "2"},
  327. new VIDItem(){Name = "MaxSpoolTransmit",Index = 2001,DataType = "U4",Description = "100"},
  328. new VIDItem(){Name = "OverWriteSpool",Index = 2003,DataType = "Boolean",Description = "FALSE"},
  329. new VIDItem(){Name = "MaxSpoolCapacity",Index = 2005,DataType = "U4",Description = "100"},
  330. new VIDItem(){Name = "SpoolEnabled",Index = 2006,DataType = "Boolean",Description = "False"},
  331. new VIDItem(){Name = "TimeFormat",Index = 2007,DataType = "U1",Description = "0"},
  332. };
  333. private void ExportAlid(List<VIDItem> dataList, bool defaultPath = true, bool createNewFile = false)
  334. {
  335. var lists = dataList.OrderBy(x => x.ModuleIndex).ThenBy(x => x.Name).ToList();
  336. bool? result = defaultPath;
  337. string savePath = $"{PathManager.GetCfgDir().Replace("\\bin\\Debug", "")}VIDs\\Equipment_VIDs_{DateTime.Now:yyyyMMdd}.xlsx";
  338. if (!defaultPath)
  339. {
  340. Microsoft.Win32.SaveFileDialog dlg = new Microsoft.Win32.SaveFileDialog();
  341. dlg.DefaultExt = ".xlsx"; // Default file extension
  342. dlg.FileName = $"Equipment_VIDs_{DateTime.Now:yyyyMMdd_HHmmss}";
  343. dlg.Filter = "Excel数据表格文件(*.xlsx)|*.xlsx"; // Filter files by extension
  344. result = dlg.ShowDialog();// Show open file dialog box
  345. savePath = dlg.FileName;
  346. }
  347. if (result == true)
  348. {
  349. System.Data.DataSet ds = new System.Data.DataSet();
  350. ds.Tables.Add(new System.Data.DataTable("ALID(Alarm ID)"));
  351. ds.Tables[0].Columns.Add("ALID");
  352. ds.Tables[0].Columns.Add("Name");
  353. ds.Tables[0].Columns.Add("Description");
  354. ds.Tables[0].Columns.Add("AlarmSet");
  355. ds.Tables[0].Columns.Add("AlarmClear");
  356. Dictionary<int, int> IdDictionary = new Dictionary<int, int>();
  357. foreach (var item in lists)
  358. {
  359. var row = ds.Tables[0].NewRow();
  360. if (!IdDictionary.ContainsKey(item.ModuleIndex))
  361. IdDictionary[item.ModuleIndex] = 0;
  362. row[0] = item.Index;
  363. row[1] = item.Name;
  364. if (string.IsNullOrEmpty(item.Description))
  365. {
  366. var arr = item.Name.Split('.');
  367. for (int i = 0; i < arr.Length; i++)
  368. row[2] += $"{arr[i]} ";
  369. }
  370. else
  371. {
  372. row[2] = item.Description;
  373. }
  374. row[3] = $"10{item.ModuleIndex.ToString().PadLeft(3, '0')}01";
  375. row[4] = $"20{item.ModuleIndex.ToString().PadLeft(3, '0')}01";
  376. ds.Tables[0].Rows.Add(row);
  377. }
  378. if (!ExcelHelper.ExportToExcel(savePath, ds, out string reason, createNewFile))
  379. {
  380. LOG.Write($"Export failed, {reason}");
  381. return;
  382. }
  383. LOG.Write($"Export succeed, file save as {savePath}");
  384. }
  385. }
  386. private void ExportCeid(List<VIDItem> dataList, bool defaultPath = true, bool createNewFile = false)
  387. {
  388. var lists = dataList.OrderBy(x => x.Index).ToList();
  389. bool? result = defaultPath;
  390. string savePath = $"{PathManager.GetCfgDir().Replace("\\bin\\Debug", "")}VIDs\\Equipment_VIDs_{DateTime.Now:yyyyMMdd}.xlsx";
  391. if (!defaultPath)
  392. {
  393. Microsoft.Win32.SaveFileDialog dlg = new Microsoft.Win32.SaveFileDialog();
  394. dlg.DefaultExt = ".xlsx"; // Default file extension
  395. dlg.FileName = $"Equipment_VIDs_{DateTime.Now:yyyyMMdd_HHmmss}";
  396. dlg.Filter = "Excel数据表格文件(*.xlsx)|*.xlsx"; // Filter files by extension
  397. result = dlg.ShowDialog();// Show open file dialog box
  398. savePath = dlg.FileName;
  399. }
  400. if (result == true)
  401. {
  402. System.Data.DataSet ds = new System.Data.DataSet();
  403. ds.Tables.Add(new System.Data.DataTable("CEID(Collection Events)"));
  404. ds.Tables[0].Columns.Add("CEID");
  405. ds.Tables[0].Columns.Add("Name");
  406. ds.Tables[0].Columns.Add("LinkableVID");
  407. ds.Tables[0].Columns.Add("Description");
  408. Dictionary<int, int> IdDictionary = new Dictionary<int, int>();
  409. foreach (var item in lists)
  410. {
  411. var row = ds.Tables[0].NewRow();
  412. if (!IdDictionary.ContainsKey(item.ModuleIndex))
  413. IdDictionary[item.ModuleIndex] = 0;
  414. row[0] = item.Index;
  415. row[1] = item.Name;
  416. if (item.LinkableVid != null)
  417. {
  418. string LinkableVidDescription = String.Empty;
  419. for (int i = 0; i < item.LinkableVid.Length; i++)
  420. {
  421. LinkableVidDescription += $"{(DataVariables.DataName)item.LinkableVid[i]} = {item.LinkableVid[i]} \r\n";
  422. }
  423. row[2] = LinkableVidDescription;
  424. }
  425. if (string.IsNullOrEmpty(item.Description))
  426. {
  427. var arr = item.Name.Split('.');
  428. for (int i = 0; i < arr.Length; i++)
  429. row[3] += $"{arr[i]} ";
  430. }
  431. else
  432. {
  433. row[3] = item.Description;
  434. }
  435. ds.Tables[0].Rows.Add(row);
  436. }
  437. if (!ExcelHelper.ExportToExcel(savePath, ds, out string reason, createNewFile))
  438. {
  439. LOG.Write($"Export failed, {reason}");
  440. return;
  441. }
  442. LOG.Write($"Export succeed, file save as {savePath}");
  443. }
  444. }
  445. private void ExportEcid(List<VIDItem> dataList, bool defaultPath = true, bool createNewFile = false)
  446. {
  447. var lists = dataList.OrderBy(x => x.Index).ToList();
  448. bool? result = defaultPath;
  449. string savePath = $"{PathManager.GetCfgDir().Replace("\\bin\\Debug", "")}VIDs\\Equipment_VIDs_{DateTime.Now:yyyyMMdd}.xlsx";
  450. if (!defaultPath)
  451. {
  452. Microsoft.Win32.SaveFileDialog dlg = new Microsoft.Win32.SaveFileDialog();
  453. dlg.DefaultExt = ".xlsx"; // Default file extension
  454. dlg.FileName = $"Equipment_VIDs_{DateTime.Now:yyyyMMdd_HHmmss}";
  455. dlg.Filter = "Excel数据表格文件(*.xlsx)|*.xlsx"; // Filter files by extension
  456. result = dlg.ShowDialog();// Show open file dialog box
  457. savePath = dlg.FileName;
  458. }
  459. if (result == true)
  460. {
  461. System.Data.DataSet ds = new System.Data.DataSet();
  462. ds.Tables.Add(new System.Data.DataTable("ECID(Equipment Constant)"));
  463. ds.Tables[0].Columns.Add("ECID");
  464. ds.Tables[0].Columns.Add("Name");
  465. ds.Tables[0].Columns.Add("Format");
  466. ds.Tables[0].Columns.Add("Description");
  467. Dictionary<int, int> IdDictionary = new Dictionary<int, int>();
  468. foreach (var item in lists)
  469. {
  470. var row = ds.Tables[0].NewRow();
  471. if (!IdDictionary.ContainsKey(item.ModuleIndex))
  472. IdDictionary[item.ModuleIndex] = 0;
  473. row[0] = item.Index;
  474. row[1] = item.Name;
  475. row[2] = VIDItemType2GemDataType(item.DataType);
  476. if (string.IsNullOrEmpty(item.Description))
  477. {
  478. var arr = item.Name.Split('.');
  479. for (int i = 0; i < arr.Length; i++)
  480. row[3] += $"{arr[i]} ";
  481. }
  482. else
  483. {
  484. row[3] = item.Description;
  485. }
  486. ds.Tables[0].Rows.Add(row);
  487. }
  488. if (!ExcelHelper.ExportToExcel(savePath, ds, out string reason, createNewFile))
  489. {
  490. LOG.Write($"Export failed, {reason}");
  491. return;
  492. }
  493. LOG.Write($"Export succeed, file save as {savePath}");
  494. }
  495. }
  496. private void ExportSvid(List<VIDItem> dataList, bool defaultPath = true, bool createNewFile = false)
  497. {
  498. var lists = dataList.OrderBy(x => x.Index).ToList();
  499. bool? result = defaultPath;
  500. string savePath = $"{PathManager.GetCfgDir().Replace("\\bin\\Debug", "")}VIDs\\Equipment_VIDs_{DateTime.Now:yyyyMMdd}.xlsx";
  501. if (!defaultPath)
  502. {
  503. Microsoft.Win32.SaveFileDialog dlg = new Microsoft.Win32.SaveFileDialog();
  504. dlg.DefaultExt = ".xlsx"; // Default file extension
  505. dlg.FileName = $"Chamber_Status_Variable_{DateTime.Now:yyyyMMdd_HHmmss}";
  506. dlg.Filter = "Excel数据表格文件(*.xlsx)|*.xlsx"; // Filter files by extension
  507. result = dlg.ShowDialog();// Show open file dialog box
  508. savePath = dlg.FileName;
  509. }
  510. if (result == true)
  511. {
  512. System.Data.DataSet ds = new System.Data.DataSet();
  513. ds.Tables.Add(new System.Data.DataTable("SVID(Status Variable)"));
  514. ds.Tables[0].Columns.Add("SVID");
  515. ds.Tables[0].Columns.Add("Name");
  516. ds.Tables[0].Columns.Add("Format");
  517. ds.Tables[0].Columns.Add("Description");
  518. Dictionary<int, int> IdDictionary = new Dictionary<int, int>();
  519. foreach (var item in lists)
  520. {
  521. var row = ds.Tables[0].NewRow();
  522. if (!IdDictionary.ContainsKey(item.ModuleIndex))
  523. IdDictionary[item.ModuleIndex] = 0;
  524. row[0] = item.Index;
  525. row[1] = item.Name;
  526. row[2] = VIDItemType2GemDataType(item.DataType);
  527. if (string.IsNullOrEmpty(item.Description))
  528. {
  529. var arr = item.Name.Split('.');
  530. for (int i = 0; i < arr.Length; i++)
  531. row[3] += $"{arr[i]} ";
  532. }
  533. else
  534. {
  535. row[3] = item.Description;
  536. }
  537. ds.Tables[0].Rows.Add(row);
  538. }
  539. if (!ExcelHelper.ExportToExcel(savePath, ds, out string reason, createNewFile))
  540. {
  541. LOG.Write($"Export failed, {reason}");
  542. return;
  543. }
  544. LOG.Write($"Export succeed, file save as {savePath}");
  545. }
  546. }
  547. private void ExportDvid(List<VIDItem> dataList, bool defaultPath = true, bool createNewFile = false)
  548. {
  549. var lists = dataList.OrderBy(x => x.Index).ToList();
  550. bool? result = defaultPath;
  551. string savePath = $"{PathManager.GetCfgDir().Replace("\\bin\\Debug", "")}VIDs\\Equipment_VIDs_{DateTime.Now:yyyyMMdd}.xlsx";
  552. if (!defaultPath)
  553. {
  554. Microsoft.Win32.SaveFileDialog dlg = new Microsoft.Win32.SaveFileDialog();
  555. dlg.DefaultExt = ".xlsx"; // Default file extension
  556. dlg.FileName = $"Data_Variable_{DateTime.Now:yyyyMMdd_HHmmss}";
  557. dlg.Filter = "Excel数据表格文件(*.xlsx)|*.xlsx"; // Filter files by extension
  558. result = dlg.ShowDialog();// Show open file dialog box
  559. savePath = dlg.FileName;
  560. }
  561. if (result == true)
  562. {
  563. System.Data.DataSet ds = new System.Data.DataSet();
  564. ds.Tables.Add(new System.Data.DataTable("DVID(Data Variable)"));
  565. ds.Tables[0].Columns.Add("DVID");
  566. ds.Tables[0].Columns.Add("Name");
  567. ds.Tables[0].Columns.Add("Format");
  568. ds.Tables[0].Columns.Add("Description");
  569. Dictionary<int, int> IdDictionary = new Dictionary<int, int>();
  570. foreach (var item in lists)
  571. {
  572. var row = ds.Tables[0].NewRow();
  573. if (!IdDictionary.ContainsKey(item.ModuleIndex))
  574. IdDictionary[item.ModuleIndex] = 0;
  575. row[0] = item.Index;
  576. row[1] = item.Name;
  577. row[2] = VIDItemType2GemDataType(item.DataType);
  578. if (string.IsNullOrEmpty(item.Description))
  579. {
  580. var arr = item.Name.Split('.');
  581. for (int i = 0; i < arr.Length; i++)
  582. row[3] += $"{arr[i]} ";
  583. }
  584. else
  585. {
  586. row[3] = item.Description;
  587. }
  588. ds.Tables[0].Rows.Add(row);
  589. }
  590. if (!ExcelHelper.ExportToExcel(savePath, ds, out string reason, createNewFile))
  591. {
  592. LOG.Write($"Export failed, {reason}");
  593. return;
  594. }
  595. LOG.Write($"Export succeed, file save as {savePath}");
  596. }
  597. }
  598. private void ReGenerateGemModelXml(List<VIDItem> Svids, List<VIDItem> Ecids, List<VIDItem> Dvids, List<VIDItem> Ceids, List<VIDItem> Alids, string equipName)
  599. {
  600. XmlDocument xml = new XmlDocument();
  601. string _defaultPathFile = $"{PathManager.GetCfgDir().Replace("\\bin\\Debug", "")}{equipName}GemModel.xml";
  602. try
  603. {
  604. xml.Load(_defaultPathFile);
  605. if (Svids != null)
  606. {
  607. XmlNode itemNodes = xml.SelectSingleNode("Equipment/StatusVariables");
  608. itemNodes.RemoveAll();
  609. foreach (var svid in OriginalSvids)
  610. {
  611. XmlElement subNode = xml.CreateElement("SVID");
  612. subNode.SetAttribute("id", svid.Index.ToString());
  613. subNode.SetAttribute("valueType", svid.DataType);
  614. subNode.SetAttribute("logicalName", svid.Name);
  615. subNode.SetAttribute("value", "");
  616. subNode.SetAttribute("eventTrigger", "");
  617. subNode.SetAttribute("units", "");
  618. subNode.SetAttribute("description", svid.Description);
  619. subNode.SetAttribute("isArray", "false");
  620. itemNodes.AppendChild(subNode);
  621. }
  622. foreach (var svid in Svids)
  623. {
  624. XmlElement subNode = xml.CreateElement("SVID");
  625. subNode.SetAttribute("id", svid.Index.ToString());
  626. subNode.SetAttribute("valueType", VIDItemType2GemDataType(svid.DataType));
  627. subNode.SetAttribute("logicalName", svid.Name);
  628. subNode.SetAttribute("value", "");
  629. subNode.SetAttribute("eventTrigger", "");
  630. subNode.SetAttribute("units", "");
  631. subNode.SetAttribute("description", svid.Description);
  632. subNode.SetAttribute("isArray", "false");
  633. itemNodes.AppendChild(subNode);
  634. }
  635. }
  636. if (Ecids != null)
  637. {
  638. XmlNode itemNodes = xml.SelectSingleNode("Equipment/EquipmentConstants");
  639. itemNodes.RemoveAll();
  640. foreach (var ecid in OriginalEcids)
  641. {
  642. XmlElement subNode = xml.CreateElement("ECID");
  643. subNode.SetAttribute("id", ecid.Index.ToString());
  644. subNode.SetAttribute("valueType", ecid.DataType);
  645. subNode.SetAttribute("logicalName", ecid.Name);
  646. subNode.SetAttribute("value", ecid.Description);
  647. subNode.SetAttribute("min", "0");
  648. subNode.SetAttribute("max", "100");
  649. subNode.SetAttribute("eventTrigger", "");
  650. subNode.SetAttribute("units", "");
  651. subNode.SetAttribute("description", "");
  652. subNode.SetAttribute("isArray", "false");
  653. itemNodes.AppendChild(subNode);
  654. }
  655. foreach (var ecid in Ecids)
  656. {
  657. XmlElement subNode = xml.CreateElement("ECID");
  658. subNode.SetAttribute("id", ecid.Index.ToString());
  659. subNode.SetAttribute("valueType", VIDItemType2GemDataType(ecid.DataType));
  660. subNode.SetAttribute("logicalName", ecid.Name);
  661. subNode.SetAttribute("value", "");
  662. subNode.SetAttribute("min", "");
  663. subNode.SetAttribute("max", "");
  664. subNode.SetAttribute("eventTrigger", "");
  665. subNode.SetAttribute("units", "");
  666. subNode.SetAttribute("description", ecid.Description);
  667. subNode.SetAttribute("isArray", "false");
  668. itemNodes.AppendChild(subNode);
  669. }
  670. }
  671. if (Dvids != null)
  672. {
  673. XmlNode itemNodes = xml.SelectSingleNode("Equipment/DataVariables");
  674. itemNodes.RemoveAll();
  675. foreach (var dvids in Dvids)
  676. {
  677. if (dvids.Index < 500)
  678. continue;
  679. XmlElement subNode = xml.CreateElement("DVID");
  680. subNode.SetAttribute("id", dvids.Index.ToString());
  681. subNode.SetAttribute("valueType", VIDItemType2GemDataType(dvids.DataType));
  682. subNode.SetAttribute("logicalName", dvids.Name);
  683. subNode.SetAttribute("value", "");
  684. subNode.SetAttribute("eventTrigger", "");
  685. subNode.SetAttribute("description", dvids.Description);
  686. subNode.SetAttribute("isArray", "false");
  687. itemNodes.AppendChild(subNode);
  688. }
  689. }
  690. var moduleAlarmEventsDictionary = new Dictionary<int, string>();
  691. if (Alids != null)
  692. {
  693. XmlNode itemNodes = xml.SelectSingleNode("Equipment/Alarms");
  694. itemNodes.RemoveAll();
  695. foreach (var alid in Alids)
  696. {
  697. XmlElement subNode = xml.CreateElement("ALID");
  698. subNode.SetAttribute("id", alid.Index.ToString());
  699. subNode.SetAttribute("logicalName", alid.Name);
  700. subNode.SetAttribute("description", alid.Description);
  701. subNode.SetAttribute("category", "EquipmentStatusWarning");
  702. subNode.SetAttribute("enabled", "false");
  703. subNode.SetAttribute("eventSet", $"10{alid.ModuleIndex.ToString().PadLeft(3, '0')}01");
  704. subNode.SetAttribute("eventClear", $"20{alid.ModuleIndex.ToString().PadLeft(3, '0')}01");
  705. itemNodes.AppendChild(subNode);
  706. moduleAlarmEventsDictionary[alid.ModuleIndex] = alid.Module;
  707. }
  708. }
  709. if (Ceids != null)
  710. {
  711. int reportID = 0;
  712. Dictionary<string, int> reportDictionary = new Dictionary<string, int>();
  713. XmlNode RPTIDNodes = xml.SelectSingleNode("Equipment/DataCollections/RPTIDs");
  714. RPTIDNodes.RemoveAll();
  715. foreach (var ceid in Ceids)
  716. {
  717. XmlElement RPTID = xml.CreateElement("RPTID");
  718. if (ceid.LinkableVid != null)
  719. {
  720. string reportKey = string.Join(",", ceid.LinkableVid);
  721. if (!reportDictionary.ContainsKey(reportKey))
  722. {
  723. reportID += 1;
  724. reportDictionary[reportKey] = reportID;
  725. RPTID.SetAttribute("id", reportID.ToString());
  726. RPTID.SetAttribute("logicalName", $"DefaultDefinedReport_{reportID}");
  727. foreach (var vid in ceid.LinkableVid)
  728. {
  729. XmlElement ReportVariable = xml.CreateElement("ReportVariable");
  730. ReportVariable.SetAttribute("id", vid.ToString());
  731. ReportVariable.SetAttribute("varType", vid < 500 ? "StatusVariable" : "DataVariable");
  732. ReportVariable.SetAttribute("logicalName", ((DataVariables.DataName)vid).ToString());
  733. RPTID.AppendChild(ReportVariable);
  734. }
  735. RPTIDNodes.AppendChild(RPTID);
  736. }
  737. }
  738. }
  739. XmlNode CEIDNodes = xml.SelectSingleNode("Equipment/DataCollections/CEIDs");
  740. CEIDNodes.RemoveAll();
  741. foreach (var ceid in Ceids)
  742. {
  743. XmlElement CEID = xml.CreateElement("CEID");
  744. CEID.SetAttribute("id", ceid.Index.ToString());
  745. CEID.SetAttribute("logicalName", ceid.Name);
  746. CEID.SetAttribute("description", ceid.Description);
  747. CEID.SetAttribute("enabled", "true");
  748. if (ceid.LinkableVid != null)
  749. {
  750. string reportKey = string.Join(",", ceid.LinkableVid);
  751. XmlElement RPTID = xml.CreateElement("RPTID");
  752. RPTID.SetAttribute("id", reportDictionary[reportKey].ToString());
  753. RPTID.SetAttribute("logicalName", $"DefaultDefinedReport_{reportDictionary[reportKey]}");
  754. foreach (var vid in ceid.LinkableVid)
  755. {
  756. XmlElement ReportVariable = xml.CreateElement("ReportVariable");
  757. ReportVariable.SetAttribute("id", vid.ToString());
  758. ReportVariable.SetAttribute("varType", vid < 500 ? "StatusVariable" : "DataVariable");
  759. ReportVariable.SetAttribute("logicalName", ((DataVariables.DataName)vid).ToString());
  760. RPTID.AppendChild(ReportVariable);
  761. }
  762. CEID.AppendChild(RPTID);
  763. }
  764. CEIDNodes.AppendChild(CEID);
  765. }
  766. foreach (var alarmEvent in moduleAlarmEventsDictionary)
  767. {
  768. XmlElement EventSet = xml.CreateElement("CEID");
  769. EventSet.SetAttribute("id", $"10{alarmEvent.Key.ToString().PadLeft(3, '0')}01");
  770. EventSet.SetAttribute("logicalName", $"__SYSTEM__10{alarmEvent.Key.ToString().PadLeft(3, '0')}01__ALARMSET");
  771. EventSet.SetAttribute("description", $"Alarm Set : {alarmEvent.Value} Error");
  772. EventSet.SetAttribute("enabled", "true");
  773. CEIDNodes.AppendChild(EventSet);
  774. XmlElement EventClear = xml.CreateElement("CEID");
  775. EventClear.SetAttribute("id", $"20{alarmEvent.Key.ToString().PadLeft(3, '0')}01");
  776. EventClear.SetAttribute("logicalName", $"__SYSTEM__20{alarmEvent.Key.ToString().PadLeft(3, '0')}01__ALARMCLEAR");
  777. EventClear.SetAttribute("description", $"Alarm Clear : {alarmEvent.Value} Error");
  778. EventClear.SetAttribute("enabled", "true");
  779. CEIDNodes.AppendChild(EventClear);
  780. }
  781. }
  782. xml.Save(_defaultPathFile);
  783. }
  784. catch (Exception ex)
  785. {
  786. LOG.Write(ex);
  787. }
  788. }
  789. string VIDItemType2GemDataType(string VIDItemType)
  790. {
  791. switch (VIDItemType.Replace("System.", ""))
  792. {
  793. case "List":
  794. case "FabConnect.SecsGemInterface.Common.SECsDataItem":
  795. return "List";
  796. case "I1":
  797. return "I1";
  798. case "I4":
  799. return "I4";
  800. case "U1":
  801. return "U1";
  802. case "U2":
  803. return "U2";
  804. case "U4":
  805. return "U4";
  806. case "Int":
  807. case "Integer":
  808. return "I4";
  809. case "Bool":
  810. case "Boolean":
  811. return "Boolean";
  812. case "Float":
  813. case "Single":
  814. case "Double":
  815. case "F8":
  816. return "F8";
  817. case "Binary":
  818. return "Binary";
  819. default:
  820. return "Ascii";
  821. }
  822. }
  823. }
  824. }