using Aitex.Core.RT.Log; using Aitex.Core.RT.Routine; using Aitex.Core.RT.SCCore; using MECF.Framework.RT.EquipmentLibrary.HardwareUnits.LoadPorts; using System; using CyberX8_Core; using MECF.Framework.Common.Equipment; namespace CyberX8_RT.Modules.LPs { class LoadPortDockRoutine : ModuleRoutineBase, IRoutine { enum RoutineStep { WaitEFEMIdle, Dock, End, } public bool IsUnloadDock { get; set; } private int _timeout = 0; private LoadPortModule _lpModule; public LoadPortDockRoutine(LoadPortModule lpModule) : base( ModuleHelper.Converter(lpModule.Module)) { _lpModule = lpModule; Name = "Dock"; } 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.Dock, Dock, CheckDevice, _timeout * 1000) .End(RoutineStep.End, NullFun, _delay_1s); return Runner.Status; } public bool Dock() { Notify($"Start Dock {_lpModule.LPDevice.Module}"); return _lpModule.LPDevice.Dock(); } bool CheckDevice() { if (_lpModule.LPDevice.IsError) return false; if (_lpModule.LPDevice.IsBusy) return false; return true; } public void Abort() { } } }