| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151 | 
							- using Aitex.Core.Common;
 
- using Aitex.Core.RT.Fsm;
 
- using Aitex.Core.RT.Log;
 
- using Aitex.Core.RT.SCCore;
 
- using Aitex.Core.Util;
 
- using Aitex.Sorter.Common;
 
- using MECF.Framework.Common.Equipment;
 
- using MECF.Framework.Common.Schedulers;
 
- using MECF.Framework.Common.SubstrateTrackings;
 
- using FurnaceRT.Equipments.PMs;
 
- using FurnaceRT.Equipments.Systems;
 
- using System;
 
- namespace FurnaceRT.Equipments.Schedulers
 
- {
 
-     public class SchedulerPM : SchedulerModule
 
-     {
 
-         public override bool IsAvailable
 
-         {
 
-             get { return _pm.IsReady && _pm.IsOnline && CheckTaskDone(); }
 
-         }
 
-         public override bool IsOnline
 
-         {
 
-             get { return _pm.IsOnline; }
 
-         }
 
-         public override bool IsError
 
-         {
 
-             get { return _pm.IsError; }
 
-         }
 
-         private PMModuleBase _pm = null;
 
-         private ModuleName _taskRobot;
 
-         private EnumTransferType _taskTransferType;
 
-         private int _taskSlot;
 
-         private DeviceTimer _timer = new DeviceTimer();
 
-         public DateTime RecipeStartTime => _recipeStartTime;
 
-         private DateTime _recipeStartTime;
 
-         public SchedulerPM(ModuleName chamber) : base(chamber.ToString())
 
-         {
 
-             _pm = Singleton<EquipmentManager>.Instance.Modules[chamber] as PMModuleBase;
 
-             //System.Diagnostics.Trace.Assert(_pm!=null);
 
-         }
 
-         public override bool IsReadyForPick(ModuleName robot, int slot)
 
-         {
 
-             return _pm.CheckReadyForTransfer(robot, Hand.Blade1, slot, EnumTransferType.Pick, out _)
 
-                    && WaferManager.Instance.CheckHasWafer(ModuleHelper.Converter(_module), 0);
 
-         }
 
-         public override bool IsReadyForPlace(ModuleName robot, int slot)
 
-         {
 
-             return _pm.CheckReadyForTransfer(robot, Hand.Blade1, slot, EnumTransferType.Place, out _)
 
-                    && WaferManager.Instance.CheckNoWafer(ModuleHelper.Converter(_module), 0);
 
-         }
 
-         public override bool PrepareTransfer(ModuleName robot, EnumTransferType type, int slot)
 
-         {
 
-             _task = TaskType.PrepareTransfer;
 
-             _taskRobot = robot;
 
-             _taskSlot = slot;
 
-             _taskTransferType = type;
 
-             if (!_pm.PrepareTransfer(robot, Hand.Blade1, slot, type, out string reason))
 
-             {
 
-                 LOG.Write(reason);
 
-                 return false;
 
-             }
 
-             LogTaskStart(_task, $"{robot} {type} slot {slot + 1}");
 
-             return true;
 
-         }
 
-         public bool IsPrepareTransfer(ModuleName robot, EnumTransferType type, int slot)
 
-         {
 
-             return _task == TaskType.PrepareTransfer && _taskRobot == robot && _taskSlot == slot &&
 
-                    _taskTransferType == type;
 
-         }
 
-         public override bool Process(string recipeName, bool isCleanRecipe, bool withWafer)
 
-         {
 
-             _task = TaskType.Process;
 
-             _recipeStartTime = DateTime.Now;
 
-             if (!_pm.Process(recipeName, isCleanRecipe, withWafer, out string reason))
 
-             {
 
-                 LOG.Write(reason);
 
-                 return false;
 
-             }
 
-             LogTaskStart(_task, $"recipe: {recipeName}, clean: {isCleanRecipe}, with wafer: {withWafer}");
 
-             return true;
 
-         }
 
-         public override bool Standby(string recipeName)
 
-         {
 
-             _task = TaskType.Standby;
 
-             if (!_pm.Standby(recipeName, out string reason))
 
-             {
 
-                 LOG.Write(reason);
 
-             }
 
-             LogTaskStart(_task, $"recipe: {recipeName}");
 
-             return true;
 
-         }
 
-         public bool CheckStandbyCondition()
 
-         {
 
-             return _pm.CheckStandbyCondition();
 
-         }
 
-         public bool CheckTaskDone()
 
-         {
 
-             bool ret = false;
 
-             switch (_task)
 
-             {
 
-                 case TaskType.None:
 
-                 case TaskType.Standby:
 
-                     ret = true;
 
-                     break;
 
-                 case TaskType.PrepareTransfer:
 
-                     ret = _pm.CheckReadyForTransfer(_taskRobot, Hand.Blade1, _taskSlot, _taskTransferType, out _);
 
-                     break;
 
-                 case TaskType.Process:
 
-                     ret = _pm.IsReady;
 
-                     break;
 
-             }
 
-             if (ret && _task != TaskType.None)
 
-             {
 
-                 LogTaskDone(_task, "");
 
-                 _task = TaskType.None;
 
-             }
 
-             return ret;
 
-         }
 
-         public bool Monitor()
 
-         {
 
-             return true;
 
-         }
 
-     }
 
- }
 
 
  |