using Aitex.Core.RT.DataCenter; using Aitex.Core.RT.Device; using Aitex.Core.RT.Fsm; using Aitex.Core.RT.Log; using Aitex.Core.RT.OperationCenter; using Aitex.Core.RT.RecipeCenter; using Aitex.Core.Util; using Aitex.Core.Utilities; using MECF.Framework.Common.Equipment; using MECF.Framework.Common.Persistent.Reservoirs; using MECF.Framework.Common.ProcessCell; using MECF.Framework.Common.RecipeCenter; using MECF.Framework.Common.ToolLayout; using PunkHPX8_Core; using PunkHPX8_RT.Devices.PlatingCell; using PunkHPX8_RT.Devices.PowerSupplier; using PunkHPX8_RT.Devices.Temperature; using PunkHPX8_RT.Modules.Reservoir; using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace PunkHPX8_RT.Modules.PlatingCell { public class PlatingCellEntity : Entity, IEntity, IModuleEntity { public enum PlatingCellMsg { NONE, Error, ResumeError, Initialize, Manual, Auto, CurrentShortTest, CloseFlowValve, OpenFlowValve, RunRecipe, Abort, Init } #region 常量 private const string STRATUS = "Stratus"; private const string AUTO = "Auto"; private const string MANUAL = "Manual"; private const string DISABLED = "Disabled"; private const string ENGINEERING = "Engineering"; private const string PRODUCTION = "Production"; #endregion #region 内部变量 /// /// 持久化数值 /// private PlatingCellPersistentValue _persistentValue; /// /// 当前recipe /// private DepRecipe _currentRecipe; #endregion #region 属性 /// /// 模块名称 /// public ModuleName Module { get; private set; } /// /// 是否Init /// public bool IsInit { get { return fsm.State == (int)PlatingCellState.Init; } } /// /// 是否Idle /// public bool IsIdle { get { return fsm.State == (int)PlatingCellState.Idle; } } /// /// 是否错误 /// public bool IsError { get { return fsm.State == (int)PlatingCellState.Error; } } /// /// 正在忙碌 /// public bool IsBusy { get { return fsm.State == (int)PlatingCellState.Initializing; } } /// /// 化学液 /// public string Chemistry { get { return _currentRecipe != null ? _currentRecipe.Chemistry : ""; } } /// /// 是否禁用 /// public bool IsDisable { get { return _persistentValue == null || _persistentValue.OperatingMode == DISABLED; } } /// /// 自动模式 /// public bool IsAuto { get { return _persistentValue != null && _persistentValue.OperatingMode == AUTO; } } /// /// 自动模式 /// public bool IsManual { get { return _persistentValue != null && _persistentValue.OperatingMode == MANUAL; } } /// /// 是否为工程模式 /// public bool IsEngineering { get { return _persistentValue != null && _persistentValue.RecipeOperatingMode == ENGINEERING; } } /// /// 是否为产品模式 /// public bool IsProduction { get { return _persistentValue != null && _persistentValue.RecipeOperatingMode == PRODUCTION; } } /// /// 状态机状态 /// public PlatingCellState State { get { return (PlatingCellState)fsm.State; } } /// /// 是否初始化完成 /// public bool IsInitialized { get { return fsm.State >= (int)PlatingCellState.Initialized; } } /// /// Reservoir项 /// private ReservoirItem _reservoirItem; #endregion /// /// 构造函数 /// /// public PlatingCellEntity(ModuleName module) { this.Module = module; InitializeParameter(); InitialFsm(); } /// /// 初始化 /// /// protected override bool Init() { InitializeRoutine(); InitializeDATA(); InitializeOperation(); return true; } /// /// 初始化参数 /// private void InitializeParameter() { _persistentValue = PlatingCellPersistentManager.Instance.GetPlatingCellPersistentValue(Module.ToString()); if (_persistentValue == null) { LOG.WriteLog(eEvent.ERR_PLATINGCELL, Module.ToString(), "Persistent Value Object is not exist"); } } /// /// 初始化Routine /// private void InitializeRoutine() { } /// /// 初始化DATA /// private void InitializeDATA() { DATA.Subscribe($"{Module}.FsmState", () => ((PlatingCellState)fsm.State).ToString(), SubscriptionAttribute.FLAG.IgnoreSaveDB); } /// /// 初始化Operation /// private void InitializeOperation() { OP.Subscribe($"{Module}.InitializeAll", (cmd, args) => { return CheckToPostMessage(eEvent.ERR_RESERVOIR, Module.ToString(), (int)ReservoirMsg.Initialize); }); } /// 初始化状态机 /// private void InitialFsm() { fsm = new StateMachine(Module.ToString(), (int)PlatingCellState.Init, 100); fsm.EnableRepeatedMsg(true); AnyStateTransition(ReservoirMsg.Error, NullFunc, PlatingCellState.Error); //Initialized Transition(PlatingCellState.Error, PlatingCellMsg.Initialize, InitializeAll, PlatingCellState.Initializing); Transition(PlatingCellState.Init, PlatingCellMsg.Initialize, InitializeAll, PlatingCellState.Initializing); Transition(PlatingCellState.Idle, PlatingCellMsg.Initialize, InitializeAll, PlatingCellState.Initializing); Transition(PlatingCellState.Initializing, FSM_MSG.TIMER, InitializeAllMonitor, PlatingCellState.Idle); //直接进入Idle Transition(PlatingCellState.Initialized, FSM_MSG.TIMER, NullFunc, PlatingCellState.Idle); //Enter Init Transition(PlatingCellState.Idle, ReservoirMsg.Init, NullFunc, PlatingCellState.Init); EnumLoop.ForEach((item) => { fsm.MapState((int)item, item.ToString()); }); EnumLoop.ForEach((item) => { fsm.MapMessage((int)item, item.ToString()); }); } #region Initialize All /// /// 初始化 /// /// private bool InitializeAll(object[] param) { if (_persistentValue == null) { LOG.WriteLog(eEvent.ERR_RESERVOIR, Module.ToString(), "persistent is null"); return false; } return true; } /// /// Initialize 监控 /// /// /// private bool InitializeAllMonitor(object[] param) { RState ret = RState.Init; if (ret == RState.Failed || ret == RState.Timeout) { PostMsg(ReservoirMsg.Error); return false; } return ret == RState.End; } #endregion /// /// EnterInit /// public void EnterInit() { if ((PlatingCellState)fsm.State != PlatingCellState.Idle) return; else { CheckToPostMessage(eEvent.ERR_PLATINGCELL, Module.ToString(), (int)PlatingCellMsg.Init); } } public bool Check(int msg, out string reason, params object[] args) { reason = ""; return true; } public bool CheckAcked(int msg) { throw new NotImplementedException(); } public int Invoke(string function, params object[] args) { throw new NotImplementedException(); } } }