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 LoadPortUnclampRoutine : ModuleRoutineBase, IRoutine { enum RoutineStep { WaitEFEMIdle, Unclamp, End, } private int _timeout = 0; private LoadPortModule _lpModule; public LoadPortUnclampRoutine(LoadPortModule lpModule) : base(ModuleHelper.Converter(lpModule.Module)) { _lpModule = lpModule; Name = "Unclamp"; } 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.Unclamp, Unclamp, CheckDevice, _timeout * 1000) .End(RoutineStep.End, NullFun, _delay_1s); return Runner.Status; } public bool Unclamp() { Notify($"Start unclamp {_lpModule.LPDevice.Module}"); _lpModule.LPDevice.Unclamp(); return true; } bool CheckDevice() { if (_lpModule.LPDevice.IsError) return false; if (_lpModule.LPDevice.IsBusy) return false; return true; } public void Abort() { } } }