| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126 | 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.FIMSs;using FurnaceRT.Equipments.Systems;using FurnaceRT.Equipments.LPs;using System.Linq;namespace FurnaceRT.Equipments.Schedulers{    public class SchedulerLoadPort : SchedulerModule    {        public override bool IsAvailable        {            get { return _lp.IsReady && _lp.IsOnline && CheckTaskDone(); }        }        public override bool IsOnline        {            get { return _lp.IsOnline; }        }        public override bool IsError        {            get { return _lp.IsError; }        }        private LoadPortModule _lp = null;        private ModuleName _taskRobot;        private EnumTransferType _taskTransferType;        private int _taskSlot;        private DeviceTimer _timer = new DeviceTimer();        public SchedulerLoadPort(ModuleName chamber) : base(chamber.ToString())        {            _lp = Singleton<EquipmentManager>.Instance.Modules.FirstOrDefault(x=>x.Key == chamber).Value as LoadPortModule;        }        public override bool IsReadyForPick(ModuleName robot, int slot)        {            return _lp.CheckReadyForTransfer(robot, Hand.Blade1, slot, EnumTransferType.Pick, out _);        }        public override bool IsReadyForPlace(ModuleName robot, int slot)        {            return _lp.CheckReadyForTransfer(robot, Hand.Blade1, slot, EnumTransferType.Place, out _)                   && CarrierManager.Instance.CheckNoCarrier(ModuleHelper.Converter(_module), 0);        }        public override bool PrepareTransfer(ModuleName robot, EnumTransferType type, int slot)        {            _task = TaskType.PrepareTransfer;            _taskRobot = robot;            _taskSlot = slot;            _taskTransferType = type;            if (!_lp.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 Load()        {            _task = TaskType.Load;            _lp.InvokeLoad();            LogTaskStart(_task, $"{Module} load start");            return true;        }        public bool Unload()        {            _task = TaskType.Unload;            _lp.InvokeUnload();            LogTaskStart(_task, $"{Module} unload start");            return true;        }        public bool CheckTaskDone()        {            bool ret = false;            switch (_task)            {                case TaskType.None:                    ret = true;                    break;                case TaskType.PrepareTransfer:                    ret = _lp.CheckReadyForTransfer(_taskRobot, Hand.Blade1, _taskSlot, _taskTransferType, out _);                    break;                case TaskType.Load:                    ret = _lp.LPDevice.IsLoadCompleted;                    break;                case TaskType.Unload:                    ret = _lp.LPDevice.IsUnloadCompleted;                    break;            }            if (ret && _task != TaskType.None)            {                LogTaskDone(_task, "");                _task = TaskType.None;            }            return ret;        }        public bool Monitor()        {            return true;        }    }}
 |