using System; using Aitex.Core.RT.Device; using Aitex.Core.RT.Log; using Aitex.Core.RT.Routine; using Aitex.Core.RT.SCCore; using MECF.Framework.Common.Equipment; using CyberX8_Core; namespace CyberX8_RT.Modules.LPs { class LoadPortReadCarrierIdRoutine : ModuleRoutineBase, IRoutine { enum RoutineStep { WaitEFEMIdle, ReadCarrierId, End, } private int _timeout = 0; private LoadPortModule _lpModule; public LoadPortReadCarrierIdRoutine(LoadPortModule lpModule) : base(ModuleHelper.Converter(lpModule.Module)) { _lpModule = lpModule; Name = "ReadCarrierId"; } public RState Start(params object[] objs) { Reset(); _timeout = SC.GetValue("EFEM.LoadPort.MotionTimeout"); Notify($"Start"); return Runner.Start(Module, Name); } public RState Monitor() { Runner.Wait(RoutineStep.WaitEFEMIdle, () => _lpModule.IsRobotIdle) .Run(RoutineStep.ReadCarrierId, ReadCarrierId, CheckDevice, _timeout * 1000) .End(RoutineStep.End, NullFun, _delay_1s); return Runner.Status; } public bool ReadCarrierId() { Notify($"Start read carrier id {_lpModule.LPDevice.Module}"); _lpModule.LPDevice.ReadCarrierID(); return true; } bool CheckDevice() { if (_lpModule.LPDevice.IsError) return false; if (_lpModule.LPDevice.IsBusy) return false; return true; } public void Abort() { } } }