123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131 |
- using Aitex.Common.Util;
- using Aitex.Core.RT.ConfigCenter;
- using Aitex.Core.RT.Log;
- using Aitex.Core.Util;
- using MECF.Framework.Common.Equipment;
- using MECF.Framework.Common.RecipeCenter;
- using CyberX8_Core;
- using CyberX8_RT.Modules;
- using CyberX8_RT.Modules.Dryer;
- using CyberX8_RT.Modules.Loader;
- using CyberX8_RT.Modules.PUF;
- using CyberX8_RT.Schedulers.EfemRobot;
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- using System.Threading.Tasks;
- using CyberX8_RT.Modules.Metal;
- namespace CyberX8_RT.Schedulers.Dryer
- {
- public class SchedulerDryer : SchedulerModule
- {
- #region 内部变量
- private DryerEntity _dryerEntity;
- private bool _isStartRunRecipe = false;
- #endregion
- #region 属性
- /// <summary>
- /// 是否空闲
- /// </summary>
- public override bool IsIdle
- {
- get { return _state == RState.End; }
- }
- /// <summary>
- /// 是否错误
- /// </summary>
- public override bool IsError
- {
- get { return _state == RState.Failed || _state == RState.Timeout; }
- }
- #endregion
- /// <summary>
- /// 构造函数
- /// </summary>
- /// <param name="module"></param>
- public SchedulerDryer(ModuleName moduleName) : base(moduleName.ToString())
- {
- _dryerEntity = Singleton<RouteManager>.Instance.GetModule<DryerEntity>(moduleName.ToString());
- }
- /// <summary>
- /// 执行
- /// </summary>
- /// <param name="parameter"></param>
- /// <returns></returns>
- public override bool RunProcess(object recipe, object parameter, List<SchedulerSyncModuleMessage> syncModuleMessages)
- {
- if(!(recipe is HvdRecipe))
- {
- _state = RState.Failed;
- LOG.WriteLog(eEvent.ERR_DRYER, Module.ToString(), "recipe is invalid");
- return false;
- }
- _isStartRunRecipe = false;
- HvdRecipe hvdRecipe = (HvdRecipe)recipe;
- bool result= _dryerEntity.CheckToPostMessage<DryerState,DryerMsg>(eEvent.ERR_DRYER,Module.ToString(),(int)DryerMsg.RunRecipe, recipe,1);
- if(result)
- {
- _state = RState.Running;
- }
- return result;
- }
- /// <summary>
- /// 监控执行
- /// </summary>
- /// <returns></returns>
- public override bool MonitorProcess(SchedulerSequence schedulerSequence, bool hasMatchWafer)
- {
- if (!_isStartRunRecipe)
- {
- _isStartRunRecipe = _dryerEntity.State == (int)DryerState.RunReciping;
- }
- if(_isStartRunRecipe&&_dryerEntity.IsIdle)
- {
- _state = RState.End;
- _isStartRunRecipe= false;
- }
- if (_dryerEntity.IsError)
- {
- _state = RState.Failed;
- _isStartRunRecipe=false;
- }
- return true;
- }
- /// <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)
- {
- if (_state == RState.Running)
- {
- reason = "scheduler module is already running";
- return false;
- }
- if (_dryerEntity.WaferHolderInfo==null)
- {
- reason = $"{_dryerEntity.Module} has no wafer shuttle";
- return false;
- }
- if(_dryerEntity.IsBusy)
- {
- reason = $"{_dryerEntity.Module} is busy";
- return false;
- }
- if (_dryerEntity.WaferHolderInfo.Id != materialId)
- {
- reason = $"{_dryerEntity.Module} wafer shuttle {_dryerEntity.WaferHolderInfo.Id} is not matched with {materialId}";
- return false;
- }
- return true;
- }
- }
- }
|