| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980 | 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<int>("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()        {        }    }}
 |