1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403 |
- using Aitex.Common.Util;
- using Aitex.Core.RT.Event;
- using Aitex.Core.RT.Log;
- using Aitex.Core.RT.SCCore;
- using Aitex.Core.Util;
- using Aitex.Core.Utilities;
- using Aitex.Core.WCF;
- using MECF.Framework.Common.Properties;
- using MECF.Framework.Common.RecipeCenter;
- using System;
- using System.Collections.Generic;
- using System.Collections.ObjectModel;
- using System.IO;
- using System.Linq;
- using System.Text;
- using System.Xml;
- using System.Xml.Schema;
- namespace Aitex.Core.RT.RecipeCenter
- {
- public class RecipeFileManager : Singleton<RecipeFileManager>
- {
- //sequence文件 统一放在 Recipes/Sequence 文件夹下面
- public const string SequenceFolder = "Sequence";
- public const string SourceModule = "Recipe";
- public const string WaferFlowFolder = "WaferFlow";
- string _chamberId;
- private bool _recipeIsValid;
- private List<string> _validationErrors = new List<string>();
- private List<string> _validationWarnings = new List<string>();
- IRecipeFileContext _rcpContext;
- private ISequenceFileContext _seqContext;
- public RecipeFileManager()
- {
- _chamberId = SC.GetStringValue("System.Recipe.RecipeChamberType");
- if (_chamberId == null)
- _chamberId = "Furnace";
- }
- public void Initialize(IRecipeFileContext context)
- {
- Initialize(context, null, true);
- }
- public void Initialize(IRecipeFileContext context, bool enableService)
- {
- Initialize(context, null, enableService);
- }
- public void Initialize(IRecipeFileContext rcpContext, ISequenceFileContext seqContext, bool enableService)
- {
- _rcpContext = rcpContext == null ? new DefaultRecipeFileContext() : rcpContext;
- _seqContext = seqContext == null ? new DefaultSequenceFileContext() : seqContext;
- CultureSupported.UpdateCoreCultureResource(CultureSupported.English);
- if (enableService)
- {
- Singleton<WcfServiceManager>.Instance.Initialize(new Type[]
- {
- typeof(RecipeService)
- });
- }
- var dir = string.Format("{0}{1}\\", PathManager.GetRecipeDir(), SequenceFolder);
- DirectoryInfo di = new DirectoryInfo(dir);
- if (!di.Exists)
- {
- di.Create();
- }
- }
- private void ValidationEventHandler(object sender, ValidationEventArgs e)
- {
- switch (e.Severity)
- {
- case XmlSeverityType.Error:
- _validationErrors.Add(e.Message);
- _recipeIsValid = false;
- break;
- case XmlSeverityType.Warning:
- _validationWarnings.Add(e.Message);
- break;
- }
- }
- /// <summary>
- /// XML schema checking
- /// </summary>
- /// <param name="chamId"></param>
- /// <param name="recipeName"></param>
- /// <param name="recipeContent"></param>
- /// <param name="reason"></param>
- /// <returns></returns>
- public bool ValidateRecipe(string chamberId, string recipeName, string recipeContent, out List<string> reason)
- {
- try
- {
- XmlDocument document = new XmlDocument();
- document.LoadXml(recipeContent);
- MemoryStream schemaStream = new MemoryStream(ASCIIEncoding.ASCII.GetBytes(GetRecipeSchema(chamberId)));
- XmlReader xmlSchemaReader = XmlReader.Create(schemaStream);
- XmlSchema schema1 = XmlSchema.Read(xmlSchemaReader, ValidationEventHandler);
- document.Schemas.Add(schema1);
- document.LoadXml(recipeContent);
- ValidationEventHandler eventHandler = new ValidationEventHandler(ValidationEventHandler);
- _recipeIsValid = true;
- _validationErrors = new List<string>();
- _validationWarnings = new List<string>();
- // Validates recipe.
- document.Validate(eventHandler);
- }
- catch (Exception ex)
- {
- LOG.Write(ex.Message);
- _recipeIsValid = false;
- }
- if (!_recipeIsValid && _validationErrors.Count == 0)
- {
- _validationErrors.Add(Resources.RecipeFileManager_ValidateRecipe_XMLSchemaValidateFailed);
- }
- reason = _validationErrors;
- return _recipeIsValid;
- }
- /// <summary>
- /// Check recipe content
- /// </summary>
- /// <param name="chamId"></param>
- /// <param name="recipeContent"></param>
- /// <param name="reasons"></param>
- /// <returns></returns>
- public bool CheckRecipe(string chamberId, string recipeName, out List<string> reasons)
- {
- reasons = new List<string>();
- string chamberType = chamberId.Split('\\')[0];
- string processType = chamberId.Split('\\')[1];
- string recipeContent = LoadRecipe(chamberId, recipeName, false);
- var xmlRecipe = new XmlDocument();
- try
- {
- if (string.IsNullOrEmpty(recipeContent))
- throw new Exception("invalid recipe file.");
- xmlRecipe.LoadXml(recipeContent);
- XmlNodeList nodeSteps = xmlRecipe.SelectNodes($"Aitex/TableRecipeData/Module[@Name='{processType}']/Step");
- XmlNode nodeConfig = xmlRecipe.SelectNodes($"Aitex/TableRecipeData/Config")[0];
- switch (processType)
- {
- case "WaferFlow":
- CheckWaferFlowRecipe(nodeConfig, nodeSteps, out reasons);
- break;
- case "COT":
- CheckSpinRecipe(nodeConfig, nodeSteps, true, out reasons);
- break;
- case "DEV":
- CheckSpinRecipe(nodeConfig, nodeSteps, false, out reasons);
- break;
- case "ADH":
- CheckADHRecipe(nodeSteps, out reasons);
- break;
- case "Oven":
- CheckOvenRecipe(nodeSteps, out reasons);
- break;
- }
- }
- catch (Exception ex)
- {
- reasons.Add(ex.Message);
- LOG.Write(ex);
- return false;
- }
- XmlElement nodeData = xmlRecipe.SelectSingleNode($"Aitex/TableRecipeData") as XmlElement;
- bool bResult = reasons.Count == 0;
- if (bResult)
- {
- nodeData.SetAttribute("CheckResult", "Correct");
- }
- else
- {
- nodeData.SetAttribute("CheckResult", "Error");
- }
- SaveRecipe(chamberId, recipeName, xmlRecipe.OuterXml, false, false);
- return bResult;
- }
- /// <summary>
- /// Check recipe content
- /// </summary>
- /// <param name="chamId"></param>
- /// <param name="recipeContent"></param>
- /// <param name="reasons"></param>
- /// <returns></returns>
- public bool CheckRestoreRecipe(string chamberId, string recipeName, out List<string> reasons)
- {
- reasons = new List<string>();
- string chamberType = chamberId.Split('\\')[0];
- string processType = chamberId.Split('\\')[1];
- string recipeContent = LoadRestoreRecipe(chamberId, recipeName, false);
- var xmlRecipe = new XmlDocument();
- try
- {
- if (string.IsNullOrEmpty(recipeContent))
- throw new Exception("invalid recipe file.");
- xmlRecipe.LoadXml(recipeContent);
- XmlNodeList nodeSteps = xmlRecipe.SelectNodes($"Aitex/TableRecipeData/Module[@Name='{processType}']/Step");
- XmlNode nodeConfig = xmlRecipe.SelectNodes($"Aitex/TableRecipeData/Config")[0];
- switch (processType)
- {
- case "WaferFlow":
- CheckWaferFlowRecipe(nodeConfig, nodeSteps, out reasons);
- break;
- case "COT":
- CheckSpinRecipe(nodeConfig, nodeSteps, true, out reasons);
- break;
- case "DEV":
- CheckSpinRecipe(nodeConfig, nodeSteps, false, out reasons);
- break;
- case "ADH":
- CheckADHRecipe(nodeSteps, out reasons);
- break;
- case "Oven":
- CheckOvenRecipe(nodeSteps, out reasons);
- break;
- }
- }
- catch (Exception ex)
- {
- reasons.Add(ex.Message);
- LOG.Write(ex);
- return false;
- }
- XmlElement nodeData = xmlRecipe.SelectSingleNode($"Aitex/TableRecipeData") as XmlElement;
- bool bResult = reasons.Count == 0;
- if (bResult)
- {
- nodeData.SetAttribute("CheckResult", "Correct");
- }
- else
- {
- nodeData.SetAttribute("CheckResult", "Error");
- }
- SaveRestoreRecipe(chamberId, recipeName, xmlRecipe.OuterXml, false, false);
- return bResult;
- }
- void CheckWaferFlowRecipe(XmlNode nodeConfig, XmlNodeList nodeSteps, out List<string> reasons)
- {
- reasons = new List<string>();
- if (nodeSteps.Count <= 0)
- {
- reasons.Add("steps count is 0");
- return;
- }
- if (nodeSteps.Count < 5)
- {
- reasons.Add("steps count is less than 5");
- return;
- }
- int beginStepIndex = 0;
- int endStepIndex = 1;
- for (int i = 0; i < nodeSteps.Count; i++)
- {
- if (nodeSteps[i].Attributes["ModuleName"].Value.Contains("End UNC"))
- {
- int.TryParse(nodeSteps[i].Attributes["StepNo"].Value, out endStepIndex);
- break;
- }
- }
- endStepIndex--;
- if (endStepIndex <= 0)
- {
- reasons.Add($"Current recipe muste contains end step");
- return;
- }
- for (int i = beginStepIndex; i <= endStepIndex; i++)
- {
- int stepNo = i + 1;
- string strModuleName = nodeSteps[i].Attributes["ModuleName"].Value;
- if (!string.IsNullOrEmpty(strModuleName))
- strModuleName = strModuleName.Split(',')[0].Split(' ')[1];
- else
- {
- reasons.Add($"Step{stepNo} module name is empty");
- return;
- }
- if (i == 0)//check step1
- {
- string moduleName = "UNC";
- if (!strModuleName.Equals(moduleName))
- {
- reasons.Add($"Step{stepNo} module muste be {moduleName}");
- }
- continue;
- }
- if (i == 1)//check step2
- {
- string moduleName = "TRS,TCP";
- if (!moduleName.Contains(strModuleName))
- {
- reasons.Add($"Step{stepNo} module muste be {moduleName} module");
- }
- }
- if (i == endStepIndex - 1)//check last second step
- {
- string moduleName = "TRS,TCP";
- if (!moduleName.Contains(strModuleName))
- {
- reasons.Add($"Step{stepNo} module muste be {moduleName} module");
- }
- if (strModuleName == nodeSteps[1].Attributes["ModuleName"].Value)
- {
- reasons.Add($"Step{stepNo} module muste be different with step1 module");
- }
- }
- if (i == endStepIndex)//check last step
- {
- string moduleName = "UNC";
- if (!strModuleName.Equals(moduleName))
- {
- reasons.Add($"Step{stepNo} module muste be {moduleName}");
- }
- continue;
- }
- //check linked recipe
- string unCheckModuleName = "SHU,TRS,SUB,EIS";
- if (!unCheckModuleName.Contains(strModuleName))
- {
- string ovenModuleName = "CPL,HHP,LHP,CHP,TCP";
- if (ovenModuleName.Contains(strModuleName))
- strModuleName = "Oven";
- string linkRecipeName = nodeSteps[i].Attributes["RecipeName"].Value;
- if (string.IsNullOrEmpty(linkRecipeName))
- {
- reasons.Add($"Step{stepNo} link recipe is empty.");
- }
- else
- {
- string[] subRecipeNames = linkRecipeName.Split(',');
- foreach (var item in subRecipeNames)
- {
- string subRecipeName = string.Empty;
- string[] subRecipeNameStrings = item.Split(':');
- if (subRecipeNameStrings.Length > 1)
- {
- subRecipeName = subRecipeNameStrings[1];
- }
- else
- {
- subRecipeName = subRecipeNameStrings[0];
- }
- if (!CheckRecipe($"{_chamberId}\\{strModuleName}", subRecipeName, out List<string> subReasons))
- {
- reasons.Add($"Step{stepNo} linked recipe check fail.");
- }
- }
- }
- }
- }
- //check system reicpe
- string strSystemReicpeName = nodeConfig.Attributes["SystemRecipe"]?.Value;
- if (!string.IsNullOrEmpty(strSystemReicpeName))
- {
- if (!CheckRecipe($"{_chamberId}\\System", strSystemReicpeName, out List<string> subReasons))
- {
- reasons.Add($"Linked system recipe check fail.");
- }
- }
- else
- {
- reasons.Add($"Must link system recipe.");
- }
- }
- public string LoadRecipeByFullPath(string fullPath)
- {
- string rcp = string.Empty;
- try
- {
- using (StreamReader fs = new StreamReader(fullPath))
- {
- rcp = fs.ReadToEnd();
- fs.Close();
- }
- }
- catch (Exception ex)
- {
- try
- {
- using (StreamReader fs = new StreamReader(fullPath))
- {
- rcp = fs.ReadToEnd();
- fs.Close();
- }
- }
- catch
- {
- LOG.Write(ex, $"load recipe file failed, {fullPath}");
- rcp = string.Empty;
- };
- }
- return rcp;
- }
- void CheckSpinRecipe(XmlNode nodeConfig, XmlNodeList nodeSteps, bool checkPumpRecipe, out List<string> reasons)
- {
- reasons = new List<string>();
- if (nodeSteps.Count <= 0)
- {
- reasons.Add("steps count is 0.");
- return;
- }
- List<int> loopStartStepsNo = new List<int>();
- List<int> loopEndStepsNo = new List<int>();
- bool hasDispense = false;
- List<bool> arm1HasMove = new List<bool>();
- List<bool> arm2HasMove = new List<bool>();
- for (int i = 0; i < nodeSteps.Count; i++)
- {
- int stepNo = i + 1;
- if (nodeSteps[i].Attributes["Loop"].Value.Contains("Start"))
- {
- loopStartStepsNo.Add(stepNo);
- }
- if (nodeSteps[i].Attributes["Loop"].Value.Contains("End"))
- {
- loopEndStepsNo.Add(stepNo);
- }
- string strDispense = nodeSteps[i].Attributes["Dispense"].Value;
- if (strDispense.Contains("Resist"))
- {
- hasDispense = true;
- }
- //check dispens
- if (!string.IsNullOrEmpty(strDispense))
- {
- bool bDispenseHasError = false;
- string[] strDispenseValues = strDispense.Split(',');
- string strFirstDispenseValue = strDispenseValues[0];
- foreach (var item in strDispenseValues)
- {
- if (strFirstDispenseValue.Split(' ')[0] != item.Split(' ')[0])
- bDispenseHasError = true;
- }
- if (bDispenseHasError)
- reasons.Add($"Step{stepNo} dispense must select same module.");
- }
- if (i > 0)
- {
- string arm1CurrentPosition = nodeSteps[i].Attributes["Arm1"].Value.Split(',')[2].Split(':')[1];
- string arm1PreviousPosition = nodeSteps[i - 1].Attributes["Arm1"].Value.Split(',')[2].Split(':')[1];
- if (!string.IsNullOrEmpty(arm1CurrentPosition))
- {
- if (arm1CurrentPosition.Equals(arm1PreviousPosition))
- arm1HasMove.Add(false);
- else
- arm1HasMove.Add(true);
- }
- string arm2CurrentPosition = nodeSteps[i].Attributes["Arm2"].Value.Split(',')[2].Split(':')[1];
- string arm2PreviousPosition = nodeSteps[i - 1].Attributes["Arm2"].Value.Split(',')[2].Split(':')[1];
- if (!string.IsNullOrEmpty(arm2CurrentPosition))
- {
- if (arm2CurrentPosition.Equals(arm2PreviousPosition))
- arm2HasMove.Add(false);
- else
- arm2HasMove.Add(true);
- }
- }
- }
- //check loop
- if (loopStartStepsNo.Count != loopEndStepsNo.Count) //判断个数
- {
- reasons.Add("loop set is incorrect");
- }
- //check pump recipe
- if (checkPumpRecipe && hasDispense)
- {
- string pumpRecipeName = nodeConfig.Attributes["COTPumpRecipe"]?.Value;
- if (string.IsNullOrEmpty(pumpRecipeName))
- reasons.Add("pump recipe is null");
- else
- {
- if (!CheckRecipe($"{_chamberId}\\Pump", pumpRecipeName, out List<string> subReasons))
- {
- reasons.Add($"Linked pump recipe check fail.");
- }
- }
- }
- //check arm move
- for (int i = 0; i < arm1HasMove.Count; i++)
- {
- if (arm1HasMove[i] && arm2HasMove[i])//同时移动
- reasons.Add($"step{i + 2} arm1 and arm2 move at the same time");
- }
- }
- void CheckADHRecipe(XmlNodeList nodeSteps, out List<string> reasons)
- {
- reasons = new List<string>();
- if (nodeSteps.Count <= 0)
- {
- reasons.Add("steps count is 0.");
- return;
- }
- for (int i = 0; i < nodeSteps.Count; i++)
- {
- int stepNo = i + 1;
- //check dispense
- if (!nodeSteps[i].Attributes["ProcessPosition"].Value.Equals("Process") && !string.IsNullOrEmpty(nodeSteps[i].Attributes["Dispense"].Value))
- {
- reasons.Add($"Step{stepNo} only position is process can select dispense.");
- }
- //check plate temp
- if (nodeSteps[i].Attributes["ProcessPosition"].Value.Equals("Process") && string.IsNullOrEmpty(nodeSteps[i].Attributes["PlateTemp"].Value))
- {
- reasons.Add($"Step{stepNo} must set plate temp.");
- }
- //check alrm
- double.TryParse(nodeSteps[i].Attributes["AlarmMax"].Value, out double alarmMax);
- double.TryParse(nodeSteps[i].Attributes["AlarmMin"].Value, out double alarmMin);
- double.TryParse(nodeSteps[i].Attributes["WarnMax"].Value, out double warnMax);
- double.TryParse(nodeSteps[i].Attributes["WarnMin"].Value, out double warnMin);
- bool bRightRange = false;
- if (alarmMax == 0 && alarmMin == 0 && warnMax == 0 && warnMin == 0) continue;
- if (alarmMax == 0 && alarmMin == 0)
- {
- bRightRange = warnMax > warnMin;
- if (!bRightRange)
- {
- reasons.Add($"Step{stepNo} warnMax>warnMin?");
- }
- }
- else if (warnMax == 0 && warnMax == 0)
- {
- bRightRange = alarmMax > alarmMin;
- if (!bRightRange)
- {
- reasons.Add($"Step{stepNo} alarmMax>alarmMin?");
- }
- }
- else
- {
- bRightRange = alarmMax > warnMax && warnMax > warnMin && warnMin > alarmMin;
- if (!bRightRange)
- {
- reasons.Add($"Step{stepNo} alarmMax>warnMax>warnMin>alarmMin?");
- }
- }
- }
- }
- void CheckOvenRecipe(XmlNodeList nodeSteps, out List<string> reasons)
- {
- reasons = new List<string>();
- if (nodeSteps.Count <= 0)
- {
- reasons.Add("steps count is 0.");
- return;
- }
- for (int i = 0; i < nodeSteps.Count; i++)
- {
- int stepNo = i + 1;
- //check plate temp
- if (nodeSteps[i].Attributes["ProcessPosition"].Value.Equals("Heat") && string.IsNullOrEmpty(nodeSteps[i].Attributes["PlateTemp"].Value))
- {
- reasons.Add($"Step{stepNo} must set plate temp.");
- }
- //check alrm
- double.TryParse(nodeSteps[i].Attributes["AlarmMax"].Value, out double alarmMax);
- double.TryParse(nodeSteps[i].Attributes["AlarmMin"].Value, out double alarmMin);
- double.TryParse(nodeSteps[i].Attributes["WarnMax"].Value, out double warnMax);
- double.TryParse(nodeSteps[i].Attributes["WarnMin"].Value, out double warnMin);
- bool bRightRange = false;
- if (alarmMax == 0 && alarmMin == 0 && warnMax == 0 && warnMin == 0) continue;
- if (alarmMax == 0 && alarmMin == 0)
- {
- bRightRange = warnMax > warnMin;
- if (!bRightRange)
- {
- reasons.Add($"Step{stepNo} warnMax>warnMin?");
- }
- }
- else if (warnMax == 0 && warnMax == 0)
- {
- bRightRange = alarmMax > alarmMin;
- if (!bRightRange)
- {
- reasons.Add($"Step{stepNo} alarmMax>alarmMin?");
- }
- }
- else
- {
- bRightRange = alarmMax > warnMax && warnMax > warnMin && warnMin > alarmMin;
- if (!bRightRange)
- {
- reasons.Add($"Step{stepNo} alarmMax>warnMax>warnMin>alarmMin?");
- }
- }
- }
- }
- public string LoadRecipe(string chamberId, string recipeName, bool needValidation)
- {
- string rcp = string.Empty;
- try
- {
- using (StreamReader fs = new StreamReader(GenerateRecipeFilePath(chamberId, recipeName)))
- {
- rcp = fs.ReadToEnd();
- fs.Close();
- }
- //if (needValidation)
- //{
- // List<string> reason;
- // if (!ValidateRecipe(chamberId, recipeName, rcp, out reason))
- // {
- // rcp = string.Empty;
- // LOG.Write("校验recipe file 出错, " + string.Join(",", reason.ToArray()));
- // }
- //}
- }
- catch (Exception ex)
- {
- LOG.Write(ex, $"load recipe file failed, {recipeName}");
- rcp = string.Empty;
- }
- return rcp;
- }
- /// <summary>
- /// Get recipe list
- /// </summary>
- /// <param name="chamId"></param>
- /// <param name="includingUsedRecipe"></param>
- /// <returns></returns>
- public IEnumerable<string> GetRecipes(string chamberId, bool includingUsedRecipe)
- {
- return _rcpContext.GetRecipes(chamberId, includingUsedRecipe);
- }
- /// <summary>
- /// Get recipe list in xml format
- /// </summary>
- /// <param name="chamId"></param>
- /// <param name="includingUsedRecipe"></param>
- /// <returns></returns>
- public string GetXmlRecipeList(string chamberId, bool includingUsedRecipe)
- {
- XmlDocument doc = new XmlDocument();
- var baseFolderPath = getRecipeDirPath(chamberId);
- DirectoryInfo curFolderInfo = new DirectoryInfo(baseFolderPath);
- doc.AppendChild(GenerateRecipeList(chamberId, curFolderInfo, doc, includingUsedRecipe));
- return doc.OuterXml;
- }
- public void SaveRecipeHistory(string chamberId, string recipeName, string recipeContent, bool needSaveAs = true)
- {
- try
- {
- if (!string.IsNullOrEmpty(recipeName) && needSaveAs)
- {
- string newRecipeName = string.Format("HistoryRecipe\\{0}\\{1}", DateTime.Now.ToString("yyyyMM"), recipeName);
- SaveRecipe(chamberId, newRecipeName, recipeContent, true, false);
- LOG.Write(string.Format("{0}通知TM保存工艺程序{1}", chamberId, recipeName));
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex, string.Format("保存{0}工艺程序{1}发生错误", chamberId, recipeName));
- }
- }
- /// <summary>
- /// generate recipe list information in current directory
- /// </summary>
- /// <param name="chamId"></param>
- /// <param name="currentDir"></param>
- /// <param name="doc"></param>
- /// <returns></returns>
- XmlElement GenerateRecipeList(string chamberId, DirectoryInfo currentDir, XmlDocument doc, bool includingUsedRecipe)
- {
- int trimLength = getRecipeDirPath(chamberId).Length;
- XmlElement folderEle = doc.CreateElement("Folder");
- folderEle.SetAttribute("Name", currentDir.FullName.Substring(trimLength));
- DirectoryInfo[] dirInfos = currentDir.GetDirectories();
- foreach (DirectoryInfo dirInfo in dirInfos)
- {
- if (!includingUsedRecipe && dirInfo.Name == "HistoryRecipe")
- continue;
- folderEle.AppendChild(GenerateRecipeList(chamberId, dirInfo, doc, includingUsedRecipe));
- }
- FileInfo[] fileInfos = currentDir.GetFiles("*.rcp");
- foreach (FileInfo fileInfo in fileInfos)
- {
- XmlElement fileNd = doc.CreateElement("File");
- string fileStr = fileInfo.FullName.Substring(trimLength).TrimStart(new char[] { '\\' }); ;
- fileStr = fileStr.Substring(0, fileStr.LastIndexOf("."));
- fileNd.SetAttribute("Name", fileStr);
- folderEle.AppendChild(fileNd);
- }
- return folderEle;
- }
- XmlElement GeneratelRestoreRecipeList(string chamberId, DirectoryInfo currentDir, XmlDocument doc, bool includingUsedRecipe)
- {
- int trimLength = getRecipeBackupDirPath(chamberId).Length;
- XmlElement folderEle = doc.CreateElement("Folder");
- var name = currentDir.FullName.Substring(trimLength);
- folderEle.SetAttribute("Name", name);
- DirectoryInfo[] dirInfos = currentDir.GetDirectories();
- foreach (DirectoryInfo dirInfo in dirInfos)
- {
- if (!includingUsedRecipe && dirInfo.Name == "HistoryRecipe")
- continue;
- folderEle.AppendChild(GeneratelRestoreRecipeList(chamberId, dirInfo, doc, includingUsedRecipe));
- }
- FileInfo[] fileInfos = currentDir.GetFiles("*.rcp");
- foreach (FileInfo fileInfo in fileInfos)
- {
- XmlElement fileNd = doc.CreateElement("File");
- string fileStr = fileInfo.FullName.Substring(trimLength).TrimStart(new char[] { '\\' }); ;
- fileStr = fileStr.Substring(0, fileStr.LastIndexOf("."));
- fileNd.SetAttribute("Name", fileStr);
- folderEle.AppendChild(fileNd);
- }
- return folderEle;
- }
- /// <summary>
- /// Delete a recipe by recipe name
- /// </summary>
- /// <param name="chamId"></param>
- /// <param name="recipeName"></param>
- /// <returns></returns>
- public bool DeleteRecipe(string chamberId, string recipeName)
- {
- try
- {
- File.Delete(GenerateRecipeFilePath(chamberId, recipeName));
- InfoDialog(string.Format(Resources.RecipeFileManager_DeleteRecipe_RecipeFile0DeleteSucceeded, recipeName));
- }
- catch (Exception ex)
- {
- LOG.Write(ex, "删除recipe file 出错");
- WarningDialog(string.Format(Resources.RecipeFileManager_DeleteRecipe_RecipeFile0DeleteFailed, recipeName));
- return false;
- }
- return true;
- }
- /// <summary>
- /// Rename recipe
- /// </summary>
- /// <param name="chamId"></param>
- /// <param name="oldName"></param>
- /// <param name="newName"></param>
- /// <returns></returns>
- public bool RenameRecipe(string chamId, string oldName, string newName)
- {
- try
- {
- if (File.Exists(GenerateRecipeFilePath(chamId, newName)))
- {
- WarningDialog(string.Format(Resources.RecipeFileManager_RenameRecipe_RecipeFile0FileExisted, oldName));
- return false;
- }
- else
- {
- File.Move(GenerateRecipeFilePath(chamId, oldName), GenerateRecipeFilePath(chamId, newName));
- InfoDialog(string.Format(Resources.RecipeFileManager_RenameRecipe_RecipeFile0Renamed, oldName, newName));
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex, "重命名recipe file 出错");
- WarningDialog(string.Format(Resources.RecipeFileManager_RenameRecipe_RecipeFile0RenameFailed, oldName, newName));
- return false;
- }
- return true;
- }
- public bool BackupRecipe(string fileOriginalPath, string fileDestinationPath, bool isSaveLinkRecipe, List<string> recipeNames)
- {
- try
- {
- string filePath = getRecipeBackupDirPath(fileOriginalPath);
- foreach (var item in recipeNames)
- {
- string sourceFilePath = GenerateRecipeFilePath(fileOriginalPath, item);
- string destFilePath = GenerateBackupRecipeFilePath(fileDestinationPath, item);
- if (item.Contains("\\"))
- {
- DirectoryInfo di = new DirectoryInfo(Path.GetDirectoryName(destFilePath));
- if (!di.Exists) di.Create();
- }
- File.Copy(sourceFilePath, destFilePath, true);
- if (isSaveLinkRecipe)
- {
- string recipeContent = LoadRecipe(fileOriginalPath, item, false);
- var xmlRecipe = new XmlDocument();
- try
- {
- string chamberType = fileOriginalPath.Split('\\')[0];
- string processType = fileOriginalPath.Split('\\')[1];
- if (string.IsNullOrEmpty(recipeContent))
- continue;
- xmlRecipe.LoadXml(recipeContent);
- XmlNodeList nodeSteps = xmlRecipe.SelectNodes($"Aitex/TableRecipeData/Module[@Name='{processType}']/Step");
- XmlNode nodeConfig = xmlRecipe.SelectNodes($"Aitex/TableRecipeData/Config")[0];
- switch (processType)
- {
- case "WaferFlow":
- string strSystemReicpeName = nodeConfig.Attributes["SystemRecipe"]?.Value;
- if (!string.IsNullOrEmpty(strSystemReicpeName))
- {
- if (CheckRecipe($"{_chamberId}\\System", strSystemReicpeName, out List<string> subReasons))
- {
- string subSourceFilePath = GenerateRecipeFilePath($"{_chamberId}\\System", strSystemReicpeName);
- string subDestFilePath = GenerateBackupRecipeFilePath($"{fileDestinationPath.Split('\\')[0]}\\System", strSystemReicpeName);
- DirectoryInfo di = new DirectoryInfo(Path.GetDirectoryName(subDestFilePath));
- if (!di.Exists) di.Create();
- File.Copy(subSourceFilePath, subDestFilePath, true);
- }
- }
- break;
- case "COT":
- case "DEV":
- string pumpRecipeName = nodeConfig.Attributes["COTPumpRecipe"]?.Value;
- if (!string.IsNullOrEmpty(pumpRecipeName))
- {
- if (CheckRecipe($"{_chamberId}\\Pump", pumpRecipeName, out List<string> subReasons))
- {
- string subSourceFilePath = GenerateRecipeFilePath($"{_chamberId}\\Pump", pumpRecipeName);
- string subDestFilePath = GenerateBackupRecipeFilePath($"{fileDestinationPath.Split('\\')[0]}\\Pump", pumpRecipeName);
- DirectoryInfo di = new DirectoryInfo(Path.GetDirectoryName(subDestFilePath));
- if (!di.Exists) di.Create();
- File.Copy(subSourceFilePath, subDestFilePath, true);
- }
- }
- break;
- case "ADH":
- case "Oven":
- break;
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex);
- continue;
- }
- }
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex, "Backup Recipe file error");
- }
- return true;
- }
- public bool CheckBackRecipeIsLinkRecipe(string fileOriginalPath, List<string> recipeNames)
- {
- string chamberType = fileOriginalPath.Split('\\')[0];
- string processType = fileOriginalPath.Split('\\')[1];
- foreach (var item in recipeNames)
- {
- string recipeContent = LoadRestoreRecipe(fileOriginalPath, item, false);
- var xmlRecipe = new XmlDocument();
- try
- {
- if (string.IsNullOrEmpty(recipeContent))
- continue;
- xmlRecipe.LoadXml(recipeContent);
- XmlNodeList nodeSteps = xmlRecipe.SelectNodes($"Aitex/TableRecipeData/Module[@Name='{processType}']/Step");
- XmlNode nodeConfig = xmlRecipe.SelectNodes($"Aitex/TableRecipeData/Config")[0];
- switch (processType)
- {
- case "WaferFlow":
- string strSystemReicpeName = nodeConfig.Attributes["SystemRecipe"]?.Value;
- if (!string.IsNullOrEmpty(strSystemReicpeName))
- {
- //if (CheckRecipe($"{_chamberId}\\System", strSystemReicpeName, out List<string> subReasons))
- //{
- return true;
- //}
- }
- break;
- case "COT":
- case "DEV":
- string pumpRecipeName = nodeConfig.Attributes["COTPumpRecipe"]?.Value;
- if (!string.IsNullOrEmpty(pumpRecipeName))
- {
- //if (CheckRecipe($"{_chamberId}\\Pump", pumpRecipeName, out List<string> subReasons))
- //{
- return true;
- //}
- }
- break;
- case "ADH":
- case "Oven":
- break;
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex);
- return false;
- }
- }
- return false;
- }
- public string GetXmlRestoreRecipeList(string chamberId, bool includingUsedRecipe)
- {
- XmlDocument doc = new XmlDocument();
- var baseFolderPath = getRecipeBackupDirPath(chamberId);
- DirectoryInfo curFolderInfo = new DirectoryInfo(baseFolderPath);
- doc.AppendChild(GeneratelRestoreRecipeList(chamberId, curFolderInfo, doc, includingUsedRecipe));
- return doc.OuterXml;
- }
- public List<string> RestoreRecipeFolderList()
- {
- List<string> folderList = new List<string>();
- var recipeBackupPath = PathManager.GetRecipeBackupDir();
- DirectoryInfo directoryInfo = new DirectoryInfo(recipeBackupPath);
- DirectoryInfo[] directoryInfos = directoryInfo.GetDirectories();
- foreach (var item in directoryInfos)
- {
- folderList.Add(item.Name);
- }
- return folderList;
- }
- public string LoadRestoreRecipe(string chamberId, string recipeName, bool needValidation)
- {
- string rcp = string.Empty;
- try
- {
- using (StreamReader fs = new StreamReader(GenerateBackupRecipeFilePath(chamberId, recipeName)))
- {
- rcp = fs.ReadToEnd();
- fs.Close();
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex, $"load recipe file failed, {recipeName}");
- rcp = string.Empty;
- }
- return rcp;
- }
- public bool SigRestoreRecipe(string chamId, List<string> recipeNames)
- {
- try
- {
- string filePath = getRecipeBackupDirPath(chamId);
- foreach (var item in recipeNames)
- {
- string strdest = chamId;
- string destFilePath = GenerateRecipeFilePath(strdest, item);
- string sourceFilePath = GenerateBackupRecipeFilePath(chamId, item);
- if (item.Contains("\\"))
- {
- DirectoryInfo di = new DirectoryInfo(Path.GetDirectoryName(destFilePath));
- if (!di.Exists) di.Create();
- }
- File.Copy(sourceFilePath, destFilePath, true);
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex, "Backup Recipe file error");
- }
- return true;
- }
- public bool RestoreRecipe(string chamId, bool isSaveLink, List<string> recipeNames)
- {
- try
- {
- string filePath = getRecipeBackupDirPath(chamId);
- foreach (var item in recipeNames)
- {
- string strdest = chamId.Remove(5, 14);
- string destFilePath = GenerateRecipeFilePath(strdest, item);
- string sourceFilePath = GenerateBackupRecipeFilePath(chamId, item);
- if (item.Contains("\\"))
- {
- DirectoryInfo di = new DirectoryInfo(Path.GetDirectoryName(destFilePath));
- if (!di.Exists) di.Create();
- }
- File.Copy(sourceFilePath, destFilePath, true);
- if (isSaveLink)
- {
- string recipeContent = LoadRestoreRecipe(chamId, item, false);
- var xmlRecipe = new XmlDocument();
- try
- {
- string chamberType = chamId.Split('\\')[0];
- string processType = chamId.Split('\\')[1];
- if (string.IsNullOrEmpty(recipeContent))
- continue;
- xmlRecipe.LoadXml(recipeContent);
- XmlNodeList nodeSteps = xmlRecipe.SelectNodes($"Aitex/TableRecipeData/Module[@Name='{processType}']/Step");
- XmlNode nodeConfig = xmlRecipe.SelectNodes($"Aitex/TableRecipeData/Config")[0];
- switch (processType)
- {
- case "WaferFlow":
- string strSystemReicpeName = nodeConfig.Attributes["SystemRecipe"]?.Value;
- if (!string.IsNullOrEmpty(strSystemReicpeName))
- {
- if (CheckRestoreRecipe($"{ chamId.Split('\\')[0]}\\System", strSystemReicpeName, out List<string> subReasons))
- {
- string subSourceFilePath = GenerateBackupRecipeFilePath($"{chamId.Split('\\')[0]}\\System", strSystemReicpeName);
- string subDestFilePath = GenerateRecipeFilePath($"{_chamberId}\\System", strSystemReicpeName);
- if (item.Contains("\\"))
- {
- DirectoryInfo di = new DirectoryInfo(Path.GetDirectoryName(subDestFilePath));
- if (!di.Exists) di.Create();
- }
- File.Copy(subSourceFilePath, subDestFilePath, true);
- }
- }
- break;
- case "COT":
- case "DEV":
- string pumpRecipeName = nodeConfig.Attributes["COTPumpRecipe"]?.Value;
- if (!string.IsNullOrEmpty(pumpRecipeName))
- {
- if (CheckRestoreRecipe($"{_chamberId}\\Pump", pumpRecipeName, out List<string> subReasons))
- {
- string subSourceFilePath = GenerateBackupRecipeFilePath($"{chamId.Split('\\')[0]}\\Pump", pumpRecipeName);
- string subDestFilePath = GenerateRecipeFilePath($"{_chamberId}\\Pump", pumpRecipeName);
- if (item.Contains("\\"))
- {
- DirectoryInfo di = new DirectoryInfo(Path.GetDirectoryName(subDestFilePath));
- if (!di.Exists) di.Create();
- }
- File.Copy(subSourceFilePath, subDestFilePath, true);
- }
- }
- break;
- case "ADH":
- case "Oven":
- break;
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex);
- continue;
- }
- }
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex, "Backup Recipe file error");
- }
- return true;
- }
- //private void EventInfo(string message)
- //{
- // _rcpContext.PostInfoEvent(message);
- //}
- //private void EventWarning(string message)
- //{
- // _rcpContext.PostWarningEvent(message);
- //}
- //private void EventAlarm(string message)
- //{
- // _rcpContext.PostAlarmEvent(message);
- //}
- private void InfoDialog(string message)
- {
- _rcpContext.PostInfoDialogMessage(message);
- }
- private void WarningDialog(string message)
- {
- _rcpContext.PostWarningDialogMessage(message);
- }
- //private void AlarmDialog(string message)
- //{
- // _rcpContext.PostAlarmDialogMessage(message);
- //}
- private void EventDialog(string message, List<string> reason)
- {
- string msg = message;
- foreach (var r in reason)
- {
- msg += "\r\n" + r;
- }
- _rcpContext.PostDialogEvent(msg);
- }
- /// <summary>
- /// get recipe's file path
- /// </summary>
- /// <param name="recipeName"></param>
- /// <returns></returns>
- private string GenerateRecipeFilePath(string chamId, string recipeName)
- {
- return getRecipeDirPath(chamId) + recipeName + ".rcp";
- }
- private string GenerateBackupRecipeFilePath(string chamId, string recipeName)
- {
- return getRecipeBackupDirPath(chamId) + recipeName + ".rcp";
- }
- private string GenerateSequenceFilePath(string chamId, string recipeName)
- {
- return getRecipeDirPath(chamId) + recipeName + ".seq";
- }
- /// <summary>
- /// get recipe's dir path
- /// </summary>
- /// <param name="recipeName"></param>
- /// <returns></returns>
- private string getRecipeDirPath(string chamId)
- {
- var dir = string.Format("{0}{1}\\", PathManager.GetRecipeDir(), chamId);
- DirectoryInfo di = new DirectoryInfo(dir);
- if (!di.Exists) di.Create();
- return dir;
- }
- /// <summary>
- /// get recipe's dir path
- /// </summary>
- /// <param name="recipeName"></param>
- /// <returns></returns>
- private string getRecipeBackupDirPath(string chamId)
- {
- var dir = string.Format("{0}{1}\\", PathManager.GetRecipeBackupDir(), chamId);
- DirectoryInfo di = new DirectoryInfo(dir);
- if (!di.Exists) di.Create();
- return dir;
- }
- /// <summary>
- /// delete a recipe folder
- /// </summary>
- /// <param name="chamId"></param>
- /// <param name="folderName"></param>
- /// <returns></returns>
- public bool DeleteFolder(string chamId, string folderName)
- {
- try
- {
- Directory.Delete(getRecipeDirPath(chamId) + folderName, true);
- InfoDialog(string.Format(Resources.RecipeFileManager_DeleteFolder_RecipeFolder0DeleteSucceeded, folderName));
- }
- catch (Exception ex)
- {
- LOG.Write(ex, "删除recipe folder 出错");
- WarningDialog(string.Format("recipe folder {0} delete failed", folderName));
- return false;
- }
- return true;
- }
- /// <summary>
- /// save as recipe content
- /// </summary>
- /// <param name="chamId"></param>
- /// <param name="recipeName"></param>
- /// <param name="recipeContent"></param>
- /// <returns></returns>
- public bool SaveAsRecipe(string chamId, string recipeName, string recipeContent)
- {
- var path = GenerateRecipeFilePath(chamId, recipeName);
- if (File.Exists(path))
- {
- WarningDialog(string.Format(Resources.RecipeFileManager_SaveAsRecipe_RecipeFile0savefailed, recipeName));
- return false;
- }
- return SaveRecipe(chamId, recipeName, recipeContent, true, true);
- }
- /// <summary>
- /// save recipe content
- /// </summary>
- /// <param name="chamId"></param>
- /// <param name="recipeName"></param>
- /// <param name="recipeContent"></param>
- /// <returns></returns>
- public bool SaveRecipe(string chamId, string recipeName, string recipeContent, bool clearBarcode, bool notifyUI)
- {
- //validate recipe format when saving a recipe file
- //var reasons1 = new List<string>();
- //var reasons2 = new List<string>();
- //ValidateRecipe(chamId, recipeName, recipeContent, out reasons1);
- //CheckRecipe(chamId, recipeContent, out reasons2);
- //reasons1.AddRange(reasons2);
- //if (reasons1.Count > 0)
- //{
- // EventDialog(string.Format( Resources.RecipeFileManager_SaveRecipe_SaveRecipeContentError, recipeName), reasons1);
- //}
- bool ret = true;
- try
- {
- var path = GenerateRecipeFilePath(chamId, recipeName);
- FileInfo fi = new FileInfo(path);
- if (!fi.Directory.Exists)
- fi.Directory.Create();
- XmlDocument xml = new XmlDocument();
- xml.LoadXml(recipeContent);
- XmlTextWriter writer = new XmlTextWriter(path, Encoding.UTF8);
- writer.Formatting = Formatting.Indented;
- xml.Save(writer);
- writer.Close();
- if (notifyUI)
- {
- InfoDialog(string.Format(Resources.RecipeFileManager_SaveRecipe_RecipeFile0SaveCompleted, recipeName));
- }
- else
- {
- EV.PostMessage("System", EventEnum.GeneralInfo, string.Format(Resources.RecipeFileManager_SaveRecipe_RecipeFile0SaveCompleted, recipeName));
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex, "保存recipe file 出错");
- if (notifyUI)
- {
- WarningDialog(string.Format(Resources.RecipeFileManager_SaveRecipe_RecipeFile0SaveFailed, recipeName));
- }
- ret = false;
- }
- return ret;
- }
- /// <summary>
- /// save recipe content
- /// </summary>
- /// <param name="chamId"></param>
- /// <param name="recipeName"></param>
- /// <param name="recipeContent"></param>
- /// <returns></returns>
- public bool SaveRestoreRecipe(string chamId, string recipeName, string recipeContent, bool clearBarcode, bool notifyUI)
- {
- //validate recipe format when saving a recipe file
- //var reasons1 = new List<string>();
- //var reasons2 = new List<string>();
- //ValidateRecipe(chamId, recipeName, recipeContent, out reasons1);
- //CheckRecipe(chamId, recipeContent, out reasons2);
- //reasons1.AddRange(reasons2);
- //if (reasons1.Count > 0)
- //{
- // EventDialog(string.Format( Resources.RecipeFileManager_SaveRecipe_SaveRecipeContentError, recipeName), reasons1);
- //}
- bool ret = true;
- try
- {
- var path = GenerateBackupRecipeFilePath(chamId, recipeName);
- FileInfo fi = new FileInfo(path);
- if (!fi.Directory.Exists)
- fi.Directory.Create();
- XmlDocument xml = new XmlDocument();
- xml.LoadXml(recipeContent);
- XmlTextWriter writer = new XmlTextWriter(path, Encoding.UTF8);
- writer.Formatting = Formatting.Indented;
- xml.Save(writer);
- writer.Close();
- if (notifyUI)
- {
- InfoDialog(string.Format(Resources.RecipeFileManager_SaveRecipe_RecipeFile0SaveCompleted, recipeName));
- }
- else
- {
- EV.PostMessage("System", EventEnum.GeneralInfo, string.Format(Resources.RecipeFileManager_SaveRecipe_RecipeFile0SaveCompleted, recipeName));
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex, "保存recipe file 出错");
- if (notifyUI)
- {
- WarningDialog(string.Format(Resources.RecipeFileManager_SaveRecipe_RecipeFile0SaveFailed, recipeName));
- }
- ret = false;
- }
- return ret;
- }
- /// <summary>
- /// create a new recipe folder
- /// </summary>
- /// <param name="chamId"></param>
- /// <param name="folderName"></param>
- /// <returns></returns>
- public bool CreateFolder(string chamId, string folderName)
- {
- try
- {
- Directory.CreateDirectory(getRecipeDirPath(chamId) + folderName);
- InfoDialog(string.Format(Resources.RecipeFileManager_CreateFolder_RecipeFolder0Created, folderName));
- }
- catch (Exception ex)
- {
- LOG.Write(ex, "create recipe folder failed");
- WarningDialog(string.Format(Resources.RecipeFileManager_CreateFolder_RecipeFolder0CreateFailed, folderName));
- return false;
- }
- return true;
- }
- /// <summary>
- /// Rename recipe folder name
- /// </summary>
- /// <param name="chamId"></param>
- /// <param name="oldName"></param>
- /// <param name="newName"></param>
- /// <returns></returns>
- public bool RenameFolder(string chamId, string oldName, string newName)
- {
- try
- {
- string oldPath = getRecipeDirPath(chamId) + oldName;
- string newPath = getRecipeDirPath(chamId) + newName;
- Directory.Move(oldPath, newPath);
- InfoDialog(string.Format(Resources.RecipeFileManager_RenameFolder_RecipeFolder0renamed, oldName, newName));
- }
- catch (Exception ex)
- {
- LOG.Write(ex, "Rename recipe folder failed");
- WarningDialog(string.Format(Resources.RecipeFileManager_RenameFolder_RecipeFolder0RenameFailed, oldName, newName));
- return false;
- }
- return true;
- }
- public XmlDocument RecipeDom = new XmlDocument();
- private string GetRecipeBody(string chamberId, string nodePath)
- {
- if (_rcpContext == null)
- return string.Empty;
- string schema = _rcpContext.GetRecipeDefiniton(chamberId);
- RecipeDom = new XmlDocument();
- RecipeDom.LoadXml(schema);
- XmlNode node = RecipeDom.SelectSingleNode(nodePath);
- return node.OuterXml;
- }
- public string RecipeChamberType
- {
- get;
- set;
- }
- public string RecipeVersion
- {
- get;
- set;
- }
- public Dictionary<string, ObservableCollection<RecipeTemplateColumnBase>> GetGroupRecipeTemplate()
- {
- try
- {
- XmlNode nodeRoot = RecipeDom.SelectSingleNode("Aitex/TableRecipeFormat");
- RecipeChamberType = nodeRoot.Attributes["RecipeChamberType"].Value;
- RecipeVersion = nodeRoot.Attributes["RecipeVersion"].Value;
- }
- catch (Exception ex)
- {
- LOG.Write(ex);
- return null;
- }
- var columns = new Dictionary<string, ObservableCollection<RecipeTemplateColumnBase>>();
- RecipeTemplateColumnBase col = null;
- XmlNodeList nodes = RecipeDom.SelectNodes("Aitex/TableRecipeFormat/Catalog/Group");
- foreach (XmlNode node in nodes)
- {
- var sigcolumns = new ObservableCollection<RecipeTemplateColumnBase>();
- XmlNodeList childNodes = node.SelectNodes("Step");
- foreach (XmlNode step in childNodes)
- {
- //step number
- if (step.Attributes["ControlName"].Value == "StepNo")
- {
- col = new RecipeTemplateColumnBase()
- {
- DisplayName = "Step",
- ControlName = "StepNo",
- };
- sigcolumns.Add(col);
- continue;
- }
- switch (step.Attributes["InputType"].Value)
- {
- case "TextInput":
- col = new RecipeTemplateColumnBase()
- {
- ValueType = "TextInput",
- ModuleName = step.Attributes["ModuleName"].Value,
- ControlName = step.Attributes["ControlName"].Value,
- DisplayName = step.Attributes["DisplayName"].Value,
- IsEnable = !bool.Parse(step.Attributes["ReadOnly"] != null ? step.Attributes["ReadOnly"].Value : "false"),
- EnableConfig = step.Attributes["EnableConfig"] != null && Convert.ToBoolean(step.Attributes["EnableConfig"].Value),
- EnableTolerance = step.Attributes["EnableTolerance"] != null && Convert.ToBoolean(step.Attributes["EnableTolerance"].Value),
- };
- sigcolumns.Add(col);
- break;
- case "NumInput":
- col = new RecipeTemplateColumnBase()
- {
- ValueType = "NumInput",
- ModuleName = step.Attributes["ModuleName"].Value,
- ControlName = step.Attributes["ControlName"].Value,
- DisplayName = step.Attributes["DisplayName"].Value,
- InputMode = step.Attributes["InputMode"].Value,
- Minimun = double.Parse(step.Attributes["Min"].Value),
- Maximun = double.Parse(step.Attributes["Max"].Value),
- IsEnable = !bool.Parse(step.Attributes["ReadOnly"] != null ? step.Attributes["ReadOnly"].Value : "false"),
- EnableConfig = step.Attributes["EnableConfig"] != null && Convert.ToBoolean(step.Attributes["EnableConfig"].Value),
- EnableTolerance = step.Attributes["EnableTolerance"] != null && Convert.ToBoolean(step.Attributes["EnableTolerance"].Value),
- };
- sigcolumns.Add(col);
- break;
- case "DoubleInput":
- col = new RecipeTemplateColumnBase()
- {
- ValueType = "DoubleInput",
- ModuleName = step.Attributes["ModuleName"].Value,
- ControlName = step.Attributes["ControlName"].Value,
- DisplayName = step.Attributes["DisplayName"].Value,
- InputMode = step.Attributes["InputMode"].Value,
- Minimun = double.Parse(step.Attributes["Min"].Value),
- Maximun = double.Parse(step.Attributes["Max"].Value),
- IsEnable = !bool.Parse(step.Attributes["ReadOnly"] != null ? step.Attributes["ReadOnly"].Value : "false"),
- EnableConfig = step.Attributes["EnableConfig"] != null && Convert.ToBoolean(step.Attributes["EnableConfig"].Value),
- EnableTolerance = step.Attributes["EnableTolerance"] != null && Convert.ToBoolean(step.Attributes["EnableTolerance"].Value),
- };
- sigcolumns.Add(col);
- break;
- case "EditableSelection":
- col = new RecipeTemplateColumnBase()
- {
- ValueType = "EditableSelection",
- ModuleName = step.Attributes["ModuleName"].Value,
- Default = step.Attributes["Default"] != null ? step.Attributes["Default"].Value : "",
- ControlName = step.Attributes["ControlName"].Value,
- DisplayName = step.Attributes["DisplayName"].Value,
- IsEnable = !bool.Parse(step.Attributes["ReadOnly"] != null ? step.Attributes["ReadOnly"].Value : "false"),
- EnableConfig = step.Attributes["EnableConfig"] != null && Convert.ToBoolean(step.Attributes["EnableConfig"].Value),
- EnableTolerance = step.Attributes["EnableTolerance"] != null && Convert.ToBoolean(step.Attributes["EnableTolerance"].Value),
- };
- XmlNodeList items = step.SelectNodes("Item");
- foreach (XmlNode item in items)
- {
- Option opt = new Option();
- opt.ControlName = item.Attributes["ControlName"].Value;
- opt.DisplayName = item.Attributes["DisplayName"].Value;
- ((RecipeTemplateColumnBase)col).Options.Add(opt);
- }
- sigcolumns.Add(col);
- break;
- case "ReadOnlySelection":
- case "LoopSelection":
- col = new RecipeTemplateColumnBase()
- {
- ValueType = "LoopSelection",
- IsReadOnly = bool.Parse(step.Attributes["ReadOnly"] != null ? step.Attributes["ReadOnly"].Value : "false"),
- ModuleName = step.Attributes["ModuleName"].Value,
- ControlName = step.Attributes["ControlName"].Value,
- DisplayName = step.Attributes["DisplayName"].Value,
- EnableConfig = step.Attributes["EnableConfig"] != null && Convert.ToBoolean(step.Attributes["EnableConfig"].Value),
- EnableTolerance = step.Attributes["EnableTolerance"] != null && Convert.ToBoolean(step.Attributes["EnableTolerance"].Value),
- };
- XmlNodeList options = step.SelectNodes("Item");
- foreach (XmlNode item in options)
- {
- Option opt = new Option();
- opt.ControlName = item.Attributes["ControlName"].Value;
- opt.DisplayName = item.Attributes["DisplayName"].Value;
- ((RecipeTemplateColumnBase)col).Options.Add(opt);
- }
- sigcolumns.Add(col);
- break;
- case "PopSetting":
- col = new RecipeTemplateColumnBase()
- {
- ValueType = "LoopSelection",
- ModuleName = step.Attributes["ModuleName"].Value,
- ControlName = step.Attributes["ControlName"].Value,
- DisplayName = step.Attributes["DisplayName"].Value,
- EnableConfig = step.Attributes["EnableConfig"] != null && Convert.ToBoolean(step.Attributes["EnableConfig"].Value),
- EnableTolerance = step.Attributes["EnableTolerance"] != null && Convert.ToBoolean(step.Attributes["EnableTolerance"].Value),
- };
- sigcolumns.Add(col);
- break;
- }
- }
- columns.Add(node.Attributes["DisplayName"].Value, sigcolumns);
- }
- return columns;
- }
- /// <summary>
- /// get reactor's recipe format define file
- /// </summary>
- /// <param name="chamId"></param>
- /// <returns></returns>
- public string GetRecipeFormatXml(string chamberId)
- {
- var rtn = GetRecipeBody(chamberId, "/Aitex/TableRecipeFormat");
- return rtn;
- }
- /// <summary>
- /// get reactor's template recipe file
- /// </summary>
- /// <param name="chamId"></param>
- /// <returns></returns>
- public string GetRecipeTemplate(string chamberId)
- {
- if (_rcpContext != null)
- return _rcpContext.GetRecipeTemplate(chamberId);
- return GetRecipeBody(chamberId, "/Aitex/TableRecipeData");
- }
- /// <summary>
- /// get reactor's template recipe file
- /// </summary>
- /// <param name="chamId"></param>
- /// <returns></returns>
- public string GetRecipeSchema(string chamberId)
- {
- if (_rcpContext == null)
- return string.Empty;
- string schema = _rcpContext.GetRecipeDefiniton(chamberId);
- XmlDocument dom = new XmlDocument();
- dom.LoadXml(schema);
- XmlNode node = dom.SelectSingleNode("/Aitex/TableRecipeSchema");
- return node.InnerXml;
- }
- public string GetRecipeByBarcode(string chamberId, string barcode)
- {
- try
- {
- string recipePath = PathManager.GetRecipeDir() + chamberId + "\\";
- var di = new DirectoryInfo(recipePath);
- var fis = di.GetFiles("*.rcp", SearchOption.AllDirectories);
- XmlDocument xml = new XmlDocument();
- foreach (var fi in fis)
- {
- string str = fi.FullName.Substring(recipePath.Length);
- if (!str.Contains("HistoryRecipe\\"))
- {
- xml.Load(fi.FullName);
- if (xml.SelectSingleNode(string.Format("/TableRecipeData[@Barcode='{0}']", barcode)) != null)
- {
- return str.Substring(0, str.LastIndexOf('.'));
- }
- }
- }
- return string.Empty;
- }
- catch (Exception ex)
- {
- LOG.Write(ex);
- return string.Empty;
- }
- }
- public List<string> ExpertLayoutRecipeParse(string chamberId, string recipeFile)
- {
- var layoutRecipe = new List<string>();
- string content = LoadRecipe(chamberId, recipeFile, false);
- if (string.IsNullOrEmpty(content))
- {
- //reason = $"{recipeFile} is not a valid recipe file";
- return layoutRecipe;
- }
- try
- {
- XmlDocument rcpDataDoc = new XmlDocument();
- rcpDataDoc.LoadXml(content);
- XmlNode nodeModule;
- nodeModule = rcpDataDoc.SelectSingleNode("/Aitex/TableRecipeData/Module/Step[@Name='Expert']");
- if (nodeModule == null)
- {
- return layoutRecipe;
- }
- else
- {
- Dictionary<string, string> recipeData = new Dictionary<string, string>();
- XmlElement stepNode = nodeModule as XmlElement;
- //遍历Step节点
- foreach (XmlAttribute att in stepNode.Attributes)
- {
- if (att.Name != "Name")
- {
- if (att.Value.ToLower() == "xd")
- {
- layoutRecipe.Add("XD");
- }
- else if (att.Value.ToLower() == "t")
- {
- layoutRecipe.Add("T");
- }
- else
- {
- layoutRecipe.Add("");
- }
- }
- }
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex);
- return layoutRecipe;
- }
- return layoutRecipe;
- }
- public List<string> LayoutExpertRecipeParse(/*string chamberId, */string recipeContent, string slotCount, string cassetteSlotCount)
- {
- var layoutRecipe = new List<string>();
- try
- {
- XmlDocument rcpDataDoc = new XmlDocument();
- rcpDataDoc.LoadXml(recipeContent);
- XmlNode nodeModule;
- nodeModule = rcpDataDoc.SelectSingleNode("/Aitex/TableRecipeData/Module/Step[@Name='Normal']");
- if (nodeModule == null)
- {
- //reason = "Recipe file does not contains step content for Normal";
- return layoutRecipe;
- }
- else
- {
- Dictionary<string, string> recipeData = new Dictionary<string, string>();
- XmlElement stepNode = nodeModule as XmlElement;
- //遍历Step节点
- foreach (XmlAttribute att in stepNode.Attributes)
- {
- if (att.Name != "Name")
- {
- recipeData[att.Name] = att.Value;
- }
- }
- // 获取SlotCount
- int iSlotCount = 0;
- int.TryParse(slotCount, out iSlotCount);
- // 获取CassetteSlotCount;
- int iCassetteSlotCount = 0;
- int.TryParse(cassetteSlotCount, out iCassetteSlotCount);
- // 先往List里面添加SlotcCount数量的空值,后续再往里面insert具体的值
- for (int i = 0; i < iSlotCount; i++)
- {
- layoutRecipe.Add(string.Empty);
- }
- // 获取DummyUpperSlot
- int iDummyUpperSlot;
- iDummyUpperSlot = 0;
- if (recipeData.ContainsKey("DummyUpperSlot"))
- {
- int.TryParse(recipeData["DummyUpperSlot"], out iDummyUpperSlot);
- if (iDummyUpperSlot == 0)
- {
- return layoutRecipe;
- }
- }
- else
- {
- return layoutRecipe;
- }
- // insert Upper Dummy
- for (int i = 0; i < iDummyUpperSlot; i++)
- {
- layoutRecipe[i] = "XD";
- }
- // 获取DummyLowerSlot
- int iDummyLowerSlot;
- iDummyLowerSlot = 0;
- if (recipeData.ContainsKey("DummyLowerSlot"))
- {
- int.TryParse(recipeData["DummyLowerSlot"], out iDummyLowerSlot);
- if (iDummyLowerSlot == 0)
- {
- return layoutRecipe;
- }
- }
- else
- {
- return layoutRecipe;
- }
- // insert Lower Dummy
- for (int i = iSlotCount - 1; i >= iSlotCount - iDummyLowerSlot; i--)
- {
- layoutRecipe[i] = "XD";
- }
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex);
- return layoutRecipe;
- }
- return layoutRecipe;
- }
- public List<string> LayoutRecipeParse(/*string chamberId, */string recipeContent, string slotCount, string cassetteSlotCount)
- {
- var layoutRecipe = new List<string>();
- //string content = loadrecipe(chamberid, recipefile, false);
- //if (string.isnullorempty(content))
- //{
- // reason = $"{recipefile} is not a valid recipe file";
- // return layoutrecipe;
- //}
- try
- {
- XmlDocument rcpDataDoc = new XmlDocument();
- rcpDataDoc.LoadXml(recipeContent);
- XmlNode nodeModule;
- nodeModule = rcpDataDoc.SelectSingleNode("/Aitex/TableRecipeData/Module/Step[@Name='Normal']");
- if (nodeModule == null)
- {
- //reason = "Recipe file does not contains step content for Normal";
- return layoutRecipe;
- }
- else
- {
- Dictionary<string, string> recipeData = new Dictionary<string, string>();
- XmlElement stepNode = nodeModule as XmlElement;
- //遍历Step节点
- foreach (XmlAttribute att in stepNode.Attributes)
- {
- if (att.Name != "Name")
- {
- recipeData[att.Name] = att.Value;
- }
- }
- // 获取SlotCount
- int iSlotCount = 0;
- int.TryParse(slotCount, out iSlotCount);
- // 获取CassetteSlotCount;
- int iCassetteSlotCount = 0;
- int.TryParse(cassetteSlotCount, out iCassetteSlotCount);
- // 先往List里面添加SlotcCount数量的空值,后续再往里面insert具体的值
- for (int i = 0; i < iSlotCount; i++)
- {
- layoutRecipe.Add(string.Empty);
- }
- // 获取DummyUpperSlot
- int iDummyUpperSlot;
- iDummyUpperSlot = 0;
- if (recipeData.ContainsKey("DummyUpperSlot"))
- {
- int.TryParse(recipeData["DummyUpperSlot"], out iDummyUpperSlot);
- if (iDummyUpperSlot == 0)
- {
- return layoutRecipe;
- }
- }
- else
- {
- return layoutRecipe;
- }
- // insert Upper Dummy
- for (int i = 0; i < iDummyUpperSlot; i++)
- {
- layoutRecipe[i] = "Dummy";
- }
- // 获取DummyLowerSlot
- int iDummyLowerSlot;
- iDummyLowerSlot = 0;
- if (recipeData.ContainsKey("DummyLowerSlot"))
- {
- int.TryParse(recipeData["DummyLowerSlot"], out iDummyLowerSlot);
- if (iDummyLowerSlot == 0)
- {
- return layoutRecipe;
- }
- }
- else
- {
- return layoutRecipe;
- }
- // insert Lower Dummy
- for (int i = iSlotCount - 1; i >= iSlotCount - iDummyLowerSlot; i--)
- {
- layoutRecipe[i] = "Dummy";
- }
- string strPitch, strProductPos, strProductSlotNo, strMonitorPos, strMonitorSlotNo, strMonitorBetweenCasseteNo;
- string strPWaferShort, strSDRule, strCassetteInBatchShort, strWaferInCasseteShort, strEDShort, strBoatRule;
- strPitch = string.Empty;
- strProductPos = string.Empty;
- strProductSlotNo = string.Empty;
- strMonitorPos = string.Empty;
- strMonitorSlotNo = string.Empty;
- strMonitorBetweenCasseteNo = string.Empty;
- strPWaferShort = string.Empty;
- strSDRule = string.Empty;
- strCassetteInBatchShort = string.Empty;
- strWaferInCasseteShort = string.Empty;
- strEDShort = string.Empty;
- strBoatRule = string.Empty;
- // 获取配置
- if (recipeData.ContainsKey("Pitch"))
- {
- strPitch = recipeData["Pitch"];
- }
- if (recipeData.ContainsKey("ProductPosition"))
- {
- strProductPos = recipeData["ProductPosition"];
- }
- if (recipeData.ContainsKey("ProductSlotNo"))
- {
- strProductSlotNo = recipeData["ProductSlotNo"];
- }
- if (recipeData.ContainsKey("MonitorPosition"))
- {
- strMonitorPos = recipeData["MonitorPosition"];
- }
- if (recipeData.ContainsKey("MonitorSlotNo"))
- {
- strMonitorSlotNo = recipeData["MonitorSlotNo"];
- }
- if (recipeData.ContainsKey("MonitorBetweenCassetteNo"))
- {
- strMonitorBetweenCasseteNo = recipeData["MonitorBetweenCassetteNo"];
- }
- if (recipeData.ContainsKey("WhenPWaferShort"))
- {
- strPWaferShort = recipeData["WhenPWaferShort"];
- }
- if (recipeData.ContainsKey("SDRule"))
- {
- strSDRule = recipeData["SDRule"];
- }
- if (recipeData.ContainsKey("WhenCassetteInBatchAreShort"))
- {
- strCassetteInBatchShort = recipeData["WhenCassetteInBatchAreShort"];
- }
- if (recipeData.ContainsKey("WhenWaferInCassetteAreShort"))
- {
- strWaferInCasseteShort = recipeData["WhenWaferInCassetteAreShort"];
- }
- if (recipeData.ContainsKey("WhenEDAreShort"))
- {
- strEDShort = recipeData["WhenEDAreShort"];
- }
- if (recipeData.ContainsKey("RuleOfSpaceInBoat"))
- {
- strBoatRule = recipeData["RuleOfSpaceInBoat"];
- }
- // insert Production and Monitor and ExtraDummy
- if (strProductPos == "Auto")
- {
- if (strMonitorPos == "BetweenCassette")
- {
- if (strPitch == "DoublePitch")
- {
- layoutRecipe = ProductAutoMonitorBetweenCassetteDoublePitch(iSlotCount, iCassetteSlotCount, iDummyUpperSlot, iDummyLowerSlot, strMonitorBetweenCasseteNo, strBoatRule);
- }
- else if (strPitch == "TriplePitch")
- {
- layoutRecipe = ProductAutoMonitorBetweenCassetteTriplePitch(iSlotCount, iCassetteSlotCount, iDummyUpperSlot, iDummyLowerSlot, strMonitorBetweenCasseteNo, strBoatRule);
- }
- else
- {
- layoutRecipe = ProductAutoMonitorBetweenCassetteStandardPitch(iSlotCount, iCassetteSlotCount, iDummyUpperSlot, iDummyLowerSlot, strMonitorBetweenCasseteNo, strBoatRule);
- }
- }
- else if (strMonitorPos == "Slot")
- {
- if (strPitch == "DoublePitch")
- {
- layoutRecipe = ProductAutoMonitorSlotDoublePitch(iSlotCount, iCassetteSlotCount, iDummyUpperSlot, iDummyLowerSlot, strMonitorSlotNo, strBoatRule);
- }
- else if (strPitch == "TriplePitch")
- {
- layoutRecipe = ProductAutoMonitorSlotTriplePitch(iSlotCount, iCassetteSlotCount, iDummyUpperSlot, iDummyLowerSlot, strMonitorSlotNo, strBoatRule);
- }
- else
- {
- layoutRecipe = ProductAutoMonitorSlotStandardPitch(iSlotCount, iCassetteSlotCount, iDummyUpperSlot, iDummyLowerSlot, strMonitorSlotNo, strBoatRule);
- }
- }
- else
- {
- //reason = "MonitorPosition is invalid";
- return layoutRecipe;
- }
- }
- else if (strProductPos == "Slot")
- {
- if (strMonitorPos == "BetweenCassette")
- {
- if (strPitch == "DoublePitch")
- {
- layoutRecipe = ProductSlotMonitorBetweenCassetteDoublePitch(iSlotCount, iCassetteSlotCount, iDummyUpperSlot, iDummyLowerSlot, strProductSlotNo, strMonitorBetweenCasseteNo, strBoatRule);
- }
- else if (strPitch == "TriplePitch")
- {
- layoutRecipe = ProductSlotMonitorBetweenCassetteTriplePitch(iSlotCount, iCassetteSlotCount, iDummyUpperSlot, iDummyLowerSlot, strProductSlotNo, strMonitorBetweenCasseteNo, strBoatRule);
- }
- else
- {
- layoutRecipe = ProductSlotMonitorBetweenCassetteStandardPitch(iSlotCount, iCassetteSlotCount, iDummyUpperSlot, iDummyLowerSlot, strProductSlotNo, strMonitorBetweenCasseteNo, strBoatRule);
- }
- }
- else if (strMonitorPos == "Slot")
- {
- if (strPitch == "DoublePitch")
- {
- layoutRecipe = ProductSlotMonitorSlotDoublePitch(iSlotCount, iCassetteSlotCount, iDummyUpperSlot, iDummyLowerSlot, strProductSlotNo, strMonitorSlotNo, strBoatRule);
- }
- else if (strPitch == "TriplePitch")
- {
- layoutRecipe = ProductSlotMonitorSlotTriplePitch(iSlotCount, iCassetteSlotCount, iDummyUpperSlot, iDummyLowerSlot, strProductSlotNo, strMonitorSlotNo, strBoatRule);
- }
- else
- {
- layoutRecipe = ProductSlotMonitorSlotStandardPitch(iSlotCount, iCassetteSlotCount, iDummyUpperSlot, iDummyLowerSlot, strProductSlotNo, strMonitorSlotNo, strBoatRule);
- }
- }
- else
- {
- //reason = "MonitorPosition is invalid";
- return layoutRecipe;
- }
- }
- else
- {
- //reason = "ProductPosition is invalid";
- return layoutRecipe;
- }
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex);
- return layoutRecipe;
- }
- return layoutRecipe;
- }
- private List<string> ProductAutoMonitorBetweenCassetteStandardPitch(int iSlotCount, int iCassetteSlotCount, int iDummyUpperSlot, int iDummyLowerSlot, string strMonitorBetweenCasseteNo, string strBoatRule)
- {
- var layoutRecipe = new List<string>();
- for (int i = 0; i < iSlotCount; i++)
- {
- layoutRecipe.Add(string.Empty);
- }
- try
- {
- // insert Upper Dummy
- for (int i = 0; i < iDummyUpperSlot; i++)
- {
- layoutRecipe[i] = "Dummy";
- }
- // insert Lower Dummy
- for (int i = iSlotCount - 1; i >= iSlotCount - iDummyLowerSlot; i--)
- {
- layoutRecipe[i] = "Dummy";
- }
- var monitorBetweenCassetteNo = new List<string>();
- monitorBetweenCassetteNo = GetLayoutProductionMonitorSlot(strMonitorBetweenCasseteNo);
- // insert Monitor
- int iIndex, iMonitorCount = 7;
- iIndex = iDummyUpperSlot;
- for (int i = 0; i < iMonitorCount; i++)
- {
- iIndex = iDummyUpperSlot + i * iCassetteSlotCount + i;
- if (iIndex < iSlotCount - iDummyLowerSlot - 1)
- {
- if (monitorBetweenCassetteNo[i] == "ON")
- {
- layoutRecipe[iIndex] = "Monitor";
- }
- }
- else
- {
- if (monitorBetweenCassetteNo[i] == "ON")
- {
- iIndex = iSlotCount - iDummyLowerSlot - 1;
- layoutRecipe[iIndex] = "Monitor";
- }
- }
- }
- // insert Production
- int iFirstMonitorIndex = 0;
- for (int i = iDummyUpperSlot; i < iSlotCount; i++)
- {
- if (layoutRecipe[i] == "Monitor")
- {
- iFirstMonitorIndex = i;
- break;
- }
- }
- // Search Up
- for (int i = iFirstMonitorIndex; i >= iDummyUpperSlot; i--)
- {
- if (layoutRecipe[i] == "")
- {
- layoutRecipe[i] = "Production";
- }
- else
- {
- break;
- }
- }
- // Search Down
- for (int i = iFirstMonitorIndex; i <= iSlotCount - iDummyLowerSlot - 1; i++)
- {
- if (layoutRecipe[i] == "")
- {
- layoutRecipe[i] = "Production";
- }
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex);
- return layoutRecipe;
- }
- return layoutRecipe;
- }
- private List<string> ProductAutoMonitorBetweenCassetteDoublePitch(int iSlotCount, int iCassetteSlotCount, int iDummyUpperSlot, int iDummyLowerSlot, string strMonitorBetweenCasseteNo, string strBoatRule)
- {
- var layoutRecipe = new List<string>();
- for (int i = 0; i < iSlotCount; i++)
- {
- layoutRecipe.Add(string.Empty);
- }
- try
- {
- // insert Upper Dummy
- for (int i = 0; i < iDummyUpperSlot; i++)
- {
- layoutRecipe[i] = "Dummy";
- }
- // insert Lower Dummy
- for (int i = iSlotCount - 1; i >= iSlotCount - iDummyLowerSlot; i--)
- {
- layoutRecipe[i] = "Dummy";
- }
- var monitorBetweenCassetteNo = new List<string>();
- monitorBetweenCassetteNo = GetLayoutProductionMonitorSlot(strMonitorBetweenCasseteNo);
- // insert Monitor
- int iIndex, iMonitorCount = 7;
- iIndex = iDummyUpperSlot;
- for (int i = 0; i < iMonitorCount; i += 2)
- {
- iIndex = iDummyUpperSlot + 1 + i * iCassetteSlotCount * 2 + i * 2;
- if (iIndex < iSlotCount - iDummyLowerSlot - 2)
- {
- if (monitorBetweenCassetteNo[i] == "ON")
- {
- layoutRecipe[iIndex] = "Monitor";
- }
- }
- else
- {
- if (monitorBetweenCassetteNo[i] == "ON")
- {
- iIndex = iSlotCount - iDummyLowerSlot - 2;
- layoutRecipe[iIndex] = "Monitor";
- }
- }
- }
- // insert Production
- int iFirstMonitorIndex = 0;
- for (int i = iDummyUpperSlot; i < iSlotCount; i++)
- {
- if (layoutRecipe[i] == "Monitor")
- {
- iFirstMonitorIndex = i;
- break;
- }
- }
- // search Up
- for (int i = iFirstMonitorIndex; i >= iDummyUpperSlot + 1; i -= 2)
- {
- if (layoutRecipe[i] == "" && layoutRecipe[i - 1] == "")
- {
- layoutRecipe[i] = "Production";
- }
- else
- {
- break;
- }
- }
- // serach Down
- for (int i = iFirstMonitorIndex; i <= iSlotCount - iDummyLowerSlot - 2; i += 2)
- {
- if (layoutRecipe[i] == "" && layoutRecipe[i + 1] == "")
- {
- layoutRecipe[i] = "Production";
- }
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex);
- return layoutRecipe;
- }
- return layoutRecipe;
- }
- private List<string> ProductAutoMonitorBetweenCassetteTriplePitch(int iSlotCount, int iCassetteSlotCount, int iDummyUpperSlot, int iDummyLowerSlot, string strMonitorBetweenCasseteNo, string strBoatRule)
- {
- var layoutRecipe = new List<string>();
- for (int i = 0; i < iSlotCount; i++)
- {
- layoutRecipe.Add(string.Empty);
- }
- try
- {
- // insert Upper Dummy
- for (int i = 0; i < iDummyUpperSlot; i++)
- {
- layoutRecipe[i] = "Dummy";
- }
- // insert Lower Dummy
- for (int i = iSlotCount - 1; i >= iSlotCount - iDummyLowerSlot; i--)
- {
- layoutRecipe[i] = "Dummy";
- }
- var monitorBetweenCassetteNo = new List<string>();
- monitorBetweenCassetteNo = GetLayoutProductionMonitorSlot(strMonitorBetweenCasseteNo);
- // insert Monitor
- int iIndex, iMonitorCount = 7;
- iIndex = iDummyUpperSlot;
- for (int i = 0; i < iMonitorCount; i += 3)
- {
- iIndex = iDummyUpperSlot + 2 + i * iCassetteSlotCount * 3 + i * 3;
- if (iIndex < iSlotCount - iDummyLowerSlot - 3)
- {
- if (monitorBetweenCassetteNo[i] == "ON")
- {
- layoutRecipe[iIndex] = "Monitor";
- }
- }
- else
- {
- if (monitorBetweenCassetteNo[i] == "ON")
- {
- iIndex = iSlotCount - iDummyLowerSlot - 3;
- layoutRecipe[iIndex] = "Monitor";
- }
- }
- }
- // insert Production
- int iFirstMonitorIndex = 0;
- for (int i = iDummyUpperSlot; i < iSlotCount; i++)
- {
- if (layoutRecipe[i] == "Monitor")
- {
- iFirstMonitorIndex = i;
- break;
- }
- }
- // search Up
- for (int i = iFirstMonitorIndex; i >= iDummyUpperSlot + 2; i -= 3)
- {
- if (layoutRecipe[i] == "" && layoutRecipe[i - 1] == "" && layoutRecipe[i - 2] == "")
- {
- layoutRecipe[i] = "Production";
- }
- else
- {
- break;
- }
- }
- // serach Down
- for (int i = iFirstMonitorIndex; i <= iSlotCount - iDummyLowerSlot - 3; i += 3)
- {
- if (layoutRecipe[i] == "" && layoutRecipe[i + 1] == "" && layoutRecipe[i + 2] == "")
- {
- layoutRecipe[i] = "Production";
- }
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex);
- return layoutRecipe;
- }
- return layoutRecipe;
- }
- private List<string> ProductAutoMonitorSlotStandardPitch(int iSlotCount, int iCassetteSlotCount, int iDummyUpperSlot, int iDummyLowerSlot, string strMonitorSlotNo, string strBoatRule)
- {
- var layoutRecipe = new List<string>();
- for (int i = 0; i < iSlotCount; i++)
- {
- layoutRecipe.Add(string.Empty);
- }
- try
- {
- // insert Upper Dummy
- for (int i = 0; i < iDummyUpperSlot; i++)
- {
- layoutRecipe[i] = "Dummy";
- }
- // insert Lower Dummy
- for (int i = iSlotCount - 1; i >= iSlotCount - iDummyLowerSlot; i--)
- {
- layoutRecipe[i] = "Dummy";
- }
- var monitorSlotList = new List<string>();
- monitorSlotList = GetLayoutProductionMonitorSlot(strMonitorSlotNo);
- var monitorSlotNo = new List<int>();
- foreach (string str in monitorSlotList)
- {
- int iPos = 0;
- int.TryParse(str, out iPos);
- iPos--;
- if (!monitorSlotNo.Contains(iPos))
- {
- monitorSlotNo.Add(iPos);
- }
- }
- monitorSlotNo.Sort();
- // insert Monitor
- List<int> monitorNo = new List<int>();
- foreach (int vm in monitorSlotNo)
- {
- if (layoutRecipe[vm] != "Dummy")
- {
- layoutRecipe[vm] = "Monitor";
- }
- }
- // insert Production
- int iFirstMonitorIndex = 0;
- for (int i = iDummyUpperSlot; i < iSlotCount; i++)
- {
- if (layoutRecipe[i] == "Monitor")
- {
- iFirstMonitorIndex = i;
- break;
- }
- }
- for (int i = iDummyUpperSlot; i < iFirstMonitorIndex; i++)
- {
- if (layoutRecipe[i] == "")
- {
- layoutRecipe[i] = "Production";
- }
- else
- {
- break;
- }
- }
- for (int i = iFirstMonitorIndex; i <= iSlotCount - iDummyLowerSlot - 1; i++)
- {
- if (layoutRecipe[i] == "")
- {
- layoutRecipe[i] = "Production";
- }
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex);
- return layoutRecipe;
- }
- return layoutRecipe;
- }
- private List<string> ProductAutoMonitorSlotDoublePitch(int iSlotCount, int iCassetteSlotCount, int iDummyUpperSlot, int iDummyLowerSlot, string strMonitorSlotNo, string strBoatRule)
- {
- var layoutRecipe = new List<string>();
- for (int i = 0; i < iSlotCount; i++)
- {
- layoutRecipe.Add(string.Empty);
- }
- try
- {
- // insert Upper Dummy
- for (int i = 0; i < iDummyUpperSlot; i++)
- {
- layoutRecipe[i] = "Dummy";
- }
- // insert Lower Dummy
- for (int i = iSlotCount - 1; i >= iSlotCount - iDummyLowerSlot; i--)
- {
- layoutRecipe[i] = "Dummy";
- }
- var monitorSlotList = new List<string>();
- monitorSlotList = GetLayoutProductionMonitorSlot(strMonitorSlotNo);
- var monitorSlotNo = new List<int>();
- foreach (string str in monitorSlotList)
- {
- int iPos = 0;
- int.TryParse(str, out iPos);
- iPos--;
- if (!monitorSlotNo.Contains(iPos))
- {
- monitorSlotNo.Add(iPos);
- }
- }
- monitorSlotNo.Sort();
- // insert Monitor
- List<int> monitorNo = new List<int>();
- foreach (int vm in monitorSlotNo)
- {
- if (layoutRecipe[vm] != "Dummy" && vm >= iDummyUpperSlot + 1 && vm <= iSlotCount - iDummyLowerSlot - 2)
- {
- layoutRecipe[vm] = "Monitor";
- }
- }
- // insert Production
- int iFirstMonitorIndex = 0;
- for (int i = iDummyUpperSlot; i < iSlotCount; i++)
- {
- if (layoutRecipe[i] == "Monitor")
- {
- iFirstMonitorIndex = i;
- break;
- }
- }
- for (int i = iDummyUpperSlot + 1; i < iFirstMonitorIndex; i += 2)
- {
- if (layoutRecipe[i] == "" && layoutRecipe[i + 1] == "")
- {
- layoutRecipe[i] = "Production";
- }
- else
- {
- break;
- }
- }
- for (int i = iFirstMonitorIndex; i <= iSlotCount - iDummyLowerSlot - 2; i += 2)
- {
- if (layoutRecipe[i] == "" && layoutRecipe[i + 1] == "")
- {
- layoutRecipe[i] = "Production";
- }
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex);
- return layoutRecipe;
- }
- return layoutRecipe;
- }
- private List<string> ProductAutoMonitorSlotTriplePitch(int iSlotCount, int iCassetteSlotCount, int iDummyUpperSlot, int iDummyLowerSlot, string strMonitorSlotNo, string strBoatRule)
- {
- var layoutRecipe = new List<string>();
- for (int i = 0; i < iSlotCount; i++)
- {
- layoutRecipe.Add(string.Empty);
- }
- try
- {
- // insert Upper Dummy
- for (int i = 0; i < iDummyUpperSlot; i++)
- {
- layoutRecipe[i] = "Dummy";
- }
- // insert Lower Dummy
- for (int i = iSlotCount - 1; i >= iSlotCount - iDummyLowerSlot; i--)
- {
- layoutRecipe[i] = "Dummy";
- }
- var monitorSlotList = new List<string>();
- monitorSlotList = GetLayoutProductionMonitorSlot(strMonitorSlotNo);
- var monitorSlotNo = new List<int>();
- foreach (string str in monitorSlotList)
- {
- int iPos = 0;
- int.TryParse(str, out iPos);
- iPos--;
- if (!monitorSlotNo.Contains(iPos))
- {
- monitorSlotNo.Add(iPos);
- }
- }
- monitorSlotNo.Sort();
- // insert Monitor
- List<int> monitorNo = new List<int>();
- foreach (int vm in monitorSlotNo)
- {
- if (layoutRecipe[vm] != "Dummy" && vm >= iDummyUpperSlot + 2 && vm <= iSlotCount - iDummyLowerSlot - 3)
- {
- layoutRecipe[vm] = "Monitor";
- }
- }
- // insert Production
- int iFirstMonitorIndex = 0;
- for (int i = iDummyUpperSlot; i < iSlotCount; i++)
- {
- if (layoutRecipe[i] == "Monitor")
- {
- iFirstMonitorIndex = i;
- break;
- }
- }
- for (int i = iDummyUpperSlot + 2; i < iFirstMonitorIndex; i += 3)
- {
- if (layoutRecipe[i] == "" && layoutRecipe[i + 1] == "" && layoutRecipe[i + 2] == "")
- {
- layoutRecipe[i] = "Production";
- }
- else
- {
- break;
- }
- }
- for (int i = iFirstMonitorIndex; i <= iSlotCount - iDummyLowerSlot - 3; i += 3)
- {
- if (layoutRecipe[i] == "" && layoutRecipe[i + 1] == "" && layoutRecipe[i + 2] == "")
- {
- layoutRecipe[i] = "Production";
- }
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex);
- return layoutRecipe;
- }
- return layoutRecipe;
- }
- private List<string> ProductSlotMonitorBetweenCassetteStandardPitch(int iSlotCount, int iCassetteSlotCount, int iDummyUpperSlot, int iDummyLowerSlot, string strProductSlotNo, string strMonitorBetweenCasseteNo, string strBoatRule)
- {
- var layoutRecipe = new List<string>();
- for (int i = 0; i < iSlotCount; i++)
- {
- layoutRecipe.Add(string.Empty);
- }
- try
- {
- // insert Upper Dummy
- for (int i = 0; i < iDummyUpperSlot; i++)
- {
- layoutRecipe[i] = "Dummy";
- }
- // insert Lower Dummy
- for (int i = iSlotCount - 1; i >= iSlotCount - iDummyLowerSlot; i--)
- {
- layoutRecipe[i] = "Dummy";
- }
- var productSlotList = new List<string>();
- productSlotList = GetLayoutProductionMonitorSlot(strProductSlotNo);
- var productSloNo = new List<int>();
- foreach (string str in productSlotList)
- {
- int iPos = 0;
- int.TryParse(str, out iPos);
- iPos--;
- if (!productSloNo.Contains(iPos))
- {
- productSloNo.Add(iPos);
- }
- }
- productSloNo.Sort();
- var monitorBetweenCassetteNo = new List<string>();
- monitorBetweenCassetteNo = GetLayoutProductionMonitorSlot(strMonitorBetweenCasseteNo);
- // insert Monitor
- int iIndex, iMonitorCount = 7;
- iIndex = iDummyUpperSlot;
- for (int i = 0; i < iMonitorCount; i++)
- {
- iIndex = iDummyUpperSlot + i * iCassetteSlotCount + i;
- if (iIndex < iSlotCount - iDummyLowerSlot - 1)
- {
- if (monitorBetweenCassetteNo[i] == "ON")
- {
- layoutRecipe[iIndex] = "Monitor";
- }
- }
- else
- {
- if (monitorBetweenCassetteNo[i] == "ON")
- {
- iIndex = iSlotCount - iDummyLowerSlot - 1;
- layoutRecipe[iIndex] = "Monitor";
- }
- }
- }
- // insert Production
- foreach (int vm in productSloNo)
- {
- if (layoutRecipe[vm] == "" && vm >= iDummyUpperSlot && vm <= iSlotCount - iDummyLowerSlot - 1)
- {
- layoutRecipe[vm] = "Production";
- }
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex);
- return layoutRecipe;
- }
- return layoutRecipe;
- }
- private List<string> ProductSlotMonitorBetweenCassetteDoublePitch(int iSlotCount, int iCassetteSlotCount, int iDummyUpperSlot, int iDummyLowerSlot, string strProductSlotNo, string strMonitorBetweenCasseteNo, string strBoatRule)
- {
- var layoutRecipe = new List<string>();
- for (int i = 0; i < iSlotCount; i++)
- {
- layoutRecipe.Add(string.Empty);
- }
- try
- {
- // insert Upper Dummy
- for (int i = 0; i < iDummyUpperSlot; i++)
- {
- layoutRecipe[i] = "Dummy";
- }
- // insert Lower Dummy
- for (int i = iSlotCount - 1; i >= iSlotCount - iDummyLowerSlot; i--)
- {
- layoutRecipe[i] = "Dummy";
- }
- var productSlotList = new List<string>();
- productSlotList = GetLayoutProductionMonitorSlot(strProductSlotNo);
- var productSloNo = new List<int>();
- foreach (string str in productSlotList)
- {
- int iPos = 0;
- int.TryParse(str, out iPos);
- iPos--;
- if (!productSloNo.Contains(iPos))
- {
- productSloNo.Add(iPos);
- }
- }
- productSloNo.Sort();
- var monitorBetweenCassetteNo = new List<string>();
- monitorBetweenCassetteNo = GetLayoutProductionMonitorSlot(strMonitorBetweenCasseteNo);
- // insert Monitor
- int iIndex, iMonitorCount = 7;
- iIndex = iDummyUpperSlot;
- for (int i = 0; i < iMonitorCount; i += 2)
- {
- iIndex = iDummyUpperSlot + 1 + i * iCassetteSlotCount * 2 + i * 2;
- if (iIndex < iSlotCount - iDummyLowerSlot - 2)
- {
- if (monitorBetweenCassetteNo[i] == "ON")
- {
- layoutRecipe[iIndex] = "Monitor";
- }
- }
- else
- {
- if (monitorBetweenCassetteNo[i] == "ON")
- {
- iIndex = iSlotCount - iDummyLowerSlot - 2;
- layoutRecipe[iIndex] = "Monitor";
- }
- }
- }
- // insert Production
- foreach (int vm in productSloNo)
- {
- if (layoutRecipe[vm] == "" && layoutRecipe[vm - 1] == "" && layoutRecipe[vm + 1] == "" && vm >= iDummyUpperSlot + 1 && vm <= iSlotCount - iDummyLowerSlot - 2)
- {
- layoutRecipe[vm] = "Production";
- }
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex);
- return layoutRecipe;
- }
- return layoutRecipe;
- }
- private List<string> ProductSlotMonitorBetweenCassetteTriplePitch(int iSlotCount, int iCassetteSlotCount, int iDummyUpperSlot, int iDummyLowerSlot, string strProductSlotNo, string strMonitorBetweenCasseteNo, string strBoatRule)
- {
- var layoutRecipe = new List<string>();
- for (int i = 0; i < iSlotCount; i++)
- {
- layoutRecipe.Add(string.Empty);
- }
- try
- {
- // insert Upper Dummy
- for (int i = 0; i < iDummyUpperSlot; i++)
- {
- layoutRecipe[i] = "Dummy";
- }
- // insert Lower Dummy
- for (int i = iSlotCount - 1; i >= iSlotCount - iDummyLowerSlot; i--)
- {
- layoutRecipe[i] = "Dummy";
- }
- var productSlotList = new List<string>();
- productSlotList = GetLayoutProductionMonitorSlot(strProductSlotNo);
- var productSloNo = new List<int>();
- foreach (string str in productSlotList)
- {
- int iPos = 0;
- int.TryParse(str, out iPos);
- iPos--;
- if (!productSloNo.Contains(iPos))
- {
- productSloNo.Add(iPos);
- }
- }
- productSloNo.Sort();
- var monitorBetweenCassetteNo = new List<string>();
- monitorBetweenCassetteNo = GetLayoutProductionMonitorSlot(strMonitorBetweenCasseteNo);
- // insert Monitor
- int iIndex, iMonitorCount = 7;
- iIndex = iDummyUpperSlot;
- for (int i = 0; i < iMonitorCount; i += 3)
- {
- iIndex = iDummyUpperSlot + 2 + i * iCassetteSlotCount * 3 + i * 3;
- if (iIndex < iSlotCount - iDummyLowerSlot - 3)
- {
- if (monitorBetweenCassetteNo[i] == "ON")
- {
- layoutRecipe[iIndex] = "Monitor";
- }
- }
- else
- {
- if (monitorBetweenCassetteNo[i] == "ON")
- {
- iIndex = iSlotCount - iDummyLowerSlot - 3;
- layoutRecipe[iIndex] = "Monitor";
- }
- }
- }
- // insert Production
- foreach (int vm in productSloNo)
- {
- if (layoutRecipe[vm] == "" && layoutRecipe[vm - 1] == "" && layoutRecipe[vm - 2] == "" &&
- layoutRecipe[vm + 1] == "" && layoutRecipe[vm + 2] == "" && vm >= iDummyUpperSlot + 2 && vm <= iSlotCount - iDummyLowerSlot - 3)
- {
- layoutRecipe[vm] = "Production";
- }
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex);
- return layoutRecipe;
- }
- return layoutRecipe;
- }
- private List<string> ProductSlotMonitorSlotStandardPitch(int iSlotCount, int iCassetteSlotCount, int iDummyUpperSlot, int iDummyLowerSlot, string strProductSlotNo, string strMonitorSlotNo, string strBoatRule)
- {
- var layoutRecipe = new List<string>();
- for (int i = 0; i < iSlotCount; i++)
- {
- layoutRecipe.Add(string.Empty);
- }
- try
- {
- // insert Upper Dummy
- for (int i = 0; i < iDummyUpperSlot; i++)
- {
- layoutRecipe[i] = "Dummy";
- }
- // insert Lower Dummy
- for (int i = iSlotCount - 1; i >= iSlotCount - iDummyLowerSlot; i--)
- {
- layoutRecipe[i] = "Dummy";
- }
- var productSlotNo = new List<string>();
- productSlotNo = GetLayoutProductionMonitorSlot(strProductSlotNo);
- var monitorSlotNo = new List<string>();
- monitorSlotNo = GetLayoutProductionMonitorSlot(strMonitorSlotNo);
- // insert Production
- foreach (string str in productSlotNo)
- {
- int iPos = 0;
- int.TryParse(str, out iPos);
- if (layoutRecipe[iPos - 1] != "Dummy")
- {
- layoutRecipe[iPos - 1] = "Production";
- }
- }
- // insert Monitor
- foreach (string str in monitorSlotNo)
- {
- int iPos = 0;
- int.TryParse(str, out iPos);
- if (layoutRecipe[iPos - 1] != "Dummy")
- {
- layoutRecipe[iPos - 1] = "Monitor";
- }
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex);
- return layoutRecipe;
- }
- return layoutRecipe;
- }
- private List<string> ProductSlotMonitorSlotDoublePitch(int iSlotCount, int iCassetteSlotCount, int iDummyUpperSlot, int iDummyLowerSlot, string strProductSlotNo, string strMonitorSlotNo, string strBoatRule)
- {
- var layoutRecipe = new List<string>();
- for (int i = 0; i < iSlotCount; i++)
- {
- layoutRecipe.Add(string.Empty);
- }
- try
- {
- // insert Upper Dummy
- for (int i = 0; i < iDummyUpperSlot; i++)
- {
- layoutRecipe[i] = "Dummy";
- }
- // insert Lower Dummy
- for (int i = iSlotCount - 1; i >= iSlotCount - iDummyLowerSlot; i--)
- {
- layoutRecipe[i] = "Dummy";
- }
- var productSlotNo = new List<string>();
- productSlotNo = GetLayoutProductionMonitorSlot(strProductSlotNo);
- var monitorSlotNo = new List<string>();
- monitorSlotNo = GetLayoutProductionMonitorSlot(strMonitorSlotNo);
- // insert Production
- foreach (string str in productSlotNo)
- {
- int iPos = 0;
- int.TryParse(str, out iPos);
- if (layoutRecipe[iPos - 2] == string.Empty && layoutRecipe[iPos - 1] != "Dummy" && layoutRecipe[iPos] == string.Empty)
- {
- layoutRecipe[iPos - 1] = "Production";
- }
- }
- // insert Monitor
- foreach (string str in monitorSlotNo)
- {
- int iPos = 0;
- int.TryParse(str, out iPos);
- if (layoutRecipe[iPos - 2] == string.Empty && layoutRecipe[iPos - 1] != "Dummy" && layoutRecipe[iPos] == string.Empty)
- {
- layoutRecipe[iPos - 1] = "Monitor";
- }
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex);
- return layoutRecipe;
- }
- return layoutRecipe;
- }
- private List<string> ProductSlotMonitorSlotTriplePitch(int iSlotCount, int iCassetteSlotCount, int iDummyUpperSlot, int iDummyLowerSlot, string strProductSlotNo, string strMonitorSlotNo, string strBoatRule)
- {
- var layoutRecipe = new List<string>();
- for (int i = 0; i < iSlotCount; i++)
- {
- layoutRecipe.Add(string.Empty);
- }
- try
- {
- // insert Upper Dummy
- for (int i = 0; i < iDummyUpperSlot; i++)
- {
- layoutRecipe[i] = "Dummy";
- }
- // insert Lower Dummy
- for (int i = iSlotCount - 1; i >= iSlotCount - iDummyLowerSlot; i--)
- {
- layoutRecipe[i] = "Dummy";
- }
- var productSlotNo = new List<string>();
- productSlotNo = GetLayoutProductionMonitorSlot(strProductSlotNo);
- var monitorSlotNo = new List<string>();
- monitorSlotNo = GetLayoutProductionMonitorSlot(strMonitorSlotNo);
- // insert Production
- foreach (string str in productSlotNo)
- {
- int iPos = 0;
- int.TryParse(str, out iPos);
- if (layoutRecipe[iPos - 3] == string.Empty && layoutRecipe[iPos - 2] == string.Empty && layoutRecipe[iPos - 1] != "Dummy" &&
- layoutRecipe[iPos] == string.Empty && layoutRecipe[iPos + 1] == string.Empty)
- {
- layoutRecipe[iPos - 1] = "Production";
- }
- }
- // insert Monitor
- foreach (string str in monitorSlotNo)
- {
- int iPos = 0;
- int.TryParse(str, out iPos);
- if (layoutRecipe[iPos - 3] == string.Empty && layoutRecipe[iPos - 2] == string.Empty && layoutRecipe[iPos - 1] != "Dummy" &&
- layoutRecipe[iPos] == string.Empty && layoutRecipe[iPos + 1] == string.Empty)
- {
- layoutRecipe[iPos - 1] = "Monitor";
- }
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex);
- return layoutRecipe;
- }
- return layoutRecipe;
- }
- private List<string> GetLayoutProductionMonitorSlot(string strParam)
- {
- var slot = new List<string>();
- if (strParam == string.Empty)
- {
- return slot;
- }
- slot = strParam.Split(',').ToList();
- return slot;
- }
- #region Sequence
- private string GetSequenceConfig(string nodePath)
- {
- if (_seqContext == null)
- return string.Empty;
- string schema = _seqContext.GetConfigXml();
- XmlDocument dom = new XmlDocument();
- dom.LoadXml(schema);
- XmlNode node = dom.SelectSingleNode(nodePath);
- return node.OuterXml;
- }
- public string GetWaferFlowRecipe(string recipeName, bool needValidation)
- {
- string seq = string.Empty;
- try
- {
- using (StreamReader fs = new StreamReader(GenerateRecipeFilePath($"{SC.GetStringValue("System.Recipe.RecipeChamberType")}\\{WaferFlowFolder}", recipeName)))
- {
- seq = fs.ReadToEnd();
- fs.Close();
- }
- if (needValidation && !_seqContext.Validation(seq))
- {
- EV.PostWarningLog(SourceModule, $"Read {recipeName} failed, validation failed");
- seq = string.Empty;
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex);
- EV.PostWarningLog(SourceModule, $"Read {recipeName} failed, " + ex.Message);
- seq = string.Empty;
- }
- return seq;
- }
- public string GetSequence(string sequenceName, bool needValidation)
- {
- string seq = string.Empty;
- try
- {
- using (StreamReader fs = new StreamReader(GenerateSequenceFilePath(SequenceFolder, sequenceName)))
- {
- seq = fs.ReadToEnd();
- fs.Close();
- }
- if (needValidation && !_seqContext.Validation(seq))
- {
- EV.PostWarningLog(SourceModule, $"Read {sequenceName} failed, validation failed");
- seq = string.Empty;
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex);
- EV.PostWarningLog(SourceModule, $"Read {sequenceName} failed, " + ex.Message);
- seq = string.Empty;
- }
- return seq;
- }
- public List<string> GetSequenceNameList()
- {
- var result = new List<string>();
- try
- {
- string recipePath = PathManager.GetRecipeDir() + SequenceFolder + "\\";
- var di = new DirectoryInfo(recipePath);
- var fis = di.GetFiles("*.seq", SearchOption.AllDirectories);
- foreach (var fi in fis)
- {
- string str = fi.FullName.Substring(recipePath.Length);
- str = str.Substring(0, str.LastIndexOf('.'));
- result.Add(str);
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex);
- EV.PostWarningLog(SourceModule, "Get sequence list failed, " + ex.Message);
- }
- return result;
- }
- public bool DeleteSequence(string sequenceName)
- {
- try
- {
- File.Delete(GenerateSequenceFilePath(SequenceFolder, sequenceName));
- EV.PostInfoLog(SourceModule, $"sequence {sequenceName} deleted");
- }
- catch (Exception ex)
- {
- LOG.Write(ex);
- EV.PostWarningLog(SourceModule, $"delete {sequenceName} failed, " + ex.Message);
- return false;
- }
- return true;
- }
- public bool SaveSequence(string sequenceName, string sequenceContent, bool notifyUI)
- {
- bool ret = true;
- try
- {
- var path = GenerateSequenceFilePath(SequenceFolder, sequenceName);
- FileInfo fi = new FileInfo(path);
- if (!fi.Directory.Exists)
- {
- fi.Directory.Create();
- }
- XmlDocument xml = new XmlDocument();
- xml.LoadXml(sequenceContent);
- XmlTextWriter writer = new XmlTextWriter(path, null);
- writer.Formatting = Formatting.Indented;
- xml.Save(writer);
- writer.Close();
- if (notifyUI)
- {
- EV.PostPopDialogMessage(EventLevel.Information, "Save Complete", $"Sequence {sequenceName} saved ");
- }
- else
- {
- EV.PostInfoLog(SourceModule, $"Sequence {sequenceName} saved ");
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex);
- EV.PostWarningLog(SourceModule, $"save sequence {sequenceName} failed, " + ex.Message);
- if (notifyUI)
- {
- EV.PostPopDialogMessage(EventLevel.Alarm, "Save Error", $"save sequence {sequenceName} failed, " + ex.Message);
- }
- ret = false;
- }
- return ret;
- }
- public bool SaveAsSequence(string sequenceName, string sequenceContent)
- {
- var path = GenerateSequenceFilePath(SequenceFolder, sequenceName);
- if (File.Exists(path))
- {
- EV.PostWarningLog(SourceModule, $"save sequence {sequenceName} failed, already exist");
- return false;
- }
- return SaveSequence(sequenceName, sequenceContent, false);
- }
- public bool RenameSequence(string oldName, string newName)
- {
- try
- {
- if (File.Exists(GenerateSequenceFilePath(SequenceFolder, newName)))
- {
- EV.PostWarningLog(SourceModule, $"{newName} already exist, rename failed");
- return false;
- }
- else
- {
- File.Move(GenerateSequenceFilePath(SequenceFolder, oldName), GenerateSequenceFilePath(SequenceFolder, newName));
- EV.PostInfoLog(SourceModule, $"sequence {oldName} renamed to {newName}");
- }
- }
- catch (Exception ex)
- {
- LOG.Write(ex);
- EV.PostWarningLog(SourceModule, $"rename {oldName} failed, " + ex.Message);
- return false;
- }
- return true;
- }
- public string GetSequenceFormatXml()
- {
- return GetSequenceConfig("/Aitex/TableSequenceFormat");
- }
- internal bool DeleteSequenceFolder(string folderName)
- {
- try
- {
- Directory.Delete(PathManager.GetRecipeDir() + SequenceFolder + "\\" + folderName, true);
- EV.PostInfoLog(SourceModule, "Folder " + folderName + "deleted");
- }
- catch (Exception ex)
- {
- LOG.Write(ex, "delete sequence folder exception");
- EV.PostWarningLog(SourceModule, $"can not delete folder {folderName}, {ex.Message}");
- return false;
- }
- return true;
- }
- internal bool CreateSequenceFolder(string folderName)
- {
- try
- {
- Directory.CreateDirectory(PathManager.GetRecipeDir() + SequenceFolder + "\\" + folderName);
- EV.PostInfoLog(SourceModule, "Folder " + folderName + "created");
- }
- catch (Exception ex)
- {
- LOG.Write(ex, "sequence folder create exception");
- EV.PostWarningLog(SourceModule, $"can not create folder {folderName}, {ex.Message}");
- return false;
- }
- return true;
- }
- internal bool RenameSequenceFolder(string oldName, string newName)
- {
- try
- {
- string oldPath = PathManager.GetRecipeDir() + SequenceFolder + "\\" + oldName;
- string newPath = PathManager.GetRecipeDir() + SequenceFolder + "\\" + newName;
- Directory.Move(oldPath, newPath);
- EV.PostInfoLog(SourceModule, $"rename folder from {oldName} to {newName}");
- }
- catch (Exception ex)
- {
- LOG.Write(ex, "rename sequence folder failed");
- EV.PostWarningLog(SourceModule, $"can not rename folder {oldName}, {ex.Message}");
- return false;
- }
- return true;
- }
- public string GetXmlSequenceList(string chamberId)
- {
- XmlDocument doc = new XmlDocument();
- DirectoryInfo curFolderInfo = new DirectoryInfo(PathManager.GetRecipeDir() + SequenceFolder + "\\");
- doc.AppendChild(GenerateSequenceList(chamberId, curFolderInfo, doc));
- return doc.OuterXml;
- }
- XmlElement GenerateSequenceList(string chamberId, DirectoryInfo currentDir, XmlDocument doc)
- {
- int trimLength = (PathManager.GetRecipeDir() + SequenceFolder + "\\").Length;
- XmlElement folderEle = doc.CreateElement("Folder");
- folderEle.SetAttribute("Name", currentDir.FullName.Substring(trimLength));
- DirectoryInfo[] dirInfos = currentDir.GetDirectories();
- foreach (DirectoryInfo dirInfo in dirInfos)
- {
- folderEle.AppendChild(GenerateSequenceList(chamberId, dirInfo, doc));
- }
- FileInfo[] fileInfos = currentDir.GetFiles("*.seq");
- foreach (FileInfo fileInfo in fileInfos)
- {
- XmlElement fileNd = doc.CreateElement("File");
- string fileStr = fileInfo.FullName.Substring(trimLength).TrimStart(new char[] { '\\' }); ;
- fileStr = fileStr.Substring(0, fileStr.LastIndexOf("."));
- fileNd.SetAttribute("Name", fileStr);
- folderEle.AppendChild(fileNd);
- }
- return folderEle;
- }
- #endregion
- }
- }
|