using Aitex.Core.RT.Device;
using Aitex.Core.RT.Log;
using Aitex.Core.RT.Routine;
using Aitex.Core.RT.SCCore;
using CyberX8_Core;
using CyberX8_RT.Devices.SRD;
using CyberX8_RT.Modules.Transporter;
using MECF.Framework.Common.Routine;
using MECF.Framework.Common.Utilities;
namespace CyberX8_RT.Modules.SRD
{
public class SRDInitializeHomeRoutine : RoutineBase, IRoutine
{
private enum InitializeStep
{
Initialize,
InitializeWait,
SwitchOn,
SwitchOnWait,
Home,
HomeWait,
End
}
#region 内部变量
private SRDInitializeRoutine _initializeRoutine;
private SRDSwitchOnRoutine _switchOnRoutine;
private SRDHomeRoutine _homeRoutine;
#endregion
///
/// 构造函数
///
///
public SRDInitializeHomeRoutine(string module) : base(module)
{
_initializeRoutine = new SRDInitializeRoutine(module);
_switchOnRoutine = new SRDSwitchOnRoutine(module);
_homeRoutine = new SRDHomeRoutine(module);
}
///
/// 中止
///
public void Abort()
{
Runner.Stop("Manual Abort");
}
///
/// 监控
///
///
public RState Monitor()
{
Runner.Run(InitializeStep.Initialize, () => _initializeRoutine.Start() == RState.Running, _delay_1ms)
.WaitWithStopCondition(InitializeStep.InitializeWait, () => CommonFunction.CheckRoutineEndState(_initializeRoutine), () => CommonFunction.CheckRoutineStopState(_initializeRoutine))
.Run(InitializeStep.SwitchOn, () => _switchOnRoutine.Start() == RState.Running, _delay_1ms)
.WaitWithStopCondition(InitializeStep.SwitchOnWait, () => CommonFunction.CheckRoutineEndState(_switchOnRoutine), () => CommonFunction.CheckRoutineStopState(_switchOnRoutine))
.Run(InitializeStep.Home, () => _homeRoutine.Start() == RState.Running, _delay_1ms)
.WaitWithStopCondition(InitializeStep.HomeWait, () => CommonFunction.CheckRoutineEndState(_homeRoutine), () => CommonFunction.CheckRoutineStopState(_homeRoutine))
.End(InitializeStep.End, NullFun, _delay_1ms);
return Runner.Status;
}
///
/// 启动
///
///
///
public RState Start(params object[] objs)
{
if (!CheckPreCondition())
{
return RState.Failed;
}
return Runner.Start(Module, "Start Initialize Home");
}
private bool CheckPreCondition()
{
SrdCommonDevice srdCommon = DEVICE.GetDevice($"{Module}.Common");
bool isSimulator = SC.GetValue("System.IsSimulatorMode");
if (!isSimulator && srdCommon.CommonData.WaferPresent)
{
LOG.WriteLog(eEvent.ERR_SRD, Module, $"Wafer is present");
return false;
}
if (!srdCommon.CommonData.ChuckVacuum)
{
LOG.WriteLog(eEvent.ERR_SRD, Module, $"Chuck Vacuum is on");
return false;
}
int vacuumOffLimit = SC.GetValue("SRD.ChuckVacuumOffLimit");
if (srdCommon.CommonData.VacuumValue < vacuumOffLimit)
{
LOG.WriteLog(eEvent.ERR_SRD, Module, $"VacuumValue:{srdCommon.CommonData.VacuumValue}, VacuumOff Limit:{vacuumOffLimit}");
return false;
}
if (srdCommon.CommonData.ChuckATMOn)
{
LOG.WriteLog(eEvent.ERR_SRD, Module, $"Chuck ATM is on");
return false;
}
return true;
}
}
}