| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451 | using Aitex.Core.RT.Device;using System;using System.Collections.Generic;using System.Linq;using System.Net.Configuration;using System.Text;using System.Text.RegularExpressions;using System.Threading.Tasks;using Aitex.Core.Common;using Aitex.Core.RT.DataCenter;using Aitex.Core.RT.Event;using Aitex.Core.RT.OperationCenter;using Aitex.Core.RT.SCCore;using Aitex.Core.Util;using Aitex.Sorter.Common;using MECF.Framework.Common.Equipment;using MECF.Framework.RT.Core.Equipments;using MECF.Framework.Common.SubstrateTrackings;using MECF.Framework.RT.EquipmentLibrary.HardwareUnits.LoadPorts.TDK;namespace MECF.Framework.RT.EquipmentLibrary.HardwareUnits.LoadPorts{    public enum IndicatorType    {        Load,        Unload,        Presence,        Placement,        Alarm,        Access,        Status1,        Status2,    }     public abstract class LoadPort : BaseDevice, IDevice    {        public IndicatorState IndicatiorLoad { get; set; }        public IndicatorState IndicatiorUnload { get; set; }        public IndicatorState IndicatiorPresence { get; set; }        public IndicatorState IndicatorAlarm { get; set; }        public IndicatorState IndicatiorPlacement { get; set; }        public IndicatorState IndicatiorOpAccess { get; set; }        public IndicatorState IndicatiorStatus1 { get; set; }        public IndicatorState IndicatiorStatus2 { get; set; }        public virtual FoupClampState ClampState { get; set; }        public virtual FoupDoorState DoorState { get; set; }        public virtual CasstleType  CasstleType { get; set; }        public string SlotMap        {            get { return GetSlotMap(); }        }        public virtual bool IsBusy { get; set; }        public virtual bool IsIdle { get; set; }        public virtual bool IsMoving { get; set; }        public virtual LoadportCassetteState CassetteState        {            get;            set;        }        public bool IsMapWaferByLoadPort { get; set; }        public EnumLoadPortType PortType { get; set; }        public bool Initalized { get; set; }        public bool IsPresent        {            get { return _isPresent; }        }        public bool IsPlacement        {            get { return _isPlaced; }        }        public bool IsMapped        {            get { return _isMapped; }        }        public bool Error { get; set; }        public string ErrorCode { get; set; }                /// <summary>        /// 是否处于FOSB模式        /// </summary>        public bool IsFOSBMode { get; set; }                    public DeviceState State        {            get            {                if (!Initalized)                {                    return DeviceState.Unknown;                }                if (Error)                {                    return DeviceState.Error;                }                if (IsBusy)                    return DeviceState.Busy;                return DeviceState.Idle;            }        }        public string CarrierId        {            get { return _carrierId; }        }        public string RfId        {            get { return _rfid; }        }        protected bool _isPresent;        protected bool _isPlaced;        protected string _carrierId;        protected string _rfid;        protected bool _isMapped;        private ModuleName _module;        private ModuleStateEnum _state;        private List<List<string>> _waferId = new List<List<string>>();        private static bool _isIndependentCEID = SC.ContainsItem("Fa.IndependentCEIDForLp")?SC.GetValue<bool>("Fa.IndependentCEIDForLp"):false;        public string PortId        {            get { return (_lpIndex+1).ToString(); }        }        public string PortCategory        {            get            {                if (SC.GetConfigItem(PortLabelScNames[_lpIndex]) == null)                    return "";                return SC.GetStringValue(PortLabelScNames[_lpIndex]) ;            }        }        string[] PortStateVariableNames = new[]        {            "CARRIER_PORT1_STATE", "CARRIER_PORT2_STATE", "CARRIER_PORT3_STATE",            "CARRIER_PORT4_STATE", "CARRIER_PORT5_STATE", "CARRIER_PORT6_STATE", "CARRIER_PORT7_STATE",            "CARRIER_PORT8_STATE", "CARRIER_PORT9_STATE", "CARRIER_PORT10_STATE"        };        ModuleName[] PortModuleNames = new[]        {            ModuleName.LP1,ModuleName.LP2,ModuleName.LP3,ModuleName.LP4,ModuleName.LP5,            ModuleName.LP6,ModuleName.LP7,ModuleName.LP8,ModuleName.LP9,ModuleName.LP10,        };        string[] PortSlotMapVariableNames = new[]        {            "CARRIER_PORT1_CURRENT_SLOTMAP", "CARRIER_PORT2_CURRENT_SLOTMAP", "CARRIER_PORT3_CURRENT_SLOTMAP",            "CARRIER_PORT4_CURRENT_SLOTMAP", "CARRIER_PORT5_CURRENT_SLOTMAP", "CARRIER_PORT6_CURRENT_SLOTMAP", "CARRIER_PORT7_CURRENT_SLOTMAP",            "CARRIER_PORT8_CURRENT_SLOTMAP", "CARRIER_PORT9_CURRENT_SLOTMAP", "CARRIER_PORT10_CURRENT_SLOTMAP"        };        string[] PortWaferIdVariableNames = new[]        {            "CARRIER_PORT1_CURRENT_WAFERID", "CARRIER_PORT2_CURRENT_WAFERID", "CARRIER_PORT3_CURRENT_WAFERID",            "CARRIER_PORT4_CURRENT_WAFERID", "CARRIER_PORT5_CURRENT_WAFERID", "CARRIER_PORT6_CURRENT_WAFERID", "CARRIER_PORT7_CURRENT_WAFERID",            "CARRIER_PORT8_CURRENT_WAFERID", "CARRIER_PORT9_CURRENT_WAFERID", "CARRIER_PORT10_CURRENT_WAFERID"        };        private string[] PortLabelScNames = new[]        {            "LoadPort.LoadPort1CarrierLabel","LoadPort.LoadPort2CarrierLabel","LoadPort.LoadPort3CarrierLabel","LoadPort.LoadPort4CarrierLabel",            "LoadPort.LoadPort5CarrierLabel","LoadPort.LoadPort6CarrierLabel","LoadPort.LoadPort7CarrierLabel","LoadPort.LoadPort8CarrierLabel",            "LoadPort.LoadPort9CarrierLabel","LoadPort.LoadPort10CarrierLabel",        };        private int _lpIndex = -1;        private string EventCarrierArrived= "CARRIER_ARRIVED";        private string EventCarrierIdRead= "CARRIER_ID_READ";        private string EventCarrierIdReadFailed = "CARRIER_ID_READ_FAILED";        private string EventCarrierIdWrite = "CARRIER_ID_WRITE";        private string EventCarrierIdWriteFailed = "CARRIER_ID_WRITE_FAILED";        private string EventSlotMapAvailable= "SLOT_MAP_AVAILABLE";        private string EventCarrierRemoved = "CARRIER_REMOVED";        private string EventCarrierUnloaded = "CARRIER_UNLOADED";        private string EventCarrierloaded = "CARRIR_DOCK_COMPLETE";        private string PORT_ID = "PORT_ID";        private string CAR_ID = "CAR_ID";        private string SLOT_MAP = "SLOT_MAP";        private string PORT_CTGRY = "PORT_CTGRY";        private string RF_ID = "RF_ID";        private string EventRfIdRead = "RF_ID_READ";        private string EventRfIdReadFailed = "RF_ID_READ_FAILED";        private string EventRfIdWrite = "RF_ID_WRITE";#pragma warning disable 414        private string EventRfIdWriteFailed = "RF_ID_WRITE_FAILED";#pragma warning restore 414        private string AlarmCarrierPortError = "CarrierPortError";        public LoadPort(string module, string name):base(module, name, name, "")        {            for (int i = 0; i < 25; i++)            {                _waferId.Add(new List<string>()                {                    i.ToString("D2"),"","",""                });            }                 if (!Enum.TryParse(name, out ModuleName m))                    Enum.TryParse(module, out m);                _module = m;             _lpIndex = Array.IndexOf(PortModuleNames, _module);            DoorState = FoupDoorState.Unknown;            System.Diagnostics.Trace.Assert(_lpIndex != -1);        }        public virtual bool Initialize()        {            WaferManager.Instance.SubscribeLocation(_module, 25);            CarrierManager.Instance.SubscribeLocation(_module.ToString());             DATA.Subscribe(Name, "IsPresent", ()=>_isPresent);            DATA.Subscribe(Name, "IsPlaced", () => _isPlaced);            DATA.Subscribe(Name, "ModuleState", () => _state.ToString());            DATA.Subscribe(Name, "CarrierId", () => _carrierId);            DATA.Subscribe(Name, "IsMapped", () => _isMapped);            DATA.Subscribe($"{Name}.LoadportState", () => State);            DATA.Subscribe($"{Name}.LoadportBusy", () => IsBusy);            DATA.Subscribe($"{Name}.LoadportError", () => ErrorCode);            DATA.Subscribe($"{Name}.CassetteState", () => CassetteState);            DATA.Subscribe($"{Name}.FoupClampState", () => ClampState);            DATA.Subscribe($"{Name}.FoupDoorState", () => DoorState);            DATA.Subscribe($"{Name}.SlotMap", () => SlotMap);            DATA.Subscribe($"{Name}.IndicatiorLoad", () => IndicatiorLoad);            DATA.Subscribe($"{Name}.IndicatiorUnload", () => IndicatiorUnload);            DATA.Subscribe($"{Name}.IndicatiorPresence", () => IndicatiorPresence);            DATA.Subscribe($"{Name}.IndicatiorPlacement", () => IndicatiorPlacement);            DATA.Subscribe($"{Name}.IndicatiorAlarm", () => IndicatorAlarm);            DATA.Subscribe($"{Name}.IndicatiorOpAccess", () => IndicatiorOpAccess);            DATA.Subscribe($"{Name}.IndicatiorStatus1", () => IndicatiorStatus1);            DATA.Subscribe($"{Name}.IndicatiorStatus2", () => IndicatiorStatus2);            DATA.Subscribe($"{Name}.CasstleType", () => CasstleType);            DATA.Subscribe(PortStateVariableNames[_lpIndex], () => (_isPlaced && _isPresent) ? "1" : "0");            DATA.Subscribe(PortSlotMapVariableNames[_lpIndex], () => SlotMap);            DATA.Subscribe(PortWaferIdVariableNames[_lpIndex], UpdatedWaferIdList);            if (_isIndependentCEID)            {                                EV.Subscribe(new EventItem("Event", $"{_module}_{EventCarrierArrived}", "Carrier arrived"));                EV.Subscribe(new EventItem("Event", $"{_module}_{EventCarrierRemoved}", "Carrier removed"));                EV.Subscribe(new EventItem("Event", $"{_module}_{EventCarrierIdRead}", "Carrier ID read"));                EV.Subscribe(new EventItem("Event", $"{_module}_{EventCarrierIdReadFailed}", "Carrier ID read failed"));                EV.Subscribe(new EventItem("Event", $"{_module}_CAR_ID_WRITE_SUCCESSFULLY", "Carrier ID write"));                EV.Subscribe(new EventItem("Event", $"{_module}_CAR_ID_WRITE_FAIL", "Carrier ID write failed"));                EV.Subscribe(new EventItem("Event", $"{_module}_{EventSlotMapAvailable}", "Slot map available"));                EV.Subscribe(new EventItem("Event", $"{_module}_{EventCarrierUnloaded}", "Carrier unloaded"));                EV.Subscribe(new EventItem("Event", $"{_module}_CARRIR_LOAD_COMPLETE", "Carrier loaded"));                EV.Subscribe(new EventItem("Event", $"{_module}_{EventRfIdRead}", "Carrier RFID read"));                EV.Subscribe(new EventItem("Event", $"{_module}_{EventRfIdReadFailed}", "Carrier RFID read failed"));                EV.Subscribe(new EventItem("Event", $"{_module}_{EventRfIdWrite}", "Carrier RFID write"));                EV.Subscribe(new EventItem("Event", $"{_module}_{AlarmCarrierPortError}", "Carrier Port error", EventLevel.Alarm, EventType.HostNotification));            }            else            {                EV.Subscribe(new EventItem("Event", EventCarrierArrived, "Carrier arrived"));                EV.Subscribe(new EventItem("Event", EventCarrierRemoved, "Carrier removed"));                EV.Subscribe(new EventItem("Event", EventCarrierIdRead, "Carrier ID read"));                EV.Subscribe(new EventItem("Event", EventCarrierIdReadFailed, "Carrier ID read failed"));                EV.Subscribe(new EventItem("Event", EventCarrierIdWrite, "Carrier ID write"));                EV.Subscribe(new EventItem("Event", EventCarrierIdWriteFailed, "Carrier ID write failed"));                EV.Subscribe(new EventItem("Event", EventSlotMapAvailable, "Slot map available"));                EV.Subscribe(new EventItem("Event", EventCarrierUnloaded, "Carrier unloaded"));                EV.Subscribe(new EventItem("Event", EventCarrierloaded, "Carrier loaded"));                EV.Subscribe(new EventItem("Event", EventRfIdRead, "Carrier RFID read"));                EV.Subscribe(new EventItem("Event", EventRfIdReadFailed, "Carrier RFID read failed"));                EV.Subscribe(new EventItem("Event", EventRfIdWrite, "Carrier RFID write"));                EV.Subscribe(new EventItem("Event", AlarmCarrierPortError, "Carrier Port error", EventLevel.Alarm, EventType.HostNotification));            }            IsIdle = true;            _state = ModuleStateEnum.Idle;            RegisterOperation();            return true;        }        public virtual bool Connect()        {            return true;        }        private void RegisterOperation()        {            OP.Subscribe($"{Name}.LoadportHome", (string cmd, object[] param) =>            {                if (!Home(out string reason))                {                    EV.PostWarningLog(Module, $"{Name} can not start home, {reason}");                    return false;                }                EV.PostInfoLog(Module, $"{Name} start home");                return true;            });            OP.Subscribe($"{Name}.LoadportReset", (string cmd, object[] param) =>            {                if (!ClearError(out string reason))                {                    EV.PostWarningLog(Module, $"{Name} can not reset, {reason}");                    return false;                }                EV.PostInfoLog(Module, $"{Name} start reset");                return true;            });            OP.Subscribe($"{Name}.LoadportStop", (string cmd, object[] param) =>            {                if (!Stop(out string reason))                {                    EV.PostWarningLog(Module, $"{Name} can not stop, {reason}");                    return false;                }                EV.PostInfoLog(Module, $"{Name} stop");                return true;            });            OP.Subscribe($"{Name}.LoadportLoad", (string cmd, object[] param) =>            {                if (!Load(out string reason))                {                    EV.PostWarningLog(Module, $"{Name} can not load, {reason}");                    return false;                }                EV.PostInfoLog(Module, $"{Name} start load");                return true;            });            OP.Subscribe($"{Name}.LoadportLoadWithoutMap", (string cmd, object[] param) =>            {                if (!LoadWithoutMap(out string reason))                {                    EV.PostWarningLog(Module, $"{Name} can not load without map, {reason}");                    return false;                }                EV.PostInfoLog(Module, $"{Name} start load without map");                return true;            });            OP.Subscribe($"{Name}.LoadportLoadWithMap", (string cmd, object[] param) =>            {                if (!Load(out string reason))                {                    EV.PostWarningLog(Module, $"{Name} can not load with map, {reason}");                    return false;                }                if (!QueryWaferMap(out reason))                {                    EV.PostWarningLog(Module, $"{Name} can not map, {reason}");                    return false;                }                EV.PostInfoLog(Module, $"{Name} start load with map");                return true;            });            OP.Subscribe($"{Name}.LoadportUnload", (string cmd, object[] param) =>            {                if (!Unload(out string reason))                {                    EV.PostWarningLog(Module, $"{Name} can not unload, {reason}");                    return false;                }                EV.PostInfoLog(Module, $"{Name} start unload");                return true;            });            OP.Subscribe($"{Name}.LoadportClamp", (string cmd, object[] param) =>            {                if (!Clamp(out string reason))                {                    EV.PostWarningLog(Module, $"{Name} can not clamp, {reason}");                    return false;                }                EV.PostInfoLog(Module, $"{Name} start clamp");                return true;            });            OP.Subscribe($"{Name}.LoadportUnclamp", (string cmd, object[] param) =>            {                if (!Unclamp(out string reason))                {                    EV.PostWarningLog(Module, $"{Name} can not unclamp, {reason}");                    return false;                }                EV.PostInfoLog(Module, $"{Name} start unclamp");                return true;            });            OP.Subscribe($"{Name}.LoadportOpenDoor", (string cmd, object[] param) =>            {                if (!OpenDoor(out string reason))                {                    EV.PostWarningLog(Module, $"{Name} can not open door, {reason}");                    return false;                }                EV.PostInfoLog(Module, $"{Name} start open door");                return true;            });            OP.Subscribe($"{Name}.LoadportOpenDoorNoMap", (string cmd, object[] param) =>            {                if (!OpenDoorNoMap(out string reason))                {                    EV.PostWarningLog(Module, $"{Name} can not open door, {reason}");                    return false;                }                EV.PostInfoLog(Module, $"{Name} start open door");                return true;            });            OP.Subscribe($"{Name}.LoadportCloseDoor", (string cmd, object[] param) =>            {                if (!CloseDoor(out string reason))                {                    EV.PostWarningLog(Module, $"{Name} can not close door, {reason}");                    return false;                }                EV.PostInfoLog(Module, $"{Name} start close door");                return true;            });            OP.Subscribe($"{Name}.LoadportDock", (string cmd, object[] param) =>            {                if (!Dock(out string reason))                {                    EV.PostWarningLog(Module, $"{Name} can not dock, {reason}");                    return false;                }                EV.PostInfoLog(Module, $"{Name} start dock");                return true;            });            OP.Subscribe($"{Name}.LoadportUndock", (string cmd, object[] param) =>            {                if (!Undock(out string reason))                {                    EV.PostWarningLog(Module, $"{Name} can not undock, {reason}");                    return false;                }                EV.PostInfoLog(Module, $"{Name} start undock");                return true;            });            OP.Subscribe($"{Name}.LoadportQueryState", (string cmd, object[] param) =>            {                if (!QueryState(out string reason))                {                    EV.PostWarningLog(Module, $"{Name} can not query state, {reason}");                    return false;                }                EV.PostInfoLog(Module, $"{Name} start query state");                return true;            });            OP.Subscribe($"{Name}.LoadportQueryLED", (string cmd, object[] param) =>            {                if (!QueryIndicator(out string reason))                {                    EV.PostWarningLog(Module, $"{Name} can not query led state, {reason}");                    return false;                }                EV.PostInfoLog(Module, $"{Name} start query led state");                return true;            });            OP.Subscribe($"{Name}.LoadportSetLED", (string cmd, object[] param) =>            {                int light = (int) param[0];                int state = (int) param[1];                if (!SetIndicator((Indicator) light, (IndicatorState) state, out string reason))                {                    EV.PostWarningLog(Module, $"{Name} can not set led state, {reason}");                    return true;                }                EV.PostInfoLog(Module, $"{Name} start set led state");                return true;            });            OP.Subscribe($"{Name}.LoadportMap", (string cmd, object[] param) =>            {                if (!QueryWaferMap(out string reason))                {                    EV.PostWarningLog(Module, $"{Name} can not map, {reason}");                    return false;                }                EV.PostInfoLog(Module, $"{Name} start map");                return true;            });                        OP.Subscribe($"{Name}.SetCassetteType", (string cmd, object[] param) =>            {                if (!SetCassetteType(param,out string reason))                {                    EV.PostWarningLog(Module, $"{Name} can not set type, {reason}");                    return false;                }                EV.PostInfoLog(Module, $"{Name} cassette type have set to {CasstleType}");                return true;            });            OP.Subscribe($"{Name}.LoadportForceHome", (string cmd, object[] param) =>            {                if (!ForceHome(out string reason))                {                    EV.PostWarningLog(Module, $"{Name} can not start force home, {reason}");                    return false;                }                EV.PostInfoLog(Module, $"{Name} start force home");                return true;            });            OP.Subscribe($"{Name}.LoadportFOSBMode", (string cmd, object[] param) =>            {                if (!FOSBMode(out string reason))                {                    EV.PostWarningLog(Module, $"{Name} can not change to FOSB mode, {reason}");                    return false;                }                IsFOSBMode = true;                EV.PostInfoLog(Module, $"{Name} changed to FOSB mode");                return true;            });            OP.Subscribe($"{Name}.LoadportFOUPMode", (string cmd, object[] param) =>            {                if (!FOUPMode(out string reason))                {                    EV.PostWarningLog(Module, $"{Name} can not change to FOSB mode, {reason}");                    return false;                }                IsFOSBMode = true;                EV.PostInfoLog(Module, $"{Name} changed to FOSB mode");                return true;            });            OP.Subscribe($"{Name}.LoadportQueryFOSBMode", (string cmd, object[] param) =>            {                if (!QueryFOSBMode(out string reason))                {                    EV.PostWarningLog(Module, $"{Name} can not change to FOUP mode, {reason}");                    return false;                }                IsFOSBMode = false;                EV.PostInfoLog(Module, $"{Name} changed to FOSB mode");                return true;            });                    }        private bool SetCassetteType(object[] param,out string reason)        {            reason = "";            if (param.Length != 1)            {                reason = "Invalid setting parameter.";                return false;            }            CasstleType = (CasstleType)int.Parse(param[0].ToString());            return true;        }        public virtual bool Load(out string reason)        {            reason = "";            return true;        }        public virtual bool LoadWithoutMap(out string reason)        {            reason = "";            return true;        }        public virtual bool QueryWaferMap(out string reason)        {            reason = "";            return true;        }        public virtual bool QueryFOSBMode(out string reason)        {            reason = "";            return true;        }        /// <summary>        /// FOSB模式下的Dock指令        /// </summary>        /// <param name="reason"></param>        /// <returns></returns>        public virtual bool FOSBDock(out string reason)        {            reason = "";            return true;        }                /// <summary>        /// FOSB模式下的FOSBUnDock指令        /// </summary>        /// <param name="reason"></param>        /// <returns></returns>        public virtual bool FOSBUnDock(out string reason)        {            reason = "";            return true;        }                /// <summary>        /// FOSB模式下的开门指令        /// </summary>        /// <param name="reason"></param>        /// <returns></returns>        public virtual bool FOSBDoorOpen(out string reason)        {            reason = "";            return true;        }                /// <summary>        /// FOSB模式下的关门指令        /// </summary>        /// <param name="reason"></param>        /// <returns></returns>        public virtual bool FOSBDoorClose(out string reason)        {            reason = "";            return true;        }        /// <summary>        /// FOSB模式下的门下移指令        /// </summary>        /// <param name="reason"></param>        /// <returns></returns>        public virtual bool FOSBDoorDown(out string reason)        {            reason = "";            return true;        }        /// <summary>        /// FOSB模式下的门上移指令        /// </summary>        /// <param name="reason"></param>        /// <returns></returns>        public virtual bool FOSBDoorUp(out string reason)        {            reason = "";            return true;        }                public bool SetIndicator(IndicatorType light, IndicatorState state)        {            switch (light)            {                case IndicatorType.Load:                    SetIndicator(Indicator.LOAD, state, out string _);                    break;                case IndicatorType.Unload:                    SetIndicator(Indicator.UNLOAD, state, out string _);                    break;                case IndicatorType.Access:                    SetIndicator(Indicator.OPACCESS, state, out string _);                    break;                case IndicatorType.Alarm:                    SetIndicator(Indicator.ALARM, state, out string _);                    break;                case IndicatorType.Presence:                    SetIndicator(Indicator.PRESENCE, state, out string _);                    break;                case IndicatorType.Placement:                    SetIndicator(Indicator.PLACEMENT, state, out string _);                    break;                case IndicatorType.Status1:                    SetIndicator(Indicator.STATUS1, state, out string _);                    break;                case IndicatorType.Status2:                    SetIndicator(Indicator.STATUS2, state, out string _);                    break;                default:                    EV.PostWarningLog(Module, $"Not supported indicator {light}");                    return false;            }            return true;        }        public virtual bool SetIndicator(Indicator light, IndicatorState state, out string reason)        {            reason = "";            return true;        }        public virtual bool QueryIndicator(out string reason)        {            reason = "";            return true;        }        public virtual bool QueryState(out string reason)        {            reason = "";            return true;        }        public virtual bool Undock(out string reason)        {            reason = "";            return true;        }        public virtual bool Dock(out string reason)        {            reason = "";            return true;        }        public virtual bool CloseDoor(out string reason)        {            reason = "";            return true;        }        public virtual bool OpenDoor(out string reason)        {            reason = "";            return true;        }        public virtual bool OpenDoorNoMap(out string reason)        {            reason = "";            return true;        }        public virtual bool OpenDoorAndMap(out string reason)        {            reason = "";            return true;        }        public virtual bool Unclamp(out string reason)        {            reason = "";            return true;        }        public virtual bool Clamp(out string reason)        {            reason = "";            return true;        }        public virtual bool Unload(out string reason)        {            reason = "";            return true;        }         public virtual bool Stop(out string reason)        {            reason = "";            return true;        }        public virtual bool ClearError(out string reason)        {            reason = "";            return true;        }        public virtual bool Home(out string reason )        {            reason = "";            return true;        }         public virtual bool ForceHome(out string reason )        {            reason = "";            return true;        }        public virtual bool FOSBMode(out string reason)        {            reason = "";            return true;        }                public virtual bool FOUPMode(out string reason)        {            reason = "";            return true;        }        public virtual  void Monitor()        {                     }        public virtual void Reset()        {                    }        public virtual void Terminate()        {                     }        private List<List<string>> UpdatedWaferIdList()        {            WaferInfo[] wafers = WaferManager.Instance.GetWafers(_module);            for (int i = 0; i < wafers.Length; i++)            {                _waferId[i][1] = wafers[i].LaserMarker;                _waferId[i][2] = wafers[i].T7Code;                _waferId[i][3] = wafers[i].WaferID;            }            return _waferId;        }        public abstract bool IsEnableMapWafer();        public abstract bool IsEnableTransferWafer();        public abstract bool IsEnableTransferWafer(out string reason);        public virtual bool IsEnableLoad()        {            return _isPresent && _isPlaced;        }        protected void ConfirmAddCarrier()        {            if (_isPresent && _isPlaced)            {                CarrierManager.Instance.CreateCarrier(Name);                if (_isIndependentCEID)                {                    var dvid1 = new SerializableDictionary<string, string>                    {                        [$"{PORT_ID}_{_module}"] = PortId,                        [$"{PORT_CTGRY}_{_module}"] = PortCategory                    };                    EV.Notify($"{_module}_{EventCarrierArrived}", dvid1);                }                else                {                    SerializableDictionary<string, string> dvid = new SerializableDictionary<string, string>();                    dvid[PORT_ID] = PortId;                    dvid[PORT_CTGRY] = PortCategory;                    EV.Notify(EventCarrierArrived, dvid );                }            }        }        protected void ConfirmRemoveCarrier()        {            if (!_isPresent && !_isPlaced)            {                for (int i = 0; i < 25; i++)                {                    WaferManager.Instance.DeleteWafer(ModuleHelper.Converter(Name), 0,25);                }                CarrierManager.Instance.DeleteCarrier(Name);                if (_isIndependentCEID)                {                    var dvid1 = new SerializableDictionary<string, string>                    {                        [$"{PORT_ID}_{_module}"] = PortId,                        [$"{CAR_ID}_{_module}"] = _carrierId ?? ""                    };                    EV.Notify($"{_module}_{EventCarrierRemoved}", dvid1);                }                else                {                    SerializableDictionary<string, string> dvid = new SerializableDictionary<string, string>();                    dvid[PORT_ID] = PortId;                    dvid[PORT_CTGRY] = PortCategory;                    dvid[CAR_ID] = _carrierId ?? "";                    EV.Notify(EventCarrierRemoved, dvid);                }                                                                _isMapped = false;                _carrierId = "";            }        }        public void OnSlotMapRead(string slotMap)        {            for (int i = 0; i < 25; i++)            {                // No wafer: "0", Wafer: "1", Crossed:"2", Undefined: "?", Overlapping wafers: "W"                WaferInfo wafer = null;                switch (slotMap[i])                {                    case '0':                        WaferManager.Instance.DeleteWafer(_module, i);                        CarrierManager.Instance.UnregisterCarrierWafer(Name, i);                        break;                    case '1':                        wafer = WaferManager.Instance.CreateWafer(_module, i, WaferStatus.Normal);                        CarrierManager.Instance.RegisterCarrierWafer(Name, i, wafer);                        break;                    case '2':                        wafer = WaferManager.Instance.CreateWafer(_module, i, WaferStatus.Crossed);                        CarrierManager.Instance.RegisterCarrierWafer(Name, i, wafer);                        //NotifyWaferError(Name, i, WaferStatus.Crossed);                        break;                    case 'W':                        wafer = WaferManager.Instance.CreateWafer(_module, i, WaferStatus.Double);                        CarrierManager.Instance.RegisterCarrierWafer(Name, i, wafer);                        //NotifyWaferError(Name, i, WaferStatus.Double);                        break;                    case '?':                        wafer = WaferManager.Instance.CreateWafer(_module, i, WaferStatus.Unknown);                        CarrierManager.Instance.RegisterCarrierWafer(Name, i, wafer);                        //NotifyWaferError(Name, i, WaferStatus.Unknown);                        break;                }            }            if (_isIndependentCEID)            {                var dvid1 = new SerializableDictionary<string, string>                {                    [$"{SLOT_MAP}_{_module}"] = SlotMap,                    [$"{PORT_ID}_{_module}"] = PortId,                    [$"{PORT_CTGRY}_{_module}"] = PortCategory,                    [$"{CAR_ID}_{_module}"] = _carrierId ?? ""                };                EV.Notify($"{_module}_{EventSlotMapAvailable}", dvid1);            }            else            {                SerializableDictionary<string, string> dvid = new SerializableDictionary<string, string>();                 dvid[SLOT_MAP] = SlotMap;                dvid[PORT_ID] = PortId;                dvid[PORT_CTGRY] = PortCategory;                dvid[CAR_ID] =  CarrierId == null ? "" : CarrierId;                EV.Notify(EventSlotMapAvailable, dvid);            }            _isMapped = true;        }         private string GetSlotMap()        {            WaferInfo[] wafers = WaferManager.Instance.GetWafers(ModuleHelper.Converter(Name) );            string slot = "";            for (int i = 0; i < 25; i++)            {                slot += wafers[i].IsEmpty? "0" : "1";            }            return slot;        }        /// <summary>        /// 获取LP中空缺Slot        /// </summary>        /// <returns>返回一个list, 顺序为从下到上.(0-25)</returns>        public List<int> GetEmptySlot()        {            List<int> slot = new List<int>();            if (IsMapped)            {                WaferInfo[] wafers = WaferManager.Instance.GetWafers(ModuleHelper.Converter(Name));                for (int i = 0; i < 25 ; i++)                {                    if(wafers[i].IsEmpty)                        slot.Add(i);                }                return slot;            }            else            {                return null;            }                    }        public void OnCarrierIdRead(ModuleName module, string name, string carrierId)        {            if (_isPlaced && _isPresent)            {                _carrierId = carrierId;                if (_isIndependentCEID)                {                    var dvid1 = new SerializableDictionary<string, string>                    {                        [$"{CAR_ID}_{_module}"] = _carrierId ?? "",                        [$"{PORT_ID}_{_module}"] = PortId,                        [$"{PORT_CTGRY}_{_module}"] = PortCategory                    };                    EV.Notify($"{_module}_{EventCarrierIdRead}", dvid1);                }                else                {                    SerializableDictionary<string, string> dvid = new SerializableDictionary<string, string>();                    dvid[CAR_ID] = carrierId ?? "";                    dvid[PORT_ID] = PortId;                    dvid[PORT_CTGRY] = PortCategory;                    EV.Notify(EventCarrierIdRead, dvid);                 }                CarrierManager.Instance.UpdateCarrierId(Name, carrierId);            }            else            {                EV.PostWarningLog(Module, $"No FOUP found, carrier id {carrierId} not saved");            }        }        public void OnCarrierIdWrite(ModuleName module, string name, string carrierId)        {            if (_isPlaced && _isPresent)            {                //_carrierId = carrierId;                if (_isIndependentCEID)                {                    var dvid1 = new SerializableDictionary<string, string>                    {                        [$"{CAR_ID}_{_module}"] = carrierId ?? "",                        [$"{PORT_ID}_{_module}"] = PortId                    };                    EV.Notify($"{_module}_CAR_ID_WRITE_SUCCESSFULLY", dvid1);                }                else                {                    SerializableDictionary<string, string> dvid = new SerializableDictionary<string, string>();                    dvid[CAR_ID] = carrierId ?? "";                    dvid[PORT_ID] = PortId;                    dvid[PORT_CTGRY] = PortCategory;                    EV.Notify(EventCarrierIdWrite, dvid);                }            }            else            {                EV.PostWarningLog(Module, $"No FOUP found, carrier id {carrierId} not saved");            }        }        public void OnCarrierIdReadFailed(ModuleName module, string name)        {            if (_isPlaced && _isPresent)            {                _carrierId = "";                if (_isIndependentCEID)                {                    var dvid1 = new SerializableDictionary<string, string>                    {                        [$"{PORT_ID}_{_module}"] = PortId,                         [$"{PORT_CTGRY}_{_module}"] = PortCategory                    };                    EV.Notify($"{_module}_{EventCarrierIdReadFailed}", dvid1);                }                else                {                    SerializableDictionary<string, string> dvid = new SerializableDictionary<string, string>();                    dvid[PORT_ID] = PortId;                    dvid[PORT_CTGRY] = PortCategory;                    EV.Notify(EventCarrierIdReadFailed, dvid);                }                                            }            else            {                EV.PostWarningLog(Module, "No FOUP found, carrier id read is not valid");            }        }        public void OnCarrierIdWriteFailed(ModuleName module, string name)        {            if (_isPlaced && _isPresent)            {                //_carrierId = "";                if (_isIndependentCEID)                {                    var dvid1 = new SerializableDictionary<string, string>                    {                        [$"{PORT_ID}_{_module}"] = PortId,                        [$"{PORT_CTGRY}_{_module}"] = PortCategory,                        [$"{CAR_ID}_{_module}"] = _carrierId ?? ""                                        };                    EV.Notify($"{_module}_CAR_ID_WRITE_FAIL", dvid1);                }                else                {                    SerializableDictionary<string, string> dvid = new SerializableDictionary<string, string>();                                    dvid[PORT_ID] = PortId;                    dvid[PORT_CTGRY] = PortCategory;                    EV.Notify(EventCarrierIdWriteFailed, dvid);                }            }            else            {                EV.PostWarningLog(Module, "No FOUP found, carrier id not valid");            }        }        public void OnCarrierIdRead(ModuleName module, string carrierId)        {            OnCarrierIdRead(module, "", carrierId);        }        public void OnCarrierIdReadFailed(ModuleName module)        {            OnCarrierIdReadFailed(module, "");        }        public void OnCarrierIdWrite(ModuleName module, string carrierId)        {            OnCarrierIdWrite(module, "", carrierId);        }                public void OnCarrierIdWriteFailed(ModuleName module)        {            OnCarrierIdWriteFailed(module, "");        }        public void OnRfIdRead(ModuleName module, string rfid)        {            if (_isPlaced && _isPresent)            {                _rfid = rfid;                if (_isIndependentCEID)                {                    var dvid1 = new SerializableDictionary<string, string>                    {                        [$"{CAR_ID}_{_module}"] = _carrierId ?? "",                        [$"{PORT_ID}_{_module}"] = PortId,                        [$"{PORT_CTGRY}_{_module}"] = PortCategory,                        [$"{RF_ID}_{_module}"] = rfid ?? ""                    };                    EV.Notify($"{_module}_{EventRfIdRead}", dvid1);                }                else                {                    SerializableDictionary<string, string> dvid = new SerializableDictionary<string, string>();                    dvid[CAR_ID] = _carrierId ?? "";                    dvid[PORT_ID] = PortId;                    dvid[PORT_CTGRY] = PortCategory;                    dvid[RF_ID] = rfid ?? "";                    EV.Notify(EventRfIdRead, dvid);                }                                CarrierManager.Instance.UpdateRfId(Name, rfid);            }            else            {                EV.PostWarningLog(Module, "No FOUP found, rf id read not valid");            }        }        public void OnRfIdReadFailed(ModuleName module)        {            if (_isPlaced && _isPresent)            {                _rfid = "";                if (_isIndependentCEID)                {                    var dvid1 = new SerializableDictionary<string, string>                    {                        [$"{CAR_ID}_{_module}"] = _carrierId ?? "",                        [$"{PORT_ID}_{_module}"] = PortId,                        [$"{PORT_CTGRY}_{_module}"] = PortCategory                    };                    EV.Notify($"{_module}_{EventRfIdReadFailed}", dvid1);                }                else                {                    SerializableDictionary<string, string> dvid = new SerializableDictionary<string, string>();                    dvid[CAR_ID] = _carrierId ?? "";                    dvid[PORT_ID] = PortId;                    dvid[PORT_CTGRY] = PortCategory;                    EV.Notify(EventRfIdReadFailed, dvid);                }            }            else            {                EV.PostWarningLog(Module, "No FOUP found, rf id read is not valid");            }        }        public void OnRfIdWrite(ModuleName module, string rfid)        {            if (_isPlaced && _isPresent)            {                _rfid = rfid;                if (_isIndependentCEID)                {                    var dvid1 = new SerializableDictionary<string, string>                    {                        [$"{CAR_ID}_{_module}"] = _carrierId ?? "",                        [$"{PORT_ID}_{_module}"] = PortId,                        [$"{PORT_CTGRY}_{_module}"] = PortCategory,                        [$"{RF_ID}_{_module}"] = rfid ?? ""                    };                    EV.Notify($"{_module}_{EventRfIdWrite}", dvid1);                }                else                {                    SerializableDictionary<string, string> dvid = new SerializableDictionary<string, string>();                    dvid[CAR_ID] = _carrierId ?? "";                    dvid[PORT_ID] = PortId;                    dvid[PORT_CTGRY] = PortCategory;                    dvid[RF_ID] = rfid ?? "";                    EV.Notify(EventRfIdWrite, dvid);                }                CarrierManager.Instance.UpdateRfId(Name, rfid);            }            else            {                EV.PostWarningLog(Module, "No FOUP found, rf id write not valid");            }        }        public void OnRfIdWriteFailed(ModuleName module )        {            if (_isPlaced && _isPresent)            {                _rfid = "";                if (_isIndependentCEID)                {                    var dvid1 = new SerializableDictionary<string, string>                    {                        [$"{CAR_ID}_{_module}"] = _carrierId ?? "",                        [$"{PORT_ID}_{_module}"] = PortId,                        [$"{PORT_CTGRY}_{_module}"] = PortCategory,                        [$"{RF_ID}_{_module}"] = ""                    };                    EV.Notify($"{_module}_{EventRfIdWrite}", dvid1);                }                else                {                    SerializableDictionary<string, string> dvid = new SerializableDictionary<string, string>();                    dvid[CAR_ID] = _carrierId ?? "";                    dvid[PORT_ID] = PortId;                    dvid[PORT_CTGRY] = PortCategory;                    dvid[RF_ID] = "";                    //EV.PostWarningLog(Module, "Write RFID failed.");                    EV.Notify(EventRfIdWrite, dvid);                }            }            else            {                EV.PostWarningLog(Module, "No FOUP found, rf id write not valid");            }        }        public void OnLoaded()        {            if (_isIndependentCEID)            {                var dvid1 = new SerializableDictionary<string, string>                {                    [$"{CAR_ID}_{_module}"] = _carrierId ?? "",                    [$"{PORT_ID}_{_module}"] = PortId                };                EV.Notify($"{_module}_CARRIR_LOAD_COMPLETE", dvid1);            }            else            {                var dvid = new SerializableDictionary<string, string>                {                    [CAR_ID] = _carrierId ?? "",                     [PORT_ID] = PortId                };                EV.Notify(EventCarrierloaded, dvid);            }        }        public void OnUnloaded()        {            if (_isIndependentCEID)            {                var dvid1 = new SerializableDictionary<string, string>                {                    [$"{PORT_CTGRY}_{_module}"] = PortCategory,                    [$"{PORT_ID}_{_module}"] = PortId,                    [$"{CAR_ID}_{_module}"] = _carrierId ?? "",                    [$"{SLOT_MAP}_{_module}"] = SlotMap,                    [$"LOT_ID_{_module}"] = CarrierManager.Instance.GetLotIdByLoadPort(_module.ToString())                                };                EV.Notify($"{_module}_{EventCarrierUnloaded}", dvid1);            }            else            {                var dvid = new SerializableDictionary<string, string>();                dvid[PORT_CTGRY] = PortCategory;                dvid[PORT_ID] = PortId;                dvid[CAR_ID] = _carrierId ?? "";                EV.Notify(EventCarrierUnloaded, dvid);            }                                    for (int i = 0; i < 25; i++)            {                WaferManager.Instance.DeleteWafer(ModuleHelper.Converter(Name), 0, 25);            }                        _isMapped = false;        }        public void OnHomed()        {            for (int i = 0; i < 25; i++)            {                WaferManager.Instance.DeleteWafer(ModuleHelper.Converter(Name), 0, 25);            }            _isMapped = false;        }        public void OnCloseDoor()        {            for (int i = 0; i < 25; i++)            {                WaferManager.Instance.DeleteWafer(ModuleHelper.Converter(Name), 0, 25);            }            _isMapped = false;        }        public void OnError()        {            EV.Notify(AlarmCarrierPortError);            EV.Notify($"{_module}_{AlarmCarrierPortError}");        }         protected void SetPresent(bool isPresent)        {            _isPresent = isPresent;            if (_isPresent)            {                ConfirmAddCarrier();            }            else            {                ConfirmRemoveCarrier();            }        }        protected void SetPlaced(bool isPlaced)        {            _isPlaced = isPlaced;            if (_isPlaced)            {                ConfirmAddCarrier();            }            else            {                ConfirmRemoveCarrier();            }        }     }}
 |