| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687 | 
							- using System;
 
- using Aitex.Core.RT.Device;
 
- using Aitex.Core.RT.Event;
 
- using Aitex.Core.RT.Log;
 
- using Aitex.Core.RT.Routine;
 
- using Aitex.Core.RT.SCCore;
 
- using MECF.Framework.Common.Equipment;
 
- using Venus_Core;
 
- namespace Venus_RT.Modules.LPs
 
- {
 
-     class LoadPortLoadRoutine : ModuleRoutineBase, IRoutine
 
-     {
 
-         enum RoutineStep
 
-         {
 
-             WaitEFEMIdle,
 
-             Load,
 
-             End,
 
-         }
 
-         private int _timeout = 0;
 
-  
 
-         private LoadPortModule _lpModule;
 
-         public LoadPortLoadRoutine(LoadPortModule lpModule) : base(ModuleHelper.Converter(lpModule.Module))
 
-         {
 
-             _lpModule = lpModule;
 
-             Name = "Load";
 
-         }
 
-  
 
-         public RState Start(params object[] objs)
 
-         {
 
-             Reset();
 
-             _timeout = SC.GetValue<int>("EFEM.LoadPort.MotionTimeout");
 
-             if (!_lpModule.LPDevice.HasCassette  )
 
-             {
 
-                 LOG.Write(eEvent.WARN_EFEM_COMMON_WARN, Module, $"{Module} not found carrier, can not load");
 
-                 return RState.Failed;
 
-             }
 
-             Notify($"Start");
 
-             return Runner.Start(Module, Name);
 
-         }
 
-         public RState Monitor()
 
-         {
 
-             Runner.Wait(RoutineStep.WaitEFEMIdle,   () => _lpModule.IsRobotIdle,    _delay_60s)
 
-                 .Run(RoutineStep.Load,              Load,                           CheckDevice,    _timeout * 1000)
 
-                 .End(RoutineStep.End,               NullFun,                        _delay_1s);
 
-             return Runner.Status;
 
-         }
 
-         public bool Load()
 
-         {
 
-             Notify($"Start Load {_lpModule.Name}");
 
-             _lpModule.LPDevice.Load();
 
-             return true;
 
-         }
 
-         bool CheckDevice()
 
-         {
 
-             if (_lpModule.LPDevice.IsError)
 
-                 return false;
 
-             if (_lpModule.LPDevice.IsBusy)
 
-                 return false;
 
-             return true;
 
-         }
 
-         public void Abort()
 
-         {
 
-             
 
-         }
 
-  
 
-     }
 
- }
 
 
  |