ToolLoader.cs 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. using System;
  2. using System.IO;
  3. using Aitex.Common.Util;
  4. using Aitex.Core.RT.ConfigCenter;
  5. using Aitex.Core.RT.DataCenter;
  6. using Aitex.Core.RT.DataCollection;
  7. using Aitex.Core.RT.DBCore;
  8. using Aitex.Core.RT.Event;
  9. using Aitex.Core.RT.Log;
  10. using Aitex.Core.RT.OperationCenter;
  11. using Aitex.Core.RT.RecipeCenter;
  12. using Aitex.Core.Util;
  13. using Aitex.Core.WCF;
  14. using MECF.Framework.Common.Account;
  15. using MECF.Framework.Common.IOCore;
  16. using MECF.Framework.Common.RecipeCenter;
  17. using MECF.Framework.Common.SCCore;
  18. using MECF.Framework.Common.SubstrateTrackings;
  19. using MECF.Framework.RT.Core.Applications;
  20. using MECF.Framework.RT.Core.Backend;
  21. using MECF.Framework.RT.Core.IoProviders;
  22. using Venus_RT.Modules;
  23. using Venus_RT.Backends;
  24. using Venus_RT.HostWrapper;
  25. using Venus_RT.Modules.PMs;
  26. using MECF.Framework.Common.DataCenter;
  27. using MECF.Framework.Common.OperationCenter;
  28. using Aitex.Core.Account;
  29. namespace Venus_RT.Instances
  30. {
  31. class ToolLoader : IRtLoader
  32. {
  33. public void Initialize()
  34. {
  35. LogDefineManager.Initialize(PathManager.GetCfgDir() + "LogDefine.json");
  36. Singleton<LogManager>.Instance.Initialize();
  37. //LOG.Write(eEvent., MECF.Framework.Common.Equipment.ModuleName.VCE1, "1", "2");
  38. WcfServiceManager.Instance.Initialize(new Type[]
  39. {
  40. typeof (RecipeService),typeof (QueryDataService)
  41. });
  42. Singleton<ConfigManager>.Instance.Initialize();
  43. Singleton<DatabaseManager>.Instance.Initialize(
  44. System.Configuration.ConfigurationManager.ConnectionStrings["PostgreSQL"].ConnectionString
  45. , RtInstance.DatabaseName
  46. , PathManager.GetCfgDir() + "DBModel.sql");
  47. Singleton<EventManager>.Instance.Initialize(PathManager.GetCfgDir() + "EventDefine.xml");
  48. Singleton<OperationManager>.Instance.Initialize();
  49. Singleton<DataManager>.Instance.Initialize();
  50. RecipeFileManager.Instance.Initialize(new VenusRecipeFileContext(), new VenusSequenceFileContext(), true);
  51. Singleton<SystemConfigManager>.Instance.Initialize(PathManager.GetCfgDir() + "System.sccfg");
  52. IoProviderManager.Instance.Initialize(PathManager.GetCfgDir() + "IoProviderConfig.xml");
  53. IoManager.Instance.Initialize(PathManager.GetCfgDir() + "Interlock.Venus.xml");
  54. WaferManager.Instance.Initialize();
  55. AccountExManager.Instance.Initialize(true);
  56. // Device manager
  57. Singleton<DeviceManager>.Instance.Initialize();
  58. Singleton<DeviceEntity>.Instance.Initialize();
  59. Singleton<FaManager>.Instance.Initialize();
  60. DataCollectionManager.Instance.Initialize(RtInstance.DatabaseName);
  61. RtSystemManager.Instance.AddCustomBackend("SC", new BackendSCConfigView());
  62. RtSystemManager.Instance.AddCustomBackend("IO", new IOView());
  63. RtSystemManager.Instance.AddCustomBackend("FSM", new FSMView());
  64. Singleton<RouteManager>.Instance.Initialize();
  65. Singleton<EventManager>.Instance.FireEvent += InstanceOnOnEvent;
  66. string s1 = System.Diagnostics.FileVersionInfo.GetVersionInfo(Path.Combine(PathManager.GetAppDir(), "Venus_RT.exe")).ProductVersion;
  67. //System.Threading.Tasks.Task.Run(() =>
  68. //{
  69. // System.Threading.Thread.Sleep(10000);
  70. // EV.PostWarningLog("System", $"{111} stats wafer value larger than wafer setting alarm value");
  71. // EV.PostAlarmLog("System", $"{222} stats wafer value larger than wafer setting alarm value");
  72. //});
  73. }
  74. private void InstanceOnOnEvent(EventItem obj)
  75. {
  76. if (obj.Level != EventLevel.Alarm)
  77. {
  78. Singleton<FaManager>.Instance.NotifyEvent(obj.EventEnum, obj.DVID, obj.ObjDVID);
  79. }
  80. else
  81. {
  82. Singleton<FaManager>.Instance.NotifyAlarm(obj.EventEnum, obj.DVID, obj.ObjDVID, obj.Description);
  83. }
  84. }
  85. public void Terminate()
  86. {
  87. Singleton<DeviceEntity>.Instance.Terminate();
  88. Singleton<DeviceManager>.Instance.Terminate();
  89. Singleton<FaManager>.Instance.Terminate();
  90. IoProviderManager.Instance.Terminate();
  91. Singleton<SystemConfigManager>.Instance.Terminate();
  92. DataCollectionManager.Instance.Terminate();
  93. Singleton<WcfServiceManager>.Instance.Terminate();
  94. Singleton<EventManager>.Instance.Terminate();
  95. Singleton<LogManager>.Instance.Terminate();
  96. Singleton<DatabaseManager>.Instance.Terminate();
  97. }
  98. }
  99. }