| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692 | using Aitex.Core.RT.Fsm;using Aitex.Core.Util;using MECF.Framework.Common.CommonData;using MECF.Framework.Common.Equipment;using MECF.Framework.Common.SubstrateTrackings;using CyberX8_Core;using CyberX8_RT.Modules;using CyberX8_RT.Modules.Loader;using CyberX8_RT.Modules.Transporter;using CyberX8_RT.Modules.PUF;using System;using System.Collections.Generic;using System.Linq;using System.ServiceModel.Syndication;using System.Text;using System.Threading.Tasks;using CyberX8_RT.Modules.Prewet;using Aitex.Core.RT.Device;using CyberX8_RT.Devices.AXIS;using MECF.Framework.Common.WaferHolder;using Aitex.Core.RT.Log;using MECF.Framework.Common.Schedulers;namespace CyberX8_RT.Schedulers.Transporter{    public class SchedulerLoaderTransporter : SchedulerModule    {        private enum TransBufferToLoaderStep        {            None,            NotifyLoaderPrepare,            WaitLoaderPrePare,            PickUpValidate,            PickUpValidateMoveto,            Place,            End        }        private enum TransporterFlip        {            None,            WaitPickUp,            LoaderFlip,            WaitLoader,            WaitPlace,        }        #region 内部变量        private LoaderEntity _loaderEntity;        private TransporterEntity _loaderTransporterEntity;        private TransporterEntity _processTransporterEntity;        private TransBufferToLoaderStep _transBufferToLoaderStep = TransBufferToLoaderStep.None;        private SchedulerPostMsg _schedulerPostMsg = new SchedulerPostMsg();        private bool _postMsgResult = false;        private TransporterFlip _transporterFlip=TransporterFlip.None;        #endregion        #region 属性        public override bool IsIdle        {            get { return _state == RState.End; }        }        public  bool IsBusy        {            get { return _state == RState.Running; }        }        public override bool IsError        {            get { return _state==RState.Failed||_state==RState.Timeout; }        }        #endregion        /// <summary>        /// 构造函数        /// </summary>        /// <param name="module"></param>        public SchedulerLoaderTransporter(ModuleName module) : base(module.ToString())        {            _loaderEntity = Singleton<RouteManager>.Instance.GetModule<LoaderEntity>(ModuleName.Loader1.ToString());            _loaderTransporterEntity = Singleton<RouteManager>.Instance.GetModule<TransporterEntity>(ModuleName.Transporter2.ToString());            _processTransporterEntity = Singleton<RouteManager>.Instance.GetModule<TransporterEntity>(ModuleName.Transporter1.ToString());        }        /// <summary>        /// 执行        /// </summary>        /// <param name="parameter"></param>        /// <returns></returns>        public override bool RunProcess(object recipe, object parameter,List<SchedulerSyncModuleMessage> syncMessages)        {            if (parameter==null)            {                return false;            }            TransporterAction action = (TransporterAction)parameter;            if (action.ActionMsg == TransporterMSG.Transfer)            {                SynchorinzeModuleMessages(syncMessages);                WaferHolderMoveItem waferHolderMoveItem = (WaferHolderMoveItem)action.Parameter;                if (waferHolderMoveItem.SourceModule != ModuleName.Unknown && waferHolderMoveItem.DestModule != ModuleName.Unknown)                {                    SchedulerProcessTransporter schedulerProcessTransporter = (SchedulerProcessTransporter)SchedulerManager.Instance.GetScheduler(ModuleName.Transporter1);                    if (schedulerProcessTransporter.IsBusy && _processTransporterEntity.IsIdle)                    {                        return false;                    }                    if (!_loaderTransporterEntity.CheckOtherEntityStatus(waferHolderMoveItem.SourceModule.ToString()))                    {                        return false;                    }                    if (!_loaderTransporterEntity.CheckOtherEntityStatus(waferHolderMoveItem.DestModule.ToString()))                    {                        return false;                    }                    string strSource = waferHolderMoveItem.SourceModule.ToString();                    if (waferHolderMoveItem.SourceModule == ModuleName.Loader1)                    {                        strSource = "Loader";                    }                    //由于PickUpValidate可能存在校验失败的现象                    if (!WaferHolderManager.Instance.HasWaferHolder(strSource) && _loaderTransporterEntity.State != (int)TransporterState.PickUpValidateComplete)                    {                        return false;                    }                    string strDest = waferHolderMoveItem.DestModule.ToString();                    if (waferHolderMoveItem.DestModule == ModuleName.Loader1)                    {                        strDest = "Loader";                    }                    if (WaferHolderManager.Instance.HasWaferHolder(strDest))                    {                        return false;                    }                    if (waferHolderMoveItem.DestModule == ModuleName.Loader1)                    {                        return TransferWaferHolderToLoader(waferHolderMoveItem);                    }                    else if (waferHolderMoveItem.SourceModule == ModuleName.Loader1)                    {                        return TransWaferHolderFromLoader(waferHolderMoveItem);                    }                    else if (waferHolderMoveItem.SourceModuleType != ModuleType.Loader && waferHolderMoveItem.DestModuleType != ModuleType.Loader)                    {                        return TransferWaferHolderNonLoader(waferHolderMoveItem);                    }                }            }            else if (action.ActionMsg == TransporterMSG.Flip)            {                return FlipLoader();            }            return true;        }        /// <summary>        /// Loader 开始Flip        /// </summary>        /// <returns></returns>        private bool FlipLoader()        {            if (_loaderEntity.WaferHolderInfo == null)            {                return false;            }            if (_loaderTransporterEntity.WaferHolderInfo != null)            {                return false;            }            bool result = _loaderTransporterEntity.CheckToPostMessage<TransporterState, TransporterMSG>(eEvent.WARN_TRANSPORTER,                Module.ToString(), (int)TransporterMSG.PickUpFrom, "Loader");            if (result)            {                _state = RState.Running;                _schedulerPostMsg.Reset();                _postMsgResult = false;                _transporterFlip = TransporterFlip.WaitPickUp;            }            return result;        }        /// <summary>        /// WaferHolder从Loader移动至Buffer        /// </summary>        private bool TransWaferHolderFromLoader(WaferHolderMoveItem waferHolderMoveItem)        {            if (_loaderEntity.IsBusy)            {                return false;            }            if (_loaderEntity.WaferHolderInfo == null)            {                return false;            }            bool result = _loaderTransporterEntity.CheckToPostMessage<TransporterState, TransporterMSG>(Aitex.Core.RT.Log.eEvent.WARN_TRANSPORTER,                Module.ToString(), (int)TransporterMSG.Transfer, "Loader", waferHolderMoveItem.DestModule.ToString());            if (result)            {                _state = RState.Running;                _schedulerPostMsg.Reset();                _postMsgResult = false;            }            return result;        }        /// <summary>        /// WaferHolder从Buffer移动至Loader        /// </summary>        private bool TransferWaferHolderToLoader(WaferHolderMoveItem waferHolderMoveItem)        {            if (_loaderEntity.WaferHolderInfo != null)            {                return false;            }            if (_loaderEntity.IsIdle)            {                bool loaderResult = _loaderEntity.CheckToPostMessage<LOADERSTATE, LoaderMSG>(eEvent.WARN_LOADER,                    _loaderEntity.Module.ToString(), (int)LoaderMSG.PrepareForPlace);                if (loaderResult)                {                    _transBufferToLoaderStep = TransBufferToLoaderStep.WaitLoaderPrePare;                }                return false;            }            else if (_loaderEntity.State == (int)LOADERSTATE.WaitForUnload&&_transBufferToLoaderStep<TransBufferToLoaderStep.PickUpValidate)            {                _transBufferToLoaderStep = TransBufferToLoaderStep.PickUpValidate;                return false;            }            else if (_transBufferToLoaderStep == TransBufferToLoaderStep.WaitLoaderPrePare)            {                if (_loaderEntity.State == (int)LOADERSTATE.WaitForUnload)                {                    _transBufferToLoaderStep = TransBufferToLoaderStep.PickUpValidate;                }                return false;            }            else if (_transBufferToLoaderStep == TransBufferToLoaderStep.PickUpValidate)            {                if(_loaderTransporterEntity.IsBusy)                {                    return false;                }                if (!_loaderTransporterEntity.CheckOtherEntityStatus(waferHolderMoveItem.SourceModule.ToString()))                {                    return false;                }                if (!_loaderTransporterEntity.CheckOtherEntityStatus(waferHolderMoveItem.DestModule.ToString()))                {                    return false;                }                bool result = _loaderTransporterEntity.CheckToPostMessage<TransporterState, TransporterMSG>(Aitex.Core.RT.Log.eEvent.WARN_TRANSPORTER,                    Module.ToString(), (int)TransporterMSG.PickUpValidate, waferHolderMoveItem.SourceModule.ToString());                if (result)                {                    _transBufferToLoaderStep= TransBufferToLoaderStep.PickUpValidateMoveto;                    _state = RState.Running;                    _schedulerPostMsg.Reset();                    _postMsgResult = false;                    return true;                }            }            return false;        }        /// <summary>        /// 传输WaferHolder(无WaferHolder)        /// </summary>        /// <param name="waferHolderMoveItem"></param>        private bool TransferWaferHolderNonLoader(WaferHolderMoveItem waferHolderMoveItem)        {            IModuleEntity moduleEntity = Singleton<RouteManager>.Instance.GetModule<IModuleEntity>(waferHolderMoveItem.DestModule.ToString());            if (moduleEntity != null)            {                if (waferHolderMoveItem.SourceModule == ModuleName.Unknown || waferHolderMoveItem.DestModule == ModuleName.Unknown)                {                    return false;                }                if (moduleEntity.Module == ModuleName.Prewet1)                {                    PrewetEntity prewetEntity = moduleEntity as PrewetEntity;                    if(prewetEntity.State!=(int)PrewetState.WaitForPlace)                    {                        return false;                    }                }                else                {                    if (!moduleEntity.IsIdle)                    {                        return false;                    }                }                if (waferHolderMoveItem.SourceModule != ModuleName.Unknown)                {                    if (!_loaderTransporterEntity.CheckOtherEntityStatus(waferHolderMoveItem.SourceModule.ToString()))                    {                        return false;                    }                }                if (waferHolderMoveItem.DestModule != ModuleName.Unknown)                {                    if (!_loaderTransporterEntity.CheckOtherEntityStatus(waferHolderMoveItem.DestModule.ToString()))                    {                        return false;                    }                }                bool result = _loaderTransporterEntity.CheckToPostMessage<TransporterState, TransporterMSG>(Aitex.Core.RT.Log.eEvent.WARN_TRANSPORTER,                    Module.ToString(), (int)TransporterMSG.Transfer, waferHolderMoveItem.SourceModule.ToString(), waferHolderMoveItem.DestModule.ToString());                if (result)                {                    _state = RState.Running;                    _postMsgResult = false;                    _schedulerPostMsg.Reset();                }                return result;            }            return false;        }        /// <summary>        /// 监控执行        /// </summary>        /// <returns></returns>        public override bool MonitorProcess(SchedulerSequence schedulerSequence, bool hasMatchWafer)        {            TransporterAction action=schedulerSequence.Parameters as TransporterAction;            if (action.ActionMsg == TransporterMSG.Transfer)            {                WaferHolderMoveItem moveItem = action.Parameter as WaferHolderMoveItem;                //检验PostMsg的结果                if (!_postMsgResult)                {                    if (_loaderTransporterEntity.IsError)                    {                        return false;                    }                    _postMsgResult = CheckPostMsg(moveItem);                    if (!_postMsgResult)                    {                        return false;                    }                }                if (moveItem.DestModule == ModuleName.Loader1)                {                    if (_transBufferToLoaderStep == TransBufferToLoaderStep.PickUpValidateMoveto)                    {                        if (_loaderTransporterEntity.IsIdle)                        {                            _state = RState.Failed;                            _transBufferToLoaderStep = TransBufferToLoaderStep.None;                            return false;                        }                        if (_loaderTransporterEntity.State == (int)TransporterState.PickUpValidateComplete)                        {                            if (!_loaderTransporterEntity.CheckOtherEntityStatus("Loader"))                            {                                return false;                            }                            bool result = _loaderTransporterEntity.CheckToPostMessage<TransporterState, TransporterMSG>(Aitex.Core.RT.Log.eEvent.WARN_TRANSPORTER,                                    Module.ToString(), (int)TransporterMSG.MoveTo, "Loader");                            if (result)                            {                                _transBufferToLoaderStep = TransBufferToLoaderStep.Place;                            }                        }                        return true;                    }                    else if (_transBufferToLoaderStep == TransBufferToLoaderStep.Place)                    {                        if (_loaderTransporterEntity.State == (int)TransporterState.ValidateMoveToComplete)                        {                            bool result = _loaderTransporterEntity.CheckToPostMessage<TransporterState, TransporterMSG>(Aitex.Core.RT.Log.eEvent.WARN_TRANSPORTER,                                    Module.ToString(), (int)TransporterMSG.Place, "Loader");                            if (result)                            {                                _transBufferToLoaderStep = TransBufferToLoaderStep.End;                            }                        }                        return true;                    }                }                if (_loaderTransporterEntity.IsIdle)                {                    if (_loaderTransporterEntity.WaferHolderInfo != null)                    {                        return false;                    }                    PrewetPickComplete(schedulerSequence);                    _state = RState.End;                    _transBufferToLoaderStep=TransBufferToLoaderStep.None;                }            }            else if (action.ActionMsg == TransporterMSG.Flip)            {                LoaderTransporterFlip();            }            return true;        }        /// <summary>        /// Flip        /// </summary>        private void LoaderTransporterFlip()        {            if(_transporterFlip==TransporterFlip.WaitPickUp)            {                //检验PostMsg的结果                if (!_postMsgResult)                {                    if (_loaderTransporterEntity.IsError)                    {                        return;                    }                    _postMsgResult = _schedulerPostMsg.PostMsg<TransporterState, TransporterMSG>(_loaderTransporterEntity, _loaderTransporterEntity.State,                        eEvent.WARN_TRANSPORTER, Module.ToString(), (int)TransporterMSG.PickUpFrom,(int)TransporterState.PickUping, "Loader");                    if (!_postMsgResult)                    {                        return;                    }                }                if (_loaderTransporterEntity.IsIdle && _loaderTransporterEntity.WaferHolderInfo != null)                {                    _transporterFlip = TransporterFlip.LoaderFlip;                }            }            else if (_transporterFlip == TransporterFlip.LoaderFlip)            {                bool result = _loaderEntity.CheckToPostMessage<LOADERSTATE, LoaderMSG>(eEvent.WARN_LOADER, Module.ToString(), (int)LoaderMSG.PrepareForPlace, "TRNPB");                if (result)                {                    _transporterFlip = TransporterFlip.WaitLoader;                }            }            else if(_transporterFlip==TransporterFlip.WaitLoader)            {                if (_loaderEntity.State == (int)LOADERSTATE.WaitForUnload)                {                    bool result = _loaderTransporterEntity.CheckToPostMessage<TransporterState, TransporterMSG>(eEvent.WARN_TRANSPORTER,                                    Module.ToString(), (int)TransporterMSG.Place, "Loader");                    if (result)                    {                        _transporterFlip = TransporterFlip.WaitPlace;                    }                }            }            else if (_transporterFlip == TransporterFlip.WaitPlace)            {                if (_loaderTransporterEntity.IsIdle && _loaderTransporterEntity.WaferHolderInfo == null)                {                    _state = RState.End;                    _transporterFlip = TransporterFlip.None;                }            }        }         /// <summary>        /// 检验PostMsg的结果        /// </summary>        /// <param name="waferHolderMoveItem"></param>        /// <returns></returns>        private bool CheckPostMsg(WaferHolderMoveItem waferHolderMoveItem)        {            if (waferHolderMoveItem.DestModule == ModuleName.Loader1)            {                return _schedulerPostMsg.PostMsg<TransporterState,TransporterMSG>(_loaderTransporterEntity, _loaderTransporterEntity.State,                     eEvent.WARN_TRANSPORTER,Module.ToString(), (int)TransporterMSG.PickUpValidate,                     (int)TransporterState.PickUpValidating, waferHolderMoveItem.SourceModule.ToString());            }            else            {                return _schedulerPostMsg.PostMsg<TransporterState, TransporterMSG>(_loaderTransporterEntity, _loaderTransporterEntity.State,                    eEvent.WARN_TRANSPORTER, Module.ToString(), (int)TransporterMSG.Transfer,                    (int)TransporterState.Transfering, waferHolderMoveItem.SourceModule.ToString(),waferHolderMoveItem.DestModule.ToString());            }        }        /// <summary>        /// PrewetPick完成事件        /// </summary>        private void PrewetPickComplete(SchedulerSequence sequence)        {            if (sequence.Parameters is TransporterAction)            {                TransporterAction action = (TransporterAction)sequence.Parameters;                if (action.ActionMsg!=TransporterMSG.Transfer)                {                    return;                }                WaferHolderMoveItem waferHolderMoveItem = (WaferHolderMoveItem)action.Parameter;                if (waferHolderMoveItem.SourceModule == ModuleName.Prewet1)                {                    PrewetEntity prewetEntity = Singleton<RouteManager>.Instance.GetModule<PrewetEntity>(ModuleName.Prewet1.ToString());                    if (prewetEntity.State == (int)PrewetState.WaitForPick)                    {                        prewetEntity.CheckToPostMessage<PrewetState, PrewetMsg>(Aitex.Core.RT.Log.eEvent.WARN_PREWET, ModuleName.Prewet1.ToString(),                            (int)PrewetMsg.PickComplete);                    }                }            }        }        /// <summary>        /// 检验前置条件        /// </summary>        /// <param name="sequenceIndex"></param>        /// <param name="parameter"></param>        /// <returns></returns>        public override bool CheckPrecondition(List<SchedulerSequence> schedulerSequences, int sequenceIndex, object parameter, string materialId, ref string reason)        {            _state = RState.Init;            if(!(parameter is TransporterAction))            {                reason = "parameter is not TransporterAction";                return false;            }            TransporterAction action = (TransporterAction)parameter;            if (_state == RState.Running)            {                reason = "scheduler module is already running";                return false;            }            if (_loaderTransporterEntity.IsBusy)            {                reason = "loader transporter entity is busy";                return false;            }            if (_loaderTransporterEntity.WaferHolderInfo != null&& _loaderTransporterEntity.State != (int)TransporterState.PickUpValidateComplete)            {                reason = "loader transporter has wafer shuttle,but state is not PickUpValidateComplete";                return false;            }            //电机是否还在执行动作            JetAxisBase gantryAxis = DEVICE.GetDevice<JetAxisBase>($"{ModuleName.Transporter2}.Gantry");            if (gantryAxis == null)            {                reason = "loader transporter gantry is null";                return false;            }            if (gantryAxis.Status == RState.Running)            {                reason = "loader transporter gantry is running";                return false;            }            JetAxisBase elevatorAxis = DEVICE.GetDevice<JetAxisBase>($"{ModuleName.Transporter2}.Elevator");            if (elevatorAxis == null)            {                reason = "loader transporter elevator is null";                return false;            }            if (elevatorAxis.Status == RState.Running)            {                reason = "loader transporter elevator is running";                return false;            }            if (action.ActionMsg == TransporterMSG.Transfer)            {                WaferHolderMoveItem waferHolderMoveItem = (WaferHolderMoveItem)action.Parameter;                //更新未知目标模块                bool result = UpdateUnkownTargetModule(schedulerSequences, waferHolderMoveItem, sequenceIndex, materialId);                if (!result)                {                    reason = "loader transporter moveitem target module is unknown";                    return false;                }                //更新未知源模块                UpdateUnkownSourceModule(schedulerSequences, waferHolderMoveItem, sequenceIndex, materialId);                if (waferHolderMoveItem.SourceModule != ModuleName.Unknown)                {                    if (!_loaderTransporterEntity.CheckOtherEntityStatus(waferHolderMoveItem.SourceModule.ToString()))                    {                        reason = $"loader transporter {waferHolderMoveItem.SourceModule} conflict process transporter";                        return false;                    }                }                if (waferHolderMoveItem.DestModule != ModuleName.Unknown)                {                    if (!_loaderTransporterEntity.CheckOtherEntityStatus(waferHolderMoveItem.DestModule.ToString()))                    {                        reason = $"loader transporter {waferHolderMoveItem.DestModule} conflict process transporter";                        return false;                    }                }                //目标为Prewet                if (waferHolderMoveItem.DestModule == ModuleName.Prewet1)                {                    bool prewetCondition = CheckTargetPrewetCondition();                    if (!prewetCondition)                    {                        reason = "loader transporter destmodule prewet condition is not avaible";                    }                    return prewetCondition;                }                //源为Prewet                if (waferHolderMoveItem.SourceModule == ModuleName.Prewet1)                {                    bool prewetCondition = CheckSourcePrewetCondition();                    if (!prewetCondition)                    {                        reason = "loader transporter sourcemodule prewet condition is not avaible";                    }                }            }            return true;        }        /// <summary>        /// 更新未知目标模块        /// </summary>        private bool UpdateUnkownTargetModule(List<SchedulerSequence> schedulerSequences, WaferHolderMoveItem waferHolderMoveItem, int sequenceIndex,string materialId)        {            SchedulerSequence currentSequence = schedulerSequences[sequenceIndex];            if (waferHolderMoveItem.DestModule == ModuleName.Unknown)            {                ModuleName moduleName = SchedulerSequenceManager.Instance.GetAvaibleEmptyModuleCell(waferHolderMoveItem.DestModuleType,currentSequence.SequenceType);                if (moduleName == ModuleName.Unknown)                {                    return false;                }                else                {                    waferHolderMoveItem.DestModule = moduleName;                    if (sequenceIndex + 1 < schedulerSequences.Count)                    {                        SchedulerSequence sequence = schedulerSequences[sequenceIndex + 1];                        if (sequence.SchedulerModule == null)                        {                            sequence.SchedulerModule = SchedulerManager.Instance.GetScheduler(moduleName);                            sequence.ModuleName = moduleName;                            LOG.WriteLog(eEvent.INFO_TRANSPORTER, Module.ToString(), $"{materialId} loadertransporter confirm source module {moduleName}");                        }                    }                }            }            return true;        }        /// <summary>        /// 更新未知源模块        /// </summary>        private void UpdateUnkownSourceModule(List<SchedulerSequence> schedulerSequences, WaferHolderMoveItem waferHolderMoveItem,int sequenceIndex,string materialId)        {            if (waferHolderMoveItem.SourceModule == ModuleName.Unknown)            {                if (sequenceIndex >= 1 && sequenceIndex - 1 < schedulerSequences.Count)                {                    SchedulerSequence preSchedulerSequence = schedulerSequences[sequenceIndex - 1];                    if (preSchedulerSequence != null && preSchedulerSequence.SchedulerModule != null)                    {                        waferHolderMoveItem.SourceModule = preSchedulerSequence.SchedulerModule.Module;                        LOG.WriteLog(eEvent.INFO_TRANSPORTER, Module.ToString(), $"{materialId} loadertransporter confirm source module {preSchedulerSequence.SchedulerModule.Module}");                    }                }            }        }        /// <summary>        /// 检验目标Prewet前置条件        /// </summary>        /// <returns></returns>        private bool CheckTargetPrewetCondition()        {            PrewetEntity prewetEntity = Singleton<RouteManager>.Instance.GetModule<PrewetEntity>(ModuleName.Prewet1.ToString());            if(prewetEntity.IsIdle)            {                prewetEntity.CheckToPostMessage<PrewetState, PrewetMsg>(Aitex.Core.RT.Log.eEvent.WARN_PREWET, ModuleName.Prewet1.ToString(),                    (int)PrewetMsg.PrepareToPlace);            }            else if(prewetEntity.State==(int)PrewetState.WaitForPlace)            {                return true;            }            return false;        }        /// <summary>        /// 检验源Prewet前置条件        /// </summary>        /// <returns></returns>        private bool CheckSourcePrewetCondition()        {            PrewetEntity prewetEntity = Singleton<RouteManager>.Instance.GetModule<PrewetEntity>(ModuleName.Prewet1.ToString());            if (prewetEntity.State == (int)PrewetState.WaitForPick||prewetEntity.IsError)            {                return true;            }            return false;        }        public override void ResetTask()        {            base.ResetTask();            _schedulerPostMsg.Reset();            _postMsgResult = false;        }    }}
 |