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();
}
}
}