Compare commits
	
		
			3 Commits
		
	
	
		
			b0b5033314
			...
			09-24-a
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 365fedce89 | |||
| 9d0d24fb83 | |||
| f15c525ab5 | 
| @ -109,7 +109,7 @@ dotnet_diagnostic.CA2254.severity = none # CA2254: The logging message template | |||||||
| dotnet_diagnostic.IDE0001.severity = warning # IDE0001: Simplify name | dotnet_diagnostic.IDE0001.severity = warning # IDE0001: Simplify name | ||||||
| dotnet_diagnostic.IDE0002.severity = warning # Simplify (member access) - System.Version.Equals("1", "2"); Version.Equals("1", "2"); | dotnet_diagnostic.IDE0002.severity = warning # Simplify (member access) - System.Version.Equals("1", "2"); Version.Equals("1", "2"); | ||||||
| dotnet_diagnostic.IDE0004.severity = warning # IDE0004: Cast is redundant. | dotnet_diagnostic.IDE0004.severity = warning # IDE0004: Cast is redundant. | ||||||
| dotnet_diagnostic.IDE0005.severity = warning # Using directive is unnecessary | dotnet_diagnostic.IDE0005.severity = none # Using directive is unnecessary | ||||||
| dotnet_diagnostic.IDE0028.severity = none # IDE0028: Collection initialization can be simplified | dotnet_diagnostic.IDE0028.severity = none # IDE0028: Collection initialization can be simplified | ||||||
| dotnet_diagnostic.IDE0031.severity = warning # Use null propagation (IDE0031) | dotnet_diagnostic.IDE0031.severity = warning # Use null propagation (IDE0031) | ||||||
| dotnet_diagnostic.IDE0047.severity = warning # IDE0047: Parentheses can be removed | dotnet_diagnostic.IDE0047.severity = warning # IDE0047: Parentheses can be removed | ||||||
| @ -121,6 +121,7 @@ dotnet_diagnostic.IDE0290.severity = none # Use primary constructor [Distance]cs | |||||||
| dotnet_diagnostic.IDE0300.severity = none # IDE0300: Collection initialization can be simplified | dotnet_diagnostic.IDE0300.severity = none # IDE0300: Collection initialization can be simplified | ||||||
| dotnet_diagnostic.IDE0301.severity = none #IDE0301: Collection initialization can be simplified | dotnet_diagnostic.IDE0301.severity = none #IDE0301: Collection initialization can be simplified | ||||||
| dotnet_diagnostic.IDE0305.severity = none # IDE0305: Collection initialization can be simplified | dotnet_diagnostic.IDE0305.severity = none # IDE0305: Collection initialization can be simplified | ||||||
|  | dotnet_diagnostic.MSTEST0015.severity = none # MSTEST0015: Test method {method} should not be ignored | ||||||
| dotnet_diagnostic.MSTEST0037.severity = error # MSTEST0037: Use proper 'Assert' methods | dotnet_diagnostic.MSTEST0037.severity = error # MSTEST0037: Use proper 'Assert' methods | ||||||
| dotnet_diagnostic.SYSLIB1045.severity = none # SYSLIB1045: diagnostics for regex source generation | dotnet_diagnostic.SYSLIB1045.severity = none # SYSLIB1045: diagnostics for regex source generation | ||||||
| dotnet_naming_rule.abstract_method_should_be_pascal_case.severity = warning | dotnet_naming_rule.abstract_method_should_be_pascal_case.severity = warning | ||||||
|  | |||||||
							
								
								
									
										39
									
								
								Adaptation/.vscode/launch.json
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										39
									
								
								Adaptation/.vscode/launch.json
									
									
									
									
										vendored
									
									
								
							| @ -1,10 +1,43 @@ | |||||||
| { | { | ||||||
|   "configurations": [ |   "configurations": [ | ||||||
|  |     { | ||||||
|  |       "mode": "debug", | ||||||
|  |       "name": "Go launch file", | ||||||
|  |       "program": "${file}", | ||||||
|  |       "request": "launch", | ||||||
|  |       "type": "go" | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "name": "node Launch Current Opened File", | ||||||
|  |       "program": "${file}", | ||||||
|  |       "request": "launch", | ||||||
|  |       "type": "node" | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "cwd": "${workspaceFolder}", | ||||||
|  |       "internalConsoleOptions": "neverOpen", | ||||||
|  |       "name": "Debug File", | ||||||
|  |       "program": "${file}", | ||||||
|  |       "request": "launch", | ||||||
|  |       "stopOnEntry": false, | ||||||
|  |       "type": "bun", | ||||||
|  |       "watchMode": false | ||||||
|  |     }, | ||||||
|  |     { | ||||||
|  |       "cwd": "${workspaceFolder}", | ||||||
|  |       "internalConsoleOptions": "neverOpen", | ||||||
|  |       "name": "Run File", | ||||||
|  |       "noDebug": true, | ||||||
|  |       "program": "${file}", | ||||||
|  |       "request": "launch", | ||||||
|  |       "type": "bun", | ||||||
|  |       "watchMode": false | ||||||
|  |     }, | ||||||
|     { |     { | ||||||
|       "name": ".NET Core Attach", |       "name": ".NET Core Attach", | ||||||
|       "type": "coreclr", |       "processId": 32760, | ||||||
|       "request": "attach", |       "request": "attach", | ||||||
|       "processId": 32760 |       "type": "coreclr" | ||||||
|     } |     } | ||||||
|   ] |   ] | ||||||
| } | } | ||||||
							
								
								
									
										133
									
								
								Adaptation/.vscode/tasks.json
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										133
									
								
								Adaptation/.vscode/tasks.json
									
									
									
									
										vendored
									
									
								
							| @ -1,19 +1,134 @@ | |||||||
| { | { | ||||||
|     "version": "2.0.0", |     "version": "2.0.0", | ||||||
|  |     "inputs": [ | ||||||
|  |         { | ||||||
|  |             "default": "Development", | ||||||
|  |             "description": "Which ASP Net Core Environment?", | ||||||
|  |             "id": "ASPNETCORE_ENVIRONMENT", | ||||||
|  |             "options": [ | ||||||
|  |                 "Development", | ||||||
|  |                 "Production" | ||||||
|  |             ], | ||||||
|  |             "type": "pickString" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "default": "{AssemblyTitle}", | ||||||
|  |             "description": "What Assembly Title?", | ||||||
|  |             "id": "AssemblyTitle", | ||||||
|  |             "type": "promptString" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "default": "{Build.BuildId}", | ||||||
|  |             "description": "Which Build BuildId?", | ||||||
|  |             "id": "Build.BuildId", | ||||||
|  |             "type": "promptString" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "default": "{Build.Reason}", | ||||||
|  |             "description": "Which Build Reason?", | ||||||
|  |             "id": "Build.Reason", | ||||||
|  |             "type": "promptString" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "default": "{Build.Repository.Id}", | ||||||
|  |             "description": "Which Build Repository Id?", | ||||||
|  |             "id": "Build.Repository.Id", | ||||||
|  |             "type": "promptString" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "default": "{Build.Repository.Name}", | ||||||
|  |             "description": "Which Build Repository Name?", | ||||||
|  |             "id": "Build.Repository.Name", | ||||||
|  |             "type": "promptString" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "default": "{Build.SourceVersion}", | ||||||
|  |             "description": "Which Build Source Version?", | ||||||
|  |             "id": "Build.SourceVersion", | ||||||
|  |             "type": "promptString" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "default": "Debug", | ||||||
|  |             "description": "Which Configuration?", | ||||||
|  |             "id": "Configuration", | ||||||
|  |             "options": [ | ||||||
|  |                 "Debug", | ||||||
|  |                 "Release" | ||||||
|  |             ], | ||||||
|  |             "type": "pickString" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "default": "net8.0", | ||||||
|  |             "description": "Which Core Version?", | ||||||
|  |             "id": "CoreVersion", | ||||||
|  |             "options": [ | ||||||
|  |                 "net8.0" | ||||||
|  |             ], | ||||||
|  |             "type": "pickString" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "default": "C:/Program Files (x86)/Microsoft Visual Studio/2022/BuildTools/MSBuild/Current/Bin/MSBuild.exe", | ||||||
|  |             "description": "Which MS Build?", | ||||||
|  |             "id": "MSBuild", | ||||||
|  |             "type": "promptString" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "default": "https://artifactory.intra.infineon.com/artifactory/api/nuget/ngt-fi-package-main-vir/", | ||||||
|  |             "description": "Which Nuget Source?", | ||||||
|  |             "id": "NugetSource", | ||||||
|  |             "type": "promptString" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "default": "win-x64", | ||||||
|  |             "description": "Which Runtime?", | ||||||
|  |             "id": "Runtime", | ||||||
|  |             "options": [ | ||||||
|  |                 "win-x64", | ||||||
|  |                 "win-x32", | ||||||
|  |                 "linux-x64", | ||||||
|  |                 "linux-x32" | ||||||
|  |             ], | ||||||
|  |             "type": "pickString" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "default": "L:/", | ||||||
|  |             "description": "Which System DefaultWorkingDirectory?", | ||||||
|  |             "id": "System.DefaultWorkingDirectory", | ||||||
|  |             "options": [ | ||||||
|  |                 "L:/", | ||||||
|  |                 "D:/", | ||||||
|  |                 "C:/" | ||||||
|  |             ], | ||||||
|  |             "type": "pickString" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "default": "v4.8", | ||||||
|  |             "description": "Which Core Target Framework Version?", | ||||||
|  |             "id": "TargetFrameworkVersion", | ||||||
|  |             "options": [ | ||||||
|  |                 "v4.8" | ||||||
|  |             ], | ||||||
|  |             "type": "pickString" | ||||||
|  |         }, | ||||||
|  |         { | ||||||
|  |             "default": "{UserSecretsId}", | ||||||
|  |             "description": "Which Core User Secrets Id?", | ||||||
|  |             "id": "UserSecretsId", | ||||||
|  |             "type": "promptString" | ||||||
|  |         } | ||||||
|  |     ], | ||||||
|     "tasks": [ |     "tasks": [ | ||||||
|         { |         { | ||||||
|             "label": "Build", |             "label": "Build", | ||||||
|             "command": "dotnet", |             "command": "dotnet", | ||||||
|             "type": "process", |             "type": "process", | ||||||
|             "args": [ |             "args": [ | ||||||
|                 "build", |                 "build" | ||||||
|                 "/property:GenerateFullPaths=true", |  | ||||||
|                 "/consoleloggerparameters:NoSummary" |  | ||||||
|             ], |             ], | ||||||
|             "problemMatcher": "$msCompile" |             "problemMatcher": "$msCompile" | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|             "label": "Test-Debug", |             "label": "Test Debug", | ||||||
|             "command": "dotnet", |             "command": "dotnet", | ||||||
|             "type": "process", |             "type": "process", | ||||||
|             "args": [ |             "args": [ | ||||||
| @ -24,7 +139,7 @@ | |||||||
|             "problemMatcher": "$msCompile" |             "problemMatcher": "$msCompile" | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|             "label": "Test-Release", |             "label": "Test Release", | ||||||
|             "command": "dotnet", |             "command": "dotnet", | ||||||
|             "type": "process", |             "type": "process", | ||||||
|             "args": [ |             "args": [ | ||||||
| @ -50,7 +165,7 @@ | |||||||
|             "problemMatcher": "$msCompile" |             "problemMatcher": "$msCompile" | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|             "label": "Format-Whitespaces", |             "label": "Format Whitespaces", | ||||||
|             "command": "dotnet", |             "command": "dotnet", | ||||||
|             "type": "process", |             "type": "process", | ||||||
|             "args": [ |             "args": [ | ||||||
| @ -87,13 +202,13 @@ | |||||||
|             "problemMatcher": "$msCompile" |             "problemMatcher": "$msCompile" | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|             "label": "Project", |             "label": "Code Project", | ||||||
|             "type": "shell", |             "type": "shell", | ||||||
|             "command": "code ../DEP08CEPIEPSILON.csproj", |             "command": "code ../DEP08CEPIEPSILON.csproj", | ||||||
|             "problemMatcher": [] |             "problemMatcher": [] | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|             "label": "Readme", |             "label": "Code Read Me", | ||||||
|             "type": "shell", |             "type": "shell", | ||||||
|             "command": "code ../README.md", |             "command": "code ../README.md", | ||||||
|             "problemMatcher": [] |             "problemMatcher": [] | ||||||
| @ -113,7 +228,7 @@ | |||||||
|             "problemMatcher": [] |             "problemMatcher": [] | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|             "label": "Git Config", |             "label": "Code Git Config", | ||||||
|             "type": "shell", |             "type": "shell", | ||||||
|             "command": "code ../.git/config", |             "command": "code ../.git/config", | ||||||
|             "problemMatcher": [] |             "problemMatcher": [] | ||||||
|  | |||||||
							
								
								
									
										133
									
								
								Adaptation/FileHandlers/Aggregation/FileRead.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										133
									
								
								Adaptation/FileHandlers/Aggregation/FileRead.cs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,133 @@ | |||||||
|  | using Adaptation.Eaf.Management.ConfigurationData.CellAutomation; | ||||||
|  | using Adaptation.Ifx.Eaf.EquipmentConnector.File.Configuration; | ||||||
|  | using Adaptation.Shared; | ||||||
|  | using Adaptation.Shared.Duplicator; | ||||||
|  | using Adaptation.Shared.Methods; | ||||||
|  | using System; | ||||||
|  | using System.Collections.Generic; | ||||||
|  | using System.Collections.ObjectModel; | ||||||
|  | using System.IO; | ||||||
|  | using System.Linq; | ||||||
|  | using System.Text.Json; | ||||||
|  |  | ||||||
|  | namespace Adaptation.FileHandlers.Aggregation; | ||||||
|  |  | ||||||
|  | public class FileRead : Shared.FileRead, IFileRead | ||||||
|  | { | ||||||
|  |  | ||||||
|  |     private readonly ReadOnlyDictionary<string, string> _SystemStateToNames; | ||||||
|  |  | ||||||
|  |     public FileRead(ISMTP smtp, Dictionary<string, string> fileParameter, string cellInstanceName, int? connectionCount, string cellInstanceConnectionName, FileConnectorConfiguration fileConnectorConfiguration, string equipmentTypeName, string parameterizedModelObjectDefinitionType, IList<ModelObjectParameterDefinition> modelObjectParameters, string equipmentDictionaryName, Dictionary<string, List<long>> dummyRuns, Dictionary<long, List<Shared.Metrology.WS.Results>> staticRuns, bool useCyclicalForDescription, bool isEAFHosted) : | ||||||
|  |         base(new Description(), false, smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null) | ||||||
|  |     { | ||||||
|  |         _MinFileLength = 10; | ||||||
|  |         _NullData = string.Empty; | ||||||
|  |         _Logistics = new(this); | ||||||
|  |         if (_FileParameter is null) | ||||||
|  |             throw new Exception(cellInstanceConnectionName); | ||||||
|  |         if (_ModelObjectParameterDefinitions is null) | ||||||
|  |             throw new Exception(cellInstanceConnectionName); | ||||||
|  |         if (!_IsDuplicator) | ||||||
|  |             throw new Exception(cellInstanceConnectionName); | ||||||
|  |         string[] segments; | ||||||
|  |         Dictionary<string, string> systemStateToNames = new(); | ||||||
|  |         ModelObjectParameterDefinition[] systemStates = GetProperties(cellInstanceConnectionName, modelObjectParameters, "ProcessDataStandardFormat.SystemState"); | ||||||
|  |         foreach (ModelObjectParameterDefinition modelObjectParameterDefinition in systemStates) | ||||||
|  |         { | ||||||
|  |             segments = modelObjectParameterDefinition.Value.Split('|'); | ||||||
|  |             if (segments.Length != 2) | ||||||
|  |                 continue; | ||||||
|  |             systemStateToNames.Add(segments[0], segments[1]); | ||||||
|  |         } | ||||||
|  |         _SystemStateToNames = new(systemStateToNames); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     void IFileRead.Move(Tuple<string, Test[], JsonElement[], List<FileInfo>> extractResults, Exception exception) | ||||||
|  |     { | ||||||
|  |         bool isErrorFile = exception is not null; | ||||||
|  |         if (!isErrorFile && !string.IsNullOrEmpty(_Logistics.ReportFullPath)) | ||||||
|  |         { | ||||||
|  |             FileInfo fileInfo = new(_Logistics.ReportFullPath); | ||||||
|  |             if (fileInfo.Exists && fileInfo.LastWriteTime < fileInfo.CreationTime) | ||||||
|  |                 File.SetLastWriteTime(_Logistics.ReportFullPath, fileInfo.CreationTime); | ||||||
|  |         } | ||||||
|  |         Move(extractResults); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     void IFileRead.WaitForThread() => WaitForThread(thread: null, threadExceptions: null); | ||||||
|  |  | ||||||
|  |     string IFileRead.GetEventDescription() | ||||||
|  |     { | ||||||
|  |         string result = _Description.GetEventDescription(); | ||||||
|  |         return result; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     List<string> IFileRead.GetHeaderNames() | ||||||
|  |     { | ||||||
|  |         List<string> results = _Description.GetHeaderNames(); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     string[] IFileRead.Move(Tuple<string, Test[], JsonElement[], List<FileInfo>> extractResults, string to, string from, string resolvedFileLocation, Exception exception) | ||||||
|  |     { | ||||||
|  |         string[] results = Move(extractResults, to, from, resolvedFileLocation, exception); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     JsonProperty[] IFileRead.GetDefault() | ||||||
|  |     { | ||||||
|  |         JsonProperty[] results = _Description.GetDefault(this, _Logistics); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     Dictionary<string, string> IFileRead.GetDisplayNamesJsonElement() | ||||||
|  |     { | ||||||
|  |         Dictionary<string, string> results = _Description.GetDisplayNamesJsonElement(this); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     List<IDescription> IFileRead.GetDescriptions(IFileRead fileRead, List<Test> tests, IProcessData processData) | ||||||
|  |     { | ||||||
|  |         List<IDescription> results = _Description.GetDescriptions(fileRead, _Logistics, tests, processData); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     Tuple<string, Test[], JsonElement[], List<FileInfo>> IFileRead.GetExtractResult(string reportFullPath, string eventName) | ||||||
|  |     { | ||||||
|  |         Tuple<string, Test[], JsonElement[], List<FileInfo>> results; | ||||||
|  |         if (string.IsNullOrEmpty(eventName)) | ||||||
|  |             throw new Exception(); | ||||||
|  |         _ReportFullPath = reportFullPath; | ||||||
|  |         DateTime dateTime = DateTime.Now; | ||||||
|  |         results = GetExtractResult(reportFullPath, dateTime); | ||||||
|  |         if (results.Item3 is null) | ||||||
|  |             results = new Tuple<string, Test[], JsonElement[], List<FileInfo>>(results.Item1, Array.Empty<Test>(), JsonSerializer.Deserialize<JsonElement[]>("[]"), results.Item4); | ||||||
|  |         if (results.Item3.Length > 0 && _IsEAFHosted) | ||||||
|  |             WritePDSF(this, results.Item3); | ||||||
|  |         UpdateLastTicksDuration(DateTime.Now.Ticks - dateTime.Ticks); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     Tuple<string, Test[], JsonElement[], List<FileInfo>> IFileRead.ReExtract() | ||||||
|  |     { | ||||||
|  |         Tuple<string, Test[], JsonElement[], List<FileInfo>> results; | ||||||
|  |         List<string> headerNames = _Description.GetHeaderNames(); | ||||||
|  |         Dictionary<string, string> keyValuePairs = _Description.GetDisplayNamesJsonElement(this); | ||||||
|  |         results = ReExtract(this, headerNames, keyValuePairs); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private Tuple<string, Test[], JsonElement[], List<FileInfo>> GetExtractResult(string reportFullPath, DateTime _) | ||||||
|  |     { | ||||||
|  |         Tuple<string, Test[], JsonElement[], List<FileInfo>> results; | ||||||
|  |         ProcessDataStandardFormat processDataStandardFormat = ProcessDataStandardFormat.GetProcessDataStandardFormat(reportFullPath); | ||||||
|  |         _Logistics = new Logistics(reportFullPath, processDataStandardFormat); | ||||||
|  |         SetFileParameterLotIDToLogisticsMID(); | ||||||
|  |         JsonElement[] jsonElements = ProcessDataStandardFormat.GetArray(processDataStandardFormat); | ||||||
|  |         List<Shared.Properties.IDescription> descriptions = GetDuplicatorDescriptions(jsonElements); | ||||||
|  |         Test[] tests = (from l in descriptions select (Test)l.Test).ToArray(); | ||||||
|  |         results = new Tuple<string, Test[], JsonElement[], List<FileInfo>>(string.Join(Environment.NewLine, processDataStandardFormat.Logistics), tests, jsonElements, new List<FileInfo>()); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -13,17 +13,16 @@ public class CellInstanceConnectionName | |||||||
|     { |     { | ||||||
|         IFileRead result = cellInstanceConnectionName switch |         IFileRead result = cellInstanceConnectionName switch | ||||||
|         { |         { | ||||||
|             nameof(R29) => new R29.FileRead(smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null), |             nameof(Aggregation) => new Aggregation.FileRead(smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null), | ||||||
|             nameof(R32) => new R32.FileRead(smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null), |  | ||||||
|             nameof(R36) => new R36.FileRead(smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null), |  | ||||||
|             nameof(R55) => new R55.FileRead(smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null), |  | ||||||
|             nameof(R57) => new R57.FileRead(smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null), |  | ||||||
|             nameof(R61) => new R61.FileRead(smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null), |  | ||||||
|             nameof(R62) => new R62.FileRead(smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null), |  | ||||||
|             nameof(R65) => new R65.FileRead(smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null), |  | ||||||
|             nameof(R75) => new R75.FileRead(smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null), |  | ||||||
|             nameof(R77) => new R77.FileRead(smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null), |  | ||||||
|             nameof(Dummy) => new Dummy.FileRead(smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null), |             nameof(Dummy) => new Dummy.FileRead(smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null), | ||||||
|  |             nameof(InfinityQS) => new InfinityQS.FileRead(smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null), | ||||||
|  |             nameof(Log) => new Log.FileRead(smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null), | ||||||
|  |             nameof(R2) => new R2.FileRead(smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null), | ||||||
|  |             nameof(R3) => new R3.FileRead(smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null), | ||||||
|  |             nameof(R4) => new R4.FileRead(smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null), | ||||||
|  |             nameof(R5) => new R5.FileRead(smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null), | ||||||
|  |             nameof(R6) => new R6.FileRead(smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null), | ||||||
|  |             nameof(R7) => new R7.FileRead(smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null), | ||||||
|             _ => throw new Exception($"\"{cellInstanceConnectionName}\" not mapped") |             _ => throw new Exception($"\"{cellInstanceConnectionName}\" not mapped") | ||||||
|         }; |         }; | ||||||
|         return result; |         return result; | ||||||
|  | |||||||
							
								
								
									
										159
									
								
								Adaptation/FileHandlers/InfinityQS/FileRead.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										159
									
								
								Adaptation/FileHandlers/InfinityQS/FileRead.cs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,159 @@ | |||||||
|  | using Adaptation.Eaf.Management.ConfigurationData.CellAutomation; | ||||||
|  | using Adaptation.Ifx.Eaf.EquipmentConnector.File.Configuration; | ||||||
|  | using Adaptation.Shared; | ||||||
|  | using Adaptation.Shared.Duplicator; | ||||||
|  | using Adaptation.Shared.Methods; | ||||||
|  | using System; | ||||||
|  | using System.Collections.Generic; | ||||||
|  | using System.Globalization; | ||||||
|  | using System.IO; | ||||||
|  | using System.Linq; | ||||||
|  | using System.Text.Json; | ||||||
|  |  | ||||||
|  | namespace Adaptation.FileHandlers.InfinityQS; | ||||||
|  |  | ||||||
|  | public class FileRead : Shared.FileRead, IFileRead | ||||||
|  | { | ||||||
|  |  | ||||||
|  |     private readonly int _IQSVP12Count; | ||||||
|  |  | ||||||
|  |     public FileRead(ISMTP smtp, Dictionary<string, string> fileParameter, string cellInstanceName, int? connectionCount, string cellInstanceConnectionName, FileConnectorConfiguration fileConnectorConfiguration, string equipmentTypeName, string parameterizedModelObjectDefinitionType, IList<ModelObjectParameterDefinition> modelObjectParameters, string equipmentDictionaryName, Dictionary<string, List<long>> dummyRuns, Dictionary<long, List<Shared.Metrology.WS.Results>> staticRuns, bool useCyclicalForDescription, bool isEAFHosted) : | ||||||
|  |         base(new Description(), false, smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null) | ||||||
|  |     { | ||||||
|  |         _MinFileLength = 10; | ||||||
|  |         _NullData = string.Empty; | ||||||
|  |         _Logistics = new(this); | ||||||
|  |         if (_FileParameter is null) | ||||||
|  |             throw new Exception(cellInstanceConnectionName); | ||||||
|  |         if (_ModelObjectParameterDefinitions is null) | ||||||
|  |             throw new Exception(cellInstanceConnectionName); | ||||||
|  |         if (!_IsDuplicator) | ||||||
|  |             throw new Exception(cellInstanceConnectionName); | ||||||
|  |         _IQSVP12Count = int.Parse(GetPropertyValue(cellInstanceConnectionName, modelObjectParameters, "IQS.VP12.Count")); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     void IFileRead.Move(Tuple<string, Test[], JsonElement[], List<FileInfo>> extractResults, Exception exception) | ||||||
|  |     { | ||||||
|  |         bool isErrorFile = exception is not null; | ||||||
|  |         if (!isErrorFile && !string.IsNullOrEmpty(_Logistics.ReportFullPath)) | ||||||
|  |         { | ||||||
|  |             FileInfo fileInfo = new(_Logistics.ReportFullPath); | ||||||
|  |             if (fileInfo.Exists && fileInfo.LastWriteTime < fileInfo.CreationTime) | ||||||
|  |                 File.SetLastWriteTime(_Logistics.ReportFullPath, fileInfo.CreationTime); | ||||||
|  |         } | ||||||
|  |         Move(extractResults); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     void IFileRead.WaitForThread() => WaitForThread(thread: null, threadExceptions: null); | ||||||
|  |  | ||||||
|  |     string IFileRead.GetEventDescription() | ||||||
|  |     { | ||||||
|  |         string result = _Description.GetEventDescription(); | ||||||
|  |         return result; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     List<string> IFileRead.GetHeaderNames() | ||||||
|  |     { | ||||||
|  |         List<string> results = _Description.GetHeaderNames(); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     string[] IFileRead.Move(Tuple<string, Test[], JsonElement[], List<FileInfo>> extractResults, string to, string from, string resolvedFileLocation, Exception exception) | ||||||
|  |     { | ||||||
|  |         string[] results = Move(extractResults, to, from, resolvedFileLocation, exception); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     JsonProperty[] IFileRead.GetDefault() | ||||||
|  |     { | ||||||
|  |         JsonProperty[] results = _Description.GetDefault(this, _Logistics); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     Dictionary<string, string> IFileRead.GetDisplayNamesJsonElement() | ||||||
|  |     { | ||||||
|  |         Dictionary<string, string> results = _Description.GetDisplayNamesJsonElement(this); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     List<IDescription> IFileRead.GetDescriptions(IFileRead fileRead, List<Test> tests, IProcessData processData) | ||||||
|  |     { | ||||||
|  |         List<IDescription> results = _Description.GetDescriptions(fileRead, _Logistics, tests, processData); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     Tuple<string, Test[], JsonElement[], List<FileInfo>> IFileRead.GetExtractResult(string reportFullPath, string eventName) | ||||||
|  |     { | ||||||
|  |         Tuple<string, Test[], JsonElement[], List<FileInfo>> results; | ||||||
|  |         if (string.IsNullOrEmpty(eventName)) | ||||||
|  |             throw new Exception(); | ||||||
|  |         _ReportFullPath = reportFullPath; | ||||||
|  |         DateTime dateTime = DateTime.Now; | ||||||
|  |         results = GetExtractResult(reportFullPath, dateTime); | ||||||
|  |         if (results.Item3 is null) | ||||||
|  |             results = new Tuple<string, Test[], JsonElement[], List<FileInfo>>(results.Item1, Array.Empty<Test>(), JsonSerializer.Deserialize<JsonElement[]>("[]"), results.Item4); | ||||||
|  |         if (results.Item3.Length > 0 && _IsEAFHosted) | ||||||
|  |             WritePDSF(this, results.Item3); | ||||||
|  |         UpdateLastTicksDuration(DateTime.Now.Ticks - dateTime.Ticks); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     Tuple<string, Test[], JsonElement[], List<FileInfo>> IFileRead.ReExtract() | ||||||
|  |     { | ||||||
|  |         Tuple<string, Test[], JsonElement[], List<FileInfo>> results; | ||||||
|  |         List<string> headerNames = _Description.GetHeaderNames(); | ||||||
|  |         Dictionary<string, string> keyValuePairs = _Description.GetDisplayNamesJsonElement(this); | ||||||
|  |         results = ReExtract(this, headerNames, keyValuePairs); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private void CopyAndWriteFile(string reportFullPath, ProcessDataStandardFormat processDataStandardFormat, JsonElement[] jsonElements) | ||||||
|  |     { | ||||||
|  |         string day = $"{_Logistics.DateTimeFromSequence:yyyy-MM-dd}"; | ||||||
|  |         string segment = _Logistics.FileInfo.Name.Split('-')[0].Split('_')[0]; | ||||||
|  |         string weekOfYear = _Calendar.GetWeekOfYear(_Logistics.DateTimeFromSequence, CalendarWeekRule.FirstDay, DayOfWeek.Sunday).ToString("00"); | ||||||
|  |         string weekDirectory = $"{_Logistics.DateTimeFromSequence:yyyy}_Week_{weekOfYear}"; | ||||||
|  |         string destinationDirectory = Path.Combine(_FileConnectorConfiguration.TargetFileLocation, weekDirectory, day, segment); | ||||||
|  |         if (!Directory.Exists(destinationDirectory)) | ||||||
|  |             _ = Directory.CreateDirectory(destinationDirectory); | ||||||
|  |         string checkFile = Path.Combine(destinationDirectory, _Logistics.FileInfo.Name); | ||||||
|  |         if (File.Exists(checkFile)) | ||||||
|  |             File.Delete(checkFile); | ||||||
|  |         File.Copy(_Logistics.FileInfo.FullName, checkFile); | ||||||
|  |         if (jsonElements.Length != 1 || jsonElements[0].ValueKind != JsonValueKind.Object) | ||||||
|  |             File.Delete(_Logistics.FileInfo.FullName); | ||||||
|  |         else | ||||||
|  |         { | ||||||
|  |             try | ||||||
|  |             { | ||||||
|  |                 Six six = JsonSerializer.Deserialize(jsonElements[0].GetRawText(), SixSourceGenerationContext.Default.Six) ?? throw new Exception($"{nameof(Six)} deserialization failed"); | ||||||
|  |                 File.Delete(_Logistics.FileInfo.FullName); | ||||||
|  |                 if (six.VP12Count > _IQSVP12Count) | ||||||
|  |                 { | ||||||
|  |                     string duplicateDirectory = Path.Combine(_FileConnectorConfiguration.SourceFileLocation, _CellInstanceName); | ||||||
|  |                     if (!Directory.Exists(duplicateDirectory)) | ||||||
|  |                         _ = Directory.CreateDirectory(duplicateDirectory); | ||||||
|  |                     string duplicateFile = Path.Combine(duplicateDirectory, $"{Path.GetFileName(reportFullPath)}.xml"); | ||||||
|  |                     string xml = ProcessDataStandardFormat.GetXml(processDataStandardFormat); | ||||||
|  |                     File.WriteAllText(duplicateFile, xml); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             catch (Exception) { File.Delete(_Logistics.FileInfo.FullName); } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private Tuple<string, Test[], JsonElement[], List<FileInfo>> GetExtractResult(string reportFullPath, DateTime _) | ||||||
|  |     { | ||||||
|  |         Tuple<string, Test[], JsonElement[], List<FileInfo>> results; | ||||||
|  |         ProcessDataStandardFormat processDataStandardFormat = ProcessDataStandardFormat.GetProcessDataStandardFormat(reportFullPath); | ||||||
|  |         _Logistics = new Logistics(reportFullPath, processDataStandardFormat); | ||||||
|  |         SetFileParameterLotIDToLogisticsMID(); | ||||||
|  |         JsonElement[] jsonElements = ProcessDataStandardFormat.GetArray(processDataStandardFormat); | ||||||
|  |         List<Shared.Properties.IDescription> descriptions = GetDuplicatorDescriptions(jsonElements); | ||||||
|  |         Test[] tests = (from l in descriptions select (Test)l.Test).ToArray(); | ||||||
|  |         if (_IsEAFHosted && _FileConnectorConfiguration.FileScanningIntervalInSeconds > 0) | ||||||
|  |             CopyAndWriteFile(reportFullPath, processDataStandardFormat, jsonElements); | ||||||
|  |         results = new Tuple<string, Test[], JsonElement[], List<FileInfo>>(string.Join(Environment.NewLine, processDataStandardFormat.Logistics), tests, jsonElements, new List<FileInfo>()); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  | } | ||||||
							
								
								
									
										41
									
								
								Adaptation/FileHandlers/InfinityQS/Six.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								Adaptation/FileHandlers/InfinityQS/Six.cs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,41 @@ | |||||||
|  | using System.Text.Json.Serialization; | ||||||
|  |  | ||||||
|  | namespace Adaptation.FileHandlers.InfinityQS; | ||||||
|  |  | ||||||
|  | #nullable enable | ||||||
|  |  | ||||||
|  | internal class Six | ||||||
|  | { | ||||||
|  |  | ||||||
|  |     [JsonConstructor] | ||||||
|  |     public Six( | ||||||
|  |         string id153, | ||||||
|  |         string id176, | ||||||
|  |         string id221, | ||||||
|  |         string id222, | ||||||
|  |         string id223, | ||||||
|  |         int vp12Count | ||||||
|  |     ) | ||||||
|  |     { | ||||||
|  |         ID153 = id153; | ||||||
|  |         ID176 = id176; | ||||||
|  |         ID221 = id221; | ||||||
|  |         ID222 = id222; | ||||||
|  |         ID223 = id223; | ||||||
|  |         VP12Count = vp12Count; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     [JsonPropertyName("id153")] public string ID153 { get; } | ||||||
|  |     [JsonPropertyName("id176")] public string ID176 { get; } | ||||||
|  |     [JsonPropertyName("id221")] public string ID221 { get; } | ||||||
|  |     [JsonPropertyName("id222")] public string ID222 { get; } | ||||||
|  |     [JsonPropertyName("id223")] public string ID223 { get; } | ||||||
|  |     [JsonPropertyName("vp12_count")] public int VP12Count { get; } | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | [JsonSourceGenerationOptions(WriteIndented = true, NumberHandling = JsonNumberHandling.AllowReadingFromString)] | ||||||
|  | [JsonSerializable(typeof(Six))] | ||||||
|  | internal partial class SixSourceGenerationContext : JsonSerializerContext | ||||||
|  | { | ||||||
|  | } | ||||||
							
								
								
									
										133
									
								
								Adaptation/FileHandlers/Log/FileRead.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										133
									
								
								Adaptation/FileHandlers/Log/FileRead.cs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,133 @@ | |||||||
|  | using Adaptation.Eaf.Management.ConfigurationData.CellAutomation; | ||||||
|  | using Adaptation.Ifx.Eaf.EquipmentConnector.File.Configuration; | ||||||
|  | using Adaptation.Shared; | ||||||
|  | using Adaptation.Shared.Duplicator; | ||||||
|  | using Adaptation.Shared.Methods; | ||||||
|  | using System; | ||||||
|  | using System.Collections.Generic; | ||||||
|  | using System.Collections.ObjectModel; | ||||||
|  | using System.IO; | ||||||
|  | using System.Linq; | ||||||
|  | using System.Text.Json; | ||||||
|  |  | ||||||
|  | namespace Adaptation.FileHandlers.Log; | ||||||
|  |  | ||||||
|  | public class FileRead : Shared.FileRead, IFileRead | ||||||
|  | { | ||||||
|  |  | ||||||
|  |     private readonly ReadOnlyDictionary<string, string> _SystemStateToNames; | ||||||
|  |  | ||||||
|  |     public FileRead(ISMTP smtp, Dictionary<string, string> fileParameter, string cellInstanceName, int? connectionCount, string cellInstanceConnectionName, FileConnectorConfiguration fileConnectorConfiguration, string equipmentTypeName, string parameterizedModelObjectDefinitionType, IList<ModelObjectParameterDefinition> modelObjectParameters, string equipmentDictionaryName, Dictionary<string, List<long>> dummyRuns, Dictionary<long, List<Shared.Metrology.WS.Results>> staticRuns, bool useCyclicalForDescription, bool isEAFHosted) : | ||||||
|  |         base(new Description(), false, smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null) | ||||||
|  |     { | ||||||
|  |         _MinFileLength = 10; | ||||||
|  |         _NullData = string.Empty; | ||||||
|  |         _Logistics = new(this); | ||||||
|  |         if (_FileParameter is null) | ||||||
|  |             throw new Exception(cellInstanceConnectionName); | ||||||
|  |         if (_ModelObjectParameterDefinitions is null) | ||||||
|  |             throw new Exception(cellInstanceConnectionName); | ||||||
|  |         if (!_IsDuplicator) | ||||||
|  |             throw new Exception(cellInstanceConnectionName); | ||||||
|  |         string[] segments; | ||||||
|  |         Dictionary<string, string> systemStateToNames = new(); | ||||||
|  |         ModelObjectParameterDefinition[] systemStates = GetProperties(cellInstanceConnectionName, modelObjectParameters, "ProcessDataStandardFormat.SystemState"); | ||||||
|  |         foreach (ModelObjectParameterDefinition modelObjectParameterDefinition in systemStates) | ||||||
|  |         { | ||||||
|  |             segments = modelObjectParameterDefinition.Value.Split('|'); | ||||||
|  |             if (segments.Length != 2) | ||||||
|  |                 continue; | ||||||
|  |             systemStateToNames.Add(segments[0], segments[1]); | ||||||
|  |         } | ||||||
|  |         _SystemStateToNames = new(systemStateToNames); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     void IFileRead.Move(Tuple<string, Test[], JsonElement[], List<FileInfo>> extractResults, Exception exception) | ||||||
|  |     { | ||||||
|  |         bool isErrorFile = exception is not null; | ||||||
|  |         if (!isErrorFile && !string.IsNullOrEmpty(_Logistics.ReportFullPath)) | ||||||
|  |         { | ||||||
|  |             FileInfo fileInfo = new(_Logistics.ReportFullPath); | ||||||
|  |             if (fileInfo.Exists && fileInfo.LastWriteTime < fileInfo.CreationTime) | ||||||
|  |                 File.SetLastWriteTime(_Logistics.ReportFullPath, fileInfo.CreationTime); | ||||||
|  |         } | ||||||
|  |         Move(extractResults); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     void IFileRead.WaitForThread() => WaitForThread(thread: null, threadExceptions: null); | ||||||
|  |  | ||||||
|  |     string IFileRead.GetEventDescription() | ||||||
|  |     { | ||||||
|  |         string result = _Description.GetEventDescription(); | ||||||
|  |         return result; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     List<string> IFileRead.GetHeaderNames() | ||||||
|  |     { | ||||||
|  |         List<string> results = _Description.GetHeaderNames(); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     string[] IFileRead.Move(Tuple<string, Test[], JsonElement[], List<FileInfo>> extractResults, string to, string from, string resolvedFileLocation, Exception exception) | ||||||
|  |     { | ||||||
|  |         string[] results = Move(extractResults, to, from, resolvedFileLocation, exception); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     JsonProperty[] IFileRead.GetDefault() | ||||||
|  |     { | ||||||
|  |         JsonProperty[] results = _Description.GetDefault(this, _Logistics); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     Dictionary<string, string> IFileRead.GetDisplayNamesJsonElement() | ||||||
|  |     { | ||||||
|  |         Dictionary<string, string> results = _Description.GetDisplayNamesJsonElement(this); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     List<IDescription> IFileRead.GetDescriptions(IFileRead fileRead, List<Test> tests, IProcessData processData) | ||||||
|  |     { | ||||||
|  |         List<IDescription> results = _Description.GetDescriptions(fileRead, _Logistics, tests, processData); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     Tuple<string, Test[], JsonElement[], List<FileInfo>> IFileRead.GetExtractResult(string reportFullPath, string eventName) | ||||||
|  |     { | ||||||
|  |         Tuple<string, Test[], JsonElement[], List<FileInfo>> results; | ||||||
|  |         if (string.IsNullOrEmpty(eventName)) | ||||||
|  |             throw new Exception(); | ||||||
|  |         _ReportFullPath = reportFullPath; | ||||||
|  |         DateTime dateTime = DateTime.Now; | ||||||
|  |         results = GetExtractResult(reportFullPath, dateTime); | ||||||
|  |         if (results.Item3 is null) | ||||||
|  |             results = new Tuple<string, Test[], JsonElement[], List<FileInfo>>(results.Item1, Array.Empty<Test>(), JsonSerializer.Deserialize<JsonElement[]>("[]"), results.Item4); | ||||||
|  |         if (results.Item3.Length > 0 && _IsEAFHosted) | ||||||
|  |             WritePDSF(this, results.Item3); | ||||||
|  |         UpdateLastTicksDuration(DateTime.Now.Ticks - dateTime.Ticks); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     Tuple<string, Test[], JsonElement[], List<FileInfo>> IFileRead.ReExtract() | ||||||
|  |     { | ||||||
|  |         Tuple<string, Test[], JsonElement[], List<FileInfo>> results; | ||||||
|  |         List<string> headerNames = _Description.GetHeaderNames(); | ||||||
|  |         Dictionary<string, string> keyValuePairs = _Description.GetDisplayNamesJsonElement(this); | ||||||
|  |         results = ReExtract(this, headerNames, keyValuePairs); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private Tuple<string, Test[], JsonElement[], List<FileInfo>> GetExtractResult(string reportFullPath, DateTime _) | ||||||
|  |     { | ||||||
|  |         Tuple<string, Test[], JsonElement[], List<FileInfo>> results; | ||||||
|  |         ProcessDataStandardFormat processDataStandardFormat = ProcessDataStandardFormat.GetProcessDataStandardFormat(reportFullPath); | ||||||
|  |         _Logistics = new Logistics(reportFullPath, processDataStandardFormat); | ||||||
|  |         SetFileParameterLotIDToLogisticsMID(); | ||||||
|  |         JsonElement[] jsonElements = ProcessDataStandardFormat.GetArray(processDataStandardFormat); | ||||||
|  |         List<Shared.Properties.IDescription> descriptions = GetDuplicatorDescriptions(jsonElements); | ||||||
|  |         Test[] tests = (from l in descriptions select (Test)l.Test).ToArray(); | ||||||
|  |         results = new Tuple<string, Test[], JsonElement[], List<FileInfo>>(string.Join(Environment.NewLine, processDataStandardFormat.Logistics), tests, jsonElements, new List<FileInfo>()); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -11,7 +11,7 @@ using System.IO; | |||||||
| using System.Linq; | using System.Linq; | ||||||
| using System.Text.Json; | using System.Text.Json; | ||||||
| 
 | 
 | ||||||
| namespace Adaptation.FileHandlers.R29; | namespace Adaptation.FileHandlers.R2; | ||||||
| 
 | 
 | ||||||
| public class FileRead : Shared.FileRead, IFileRead | public class FileRead : Shared.FileRead, IFileRead | ||||||
| { | { | ||||||
| @ -159,7 +159,7 @@ public class FileRead : Shared.FileRead, IFileRead | |||||||
|         return new(results); |         return new(results); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     private void MoveFile(string reportFullPath) |     private void CopyFile(string reportFullPath) | ||||||
|     { |     { | ||||||
|         string equipment; |         string equipment; | ||||||
|         string timestamp; |         string timestamp; | ||||||
| @ -201,13 +201,13 @@ public class FileRead : Shared.FileRead, IFileRead | |||||||
|             keyColumnIndex = GetKeyColumnIndex(columns, _KeyColumn); |             keyColumnIndex = GetKeyColumnIndex(columns, _KeyColumn); | ||||||
|             if (keyColumnIndex is null) |             if (keyColumnIndex is null) | ||||||
|             { |             { | ||||||
|                 File.Move(reportFullPath, Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, missingKeyDirectory, fileName)); |                 File.Copy(reportFullPath, Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, missingKeyDirectory, fileName)); | ||||||
|                 continue; |                 continue; | ||||||
|             } |             } | ||||||
|             systemStateValues = GetSystemStateValues(lines, columns, keyColumnIndex.Value); |             systemStateValues = GetSystemStateValues(lines, columns, keyColumnIndex.Value); | ||||||
|             if (systemStateValues.Count == 0) |             if (systemStateValues.Count == 0) | ||||||
|             { |             { | ||||||
|                 File.Move(reportFullPath, Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, missingKeyDirectory, fileName)); |                 File.Copy(reportFullPath, Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, missingKeyDirectory, fileName)); | ||||||
|                 continue; |                 continue; | ||||||
|             } |             } | ||||||
|             lines.AddRange(headerLines); |             lines.AddRange(headerLines); | ||||||
| @ -230,8 +230,8 @@ public class FileRead : Shared.FileRead, IFileRead | |||||||
|         List<Shared.Properties.IDescription> descriptions = GetDuplicatorDescriptions(jsonElements); |         List<Shared.Properties.IDescription> descriptions = GetDuplicatorDescriptions(jsonElements); | ||||||
|         Test[] tests = (from l in descriptions select (Test)l.Test).ToArray(); |         Test[] tests = (from l in descriptions select (Test)l.Test).ToArray(); | ||||||
|         if (_IsEAFHosted && _FileConnectorConfiguration.FileScanningIntervalInSeconds > 0) |         if (_IsEAFHosted && _FileConnectorConfiguration.FileScanningIntervalInSeconds > 0) | ||||||
|             MoveFile(reportFullPath); |             CopyFile(reportFullPath); | ||||||
|         results = new Tuple<string, Test[], JsonElement[], List<FileInfo>>(string.Join(Environment.NewLine, processDataStandardFormat.Logistics[0]), tests, jsonElements, new List<FileInfo>()); |         results = new Tuple<string, Test[], JsonElement[], List<FileInfo>>(string.Join(Environment.NewLine, processDataStandardFormat.Logistics), tests, jsonElements, new List<FileInfo>()); | ||||||
|         return results; |         return results; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -11,7 +11,7 @@ using System.IO; | |||||||
| using System.Linq; | using System.Linq; | ||||||
| using System.Text.Json; | using System.Text.Json; | ||||||
| 
 | 
 | ||||||
| namespace Adaptation.FileHandlers.R32; | namespace Adaptation.FileHandlers.R3; | ||||||
| 
 | 
 | ||||||
| public class FileRead : Shared.FileRead, IFileRead | public class FileRead : Shared.FileRead, IFileRead | ||||||
| { | { | ||||||
| @ -159,7 +159,7 @@ public class FileRead : Shared.FileRead, IFileRead | |||||||
|         return new(results); |         return new(results); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     private void MoveFile(string reportFullPath) |     private void CopyFile(string reportFullPath) | ||||||
|     { |     { | ||||||
|         string equipment; |         string equipment; | ||||||
|         string timestamp; |         string timestamp; | ||||||
| @ -201,13 +201,13 @@ public class FileRead : Shared.FileRead, IFileRead | |||||||
|             keyColumnIndex = GetKeyColumnIndex(columns, _KeyColumn); |             keyColumnIndex = GetKeyColumnIndex(columns, _KeyColumn); | ||||||
|             if (keyColumnIndex is null) |             if (keyColumnIndex is null) | ||||||
|             { |             { | ||||||
|                 File.Move(reportFullPath, Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, missingKeyDirectory, fileName)); |                 File.Copy(reportFullPath, Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, missingKeyDirectory, fileName)); | ||||||
|                 continue; |                 continue; | ||||||
|             } |             } | ||||||
|             systemStateValues = GetSystemStateValues(lines, columns, keyColumnIndex.Value); |             systemStateValues = GetSystemStateValues(lines, columns, keyColumnIndex.Value); | ||||||
|             if (systemStateValues.Count == 0) |             if (systemStateValues.Count == 0) | ||||||
|             { |             { | ||||||
|                 File.Move(reportFullPath, Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, missingKeyDirectory, fileName)); |                 File.Copy(reportFullPath, Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, missingKeyDirectory, fileName)); | ||||||
|                 continue; |                 continue; | ||||||
|             } |             } | ||||||
|             lines.AddRange(headerLines); |             lines.AddRange(headerLines); | ||||||
| @ -230,8 +230,8 @@ public class FileRead : Shared.FileRead, IFileRead | |||||||
|         List<Shared.Properties.IDescription> descriptions = GetDuplicatorDescriptions(jsonElements); |         List<Shared.Properties.IDescription> descriptions = GetDuplicatorDescriptions(jsonElements); | ||||||
|         Test[] tests = (from l in descriptions select (Test)l.Test).ToArray(); |         Test[] tests = (from l in descriptions select (Test)l.Test).ToArray(); | ||||||
|         if (_IsEAFHosted && _FileConnectorConfiguration.FileScanningIntervalInSeconds > 0) |         if (_IsEAFHosted && _FileConnectorConfiguration.FileScanningIntervalInSeconds > 0) | ||||||
|             MoveFile(reportFullPath); |             CopyFile(reportFullPath); | ||||||
|         results = new Tuple<string, Test[], JsonElement[], List<FileInfo>>(string.Join(Environment.NewLine, processDataStandardFormat.Logistics[0]), tests, jsonElements, new List<FileInfo>()); |         results = new Tuple<string, Test[], JsonElement[], List<FileInfo>>(string.Join(Environment.NewLine, processDataStandardFormat.Logistics), tests, jsonElements, new List<FileInfo>()); | ||||||
|         return results; |         return results; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -11,7 +11,7 @@ using System.IO; | |||||||
| using System.Linq; | using System.Linq; | ||||||
| using System.Text.Json; | using System.Text.Json; | ||||||
| 
 | 
 | ||||||
| namespace Adaptation.FileHandlers.R36; | namespace Adaptation.FileHandlers.R4; | ||||||
| 
 | 
 | ||||||
| public class FileRead : Shared.FileRead, IFileRead | public class FileRead : Shared.FileRead, IFileRead | ||||||
| { | { | ||||||
| @ -159,7 +159,7 @@ public class FileRead : Shared.FileRead, IFileRead | |||||||
|         return new(results); |         return new(results); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     private void MoveFile(string reportFullPath) |     private void CopyFile(string reportFullPath) | ||||||
|     { |     { | ||||||
|         string equipment; |         string equipment; | ||||||
|         string timestamp; |         string timestamp; | ||||||
| @ -201,13 +201,13 @@ public class FileRead : Shared.FileRead, IFileRead | |||||||
|             keyColumnIndex = GetKeyColumnIndex(columns, _KeyColumn); |             keyColumnIndex = GetKeyColumnIndex(columns, _KeyColumn); | ||||||
|             if (keyColumnIndex is null) |             if (keyColumnIndex is null) | ||||||
|             { |             { | ||||||
|                 File.Move(reportFullPath, Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, missingKeyDirectory, fileName)); |                 File.Copy(reportFullPath, Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, missingKeyDirectory, fileName)); | ||||||
|                 continue; |                 continue; | ||||||
|             } |             } | ||||||
|             systemStateValues = GetSystemStateValues(lines, columns, keyColumnIndex.Value); |             systemStateValues = GetSystemStateValues(lines, columns, keyColumnIndex.Value); | ||||||
|             if (systemStateValues.Count == 0) |             if (systemStateValues.Count == 0) | ||||||
|             { |             { | ||||||
|                 File.Move(reportFullPath, Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, missingKeyDirectory, fileName)); |                 File.Copy(reportFullPath, Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, missingKeyDirectory, fileName)); | ||||||
|                 continue; |                 continue; | ||||||
|             } |             } | ||||||
|             lines.AddRange(headerLines); |             lines.AddRange(headerLines); | ||||||
| @ -230,8 +230,8 @@ public class FileRead : Shared.FileRead, IFileRead | |||||||
|         List<Shared.Properties.IDescription> descriptions = GetDuplicatorDescriptions(jsonElements); |         List<Shared.Properties.IDescription> descriptions = GetDuplicatorDescriptions(jsonElements); | ||||||
|         Test[] tests = (from l in descriptions select (Test)l.Test).ToArray(); |         Test[] tests = (from l in descriptions select (Test)l.Test).ToArray(); | ||||||
|         if (_IsEAFHosted && _FileConnectorConfiguration.FileScanningIntervalInSeconds > 0) |         if (_IsEAFHosted && _FileConnectorConfiguration.FileScanningIntervalInSeconds > 0) | ||||||
|             MoveFile(reportFullPath); |             CopyFile(reportFullPath); | ||||||
|         results = new Tuple<string, Test[], JsonElement[], List<FileInfo>>(string.Join(Environment.NewLine, processDataStandardFormat.Logistics[0]), tests, jsonElements, new List<FileInfo>()); |         results = new Tuple<string, Test[], JsonElement[], List<FileInfo>>(string.Join(Environment.NewLine, processDataStandardFormat.Logistics), tests, jsonElements, new List<FileInfo>()); | ||||||
|         return results; |         return results; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -11,7 +11,7 @@ using System.IO; | |||||||
| using System.Linq; | using System.Linq; | ||||||
| using System.Text.Json; | using System.Text.Json; | ||||||
| 
 | 
 | ||||||
| namespace Adaptation.FileHandlers.R55; | namespace Adaptation.FileHandlers.R5; | ||||||
| 
 | 
 | ||||||
| public class FileRead : Shared.FileRead, IFileRead | public class FileRead : Shared.FileRead, IFileRead | ||||||
| { | { | ||||||
| @ -159,7 +159,7 @@ public class FileRead : Shared.FileRead, IFileRead | |||||||
|         return new(results); |         return new(results); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     private void MoveFile(string reportFullPath) |     private void CopyFile(string reportFullPath) | ||||||
|     { |     { | ||||||
|         string equipment; |         string equipment; | ||||||
|         string timestamp; |         string timestamp; | ||||||
| @ -201,13 +201,13 @@ public class FileRead : Shared.FileRead, IFileRead | |||||||
|             keyColumnIndex = GetKeyColumnIndex(columns, _KeyColumn); |             keyColumnIndex = GetKeyColumnIndex(columns, _KeyColumn); | ||||||
|             if (keyColumnIndex is null) |             if (keyColumnIndex is null) | ||||||
|             { |             { | ||||||
|                 File.Move(reportFullPath, Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, missingKeyDirectory, fileName)); |                 File.Copy(reportFullPath, Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, missingKeyDirectory, fileName)); | ||||||
|                 continue; |                 continue; | ||||||
|             } |             } | ||||||
|             systemStateValues = GetSystemStateValues(lines, columns, keyColumnIndex.Value); |             systemStateValues = GetSystemStateValues(lines, columns, keyColumnIndex.Value); | ||||||
|             if (systemStateValues.Count == 0) |             if (systemStateValues.Count == 0) | ||||||
|             { |             { | ||||||
|                 File.Move(reportFullPath, Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, missingKeyDirectory, fileName)); |                 File.Copy(reportFullPath, Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, missingKeyDirectory, fileName)); | ||||||
|                 continue; |                 continue; | ||||||
|             } |             } | ||||||
|             lines.AddRange(headerLines); |             lines.AddRange(headerLines); | ||||||
| @ -230,8 +230,8 @@ public class FileRead : Shared.FileRead, IFileRead | |||||||
|         List<Shared.Properties.IDescription> descriptions = GetDuplicatorDescriptions(jsonElements); |         List<Shared.Properties.IDescription> descriptions = GetDuplicatorDescriptions(jsonElements); | ||||||
|         Test[] tests = (from l in descriptions select (Test)l.Test).ToArray(); |         Test[] tests = (from l in descriptions select (Test)l.Test).ToArray(); | ||||||
|         if (_IsEAFHosted && _FileConnectorConfiguration.FileScanningIntervalInSeconds > 0) |         if (_IsEAFHosted && _FileConnectorConfiguration.FileScanningIntervalInSeconds > 0) | ||||||
|             MoveFile(reportFullPath); |             CopyFile(reportFullPath); | ||||||
|         results = new Tuple<string, Test[], JsonElement[], List<FileInfo>>(string.Join(Environment.NewLine, processDataStandardFormat.Logistics[0]), tests, jsonElements, new List<FileInfo>()); |         results = new Tuple<string, Test[], JsonElement[], List<FileInfo>>(string.Join(Environment.NewLine, processDataStandardFormat.Logistics), tests, jsonElements, new List<FileInfo>()); | ||||||
|         return results; |         return results; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -1,238 +0,0 @@ | |||||||
| using Adaptation.Eaf.Management.ConfigurationData.CellAutomation; |  | ||||||
| using Adaptation.Ifx.Eaf.EquipmentConnector.File.Configuration; |  | ||||||
| using Adaptation.Shared; |  | ||||||
| using Adaptation.Shared.Duplicator; |  | ||||||
| using Adaptation.Shared.Methods; |  | ||||||
| using System; |  | ||||||
| using System.Collections.Generic; |  | ||||||
| using System.Collections.ObjectModel; |  | ||||||
| using System.Globalization; |  | ||||||
| using System.IO; |  | ||||||
| using System.Linq; |  | ||||||
| using System.Text.Json; |  | ||||||
|  |  | ||||||
| namespace Adaptation.FileHandlers.R57; |  | ||||||
|  |  | ||||||
| public class FileRead : Shared.FileRead, IFileRead |  | ||||||
| { |  | ||||||
|  |  | ||||||
|     private readonly string _KeyColumn; |  | ||||||
|     private readonly string _TimestampFormat; |  | ||||||
|     private readonly ReadOnlyDictionary<string, string> _SystemStateToNames; |  | ||||||
|  |  | ||||||
|     public FileRead(ISMTP smtp, Dictionary<string, string> fileParameter, string cellInstanceName, int? connectionCount, string cellInstanceConnectionName, FileConnectorConfiguration fileConnectorConfiguration, string equipmentTypeName, string parameterizedModelObjectDefinitionType, IList<ModelObjectParameterDefinition> modelObjectParameters, string equipmentDictionaryName, Dictionary<string, List<long>> dummyRuns, Dictionary<long, List<Shared.Metrology.WS.Results>> staticRuns, bool useCyclicalForDescription, bool isEAFHosted) : |  | ||||||
|         base(new Description(), false, smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null) |  | ||||||
|     { |  | ||||||
|         _MinFileLength = 10; |  | ||||||
|         _NullData = string.Empty; |  | ||||||
|         _Logistics = new(this); |  | ||||||
|         if (_FileParameter is null) |  | ||||||
|             throw new Exception(cellInstanceConnectionName); |  | ||||||
|         if (_ModelObjectParameterDefinitions is null) |  | ||||||
|             throw new Exception(cellInstanceConnectionName); |  | ||||||
|         if (!_IsDuplicator) |  | ||||||
|             throw new Exception(cellInstanceConnectionName); |  | ||||||
|         string[] segments; |  | ||||||
|         Dictionary<string, string> systemStateToNames = new(); |  | ||||||
|         _KeyColumn = GetPropertyValue(cellInstanceConnectionName, modelObjectParameters, "ProcessDataStandardFormat.KeyColumn"); |  | ||||||
|         _TimestampFormat = GetPropertyValue(cellInstanceConnectionName, modelObjectParameters, "ProcessDataStandardFormat.TimestampFormat"); |  | ||||||
|         ModelObjectParameterDefinition[] systemStates = GetProperties(cellInstanceConnectionName, modelObjectParameters, "ProcessDataStandardFormat.SystemState"); |  | ||||||
|         foreach (ModelObjectParameterDefinition modelObjectParameterDefinition in systemStates) |  | ||||||
|         { |  | ||||||
|             segments = modelObjectParameterDefinition.Value.Split('|'); |  | ||||||
|             if (segments.Length != 2) |  | ||||||
|                 continue; |  | ||||||
|             systemStateToNames.Add(segments[0], segments[1]); |  | ||||||
|         } |  | ||||||
|         _SystemStateToNames = new(systemStateToNames); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     void IFileRead.Move(Tuple<string, Test[], JsonElement[], List<FileInfo>> extractResults, Exception exception) |  | ||||||
|     { |  | ||||||
|         bool isErrorFile = exception is not null; |  | ||||||
|         if (!isErrorFile && !string.IsNullOrEmpty(_Logistics.ReportFullPath)) |  | ||||||
|         { |  | ||||||
|             FileInfo fileInfo = new(_Logistics.ReportFullPath); |  | ||||||
|             if (fileInfo.Exists && fileInfo.LastWriteTime < fileInfo.CreationTime) |  | ||||||
|                 File.SetLastWriteTime(_Logistics.ReportFullPath, fileInfo.CreationTime); |  | ||||||
|         } |  | ||||||
|         Move(extractResults); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     void IFileRead.WaitForThread() => WaitForThread(thread: null, threadExceptions: null); |  | ||||||
|  |  | ||||||
|     string IFileRead.GetEventDescription() |  | ||||||
|     { |  | ||||||
|         string result = _Description.GetEventDescription(); |  | ||||||
|         return result; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     List<string> IFileRead.GetHeaderNames() |  | ||||||
|     { |  | ||||||
|         List<string> results = _Description.GetHeaderNames(); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     string[] IFileRead.Move(Tuple<string, Test[], JsonElement[], List<FileInfo>> extractResults, string to, string from, string resolvedFileLocation, Exception exception) |  | ||||||
|     { |  | ||||||
|         string[] results = Move(extractResults, to, from, resolvedFileLocation, exception); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     JsonProperty[] IFileRead.GetDefault() |  | ||||||
|     { |  | ||||||
|         JsonProperty[] results = _Description.GetDefault(this, _Logistics); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     Dictionary<string, string> IFileRead.GetDisplayNamesJsonElement() |  | ||||||
|     { |  | ||||||
|         Dictionary<string, string> results = _Description.GetDisplayNamesJsonElement(this); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     List<IDescription> IFileRead.GetDescriptions(IFileRead fileRead, List<Test> tests, IProcessData processData) |  | ||||||
|     { |  | ||||||
|         List<IDescription> results = _Description.GetDescriptions(fileRead, _Logistics, tests, processData); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     Tuple<string, Test[], JsonElement[], List<FileInfo>> IFileRead.GetExtractResult(string reportFullPath, string eventName) |  | ||||||
|     { |  | ||||||
|         Tuple<string, Test[], JsonElement[], List<FileInfo>> results; |  | ||||||
|         if (string.IsNullOrEmpty(eventName)) |  | ||||||
|             throw new Exception(); |  | ||||||
|         _ReportFullPath = reportFullPath; |  | ||||||
|         DateTime dateTime = DateTime.Now; |  | ||||||
|         results = GetExtractResult(reportFullPath, dateTime); |  | ||||||
|         if (results.Item3 is null) |  | ||||||
|             results = new Tuple<string, Test[], JsonElement[], List<FileInfo>>(results.Item1, Array.Empty<Test>(), JsonSerializer.Deserialize<JsonElement[]>("[]"), results.Item4); |  | ||||||
|         if (results.Item3.Length > 0 && _IsEAFHosted) |  | ||||||
|             WritePDSF(this, results.Item3); |  | ||||||
|         UpdateLastTicksDuration(DateTime.Now.Ticks - dateTime.Ticks); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     Tuple<string, Test[], JsonElement[], List<FileInfo>> IFileRead.ReExtract() |  | ||||||
|     { |  | ||||||
|         Tuple<string, Test[], JsonElement[], List<FileInfo>> results; |  | ||||||
|         List<string> headerNames = _Description.GetHeaderNames(); |  | ||||||
|         Dictionary<string, string> keyValuePairs = _Description.GetDisplayNamesJsonElement(this); |  | ||||||
|         results = ReExtract(this, headerNames, keyValuePairs); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private static int? GetKeyColumnIndex(string[] columns, string keyColumn) |  | ||||||
|     { |  | ||||||
| #nullable enable |  | ||||||
|         int? result = null; |  | ||||||
|         for (int i = 0; i < columns.Length; i++) |  | ||||||
|         { |  | ||||||
|             if (columns[i] != keyColumn) |  | ||||||
|                 continue; |  | ||||||
|             result = i; |  | ||||||
|             break; |  | ||||||
|         } |  | ||||||
|         return result; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private ReadOnlyCollection<string> GetSystemStateValues(List<string> lines, string[] columns, int keyColumnIndex) |  | ||||||
|     { |  | ||||||
|         List<string> results = new(); |  | ||||||
|         string[] values; |  | ||||||
|         string? systemState; |  | ||||||
|         string keyColumnValue; |  | ||||||
|         for (int i = 7; i < lines.Count; i++) |  | ||||||
|         { |  | ||||||
|             values = lines[i].Split('\t'); |  | ||||||
|             if (values.Length != columns.Length) |  | ||||||
|                 continue; |  | ||||||
|             keyColumnValue = values[keyColumnIndex]; |  | ||||||
|             if (string.IsNullOrEmpty(keyColumnValue)) |  | ||||||
|                 continue; |  | ||||||
|             if (!_SystemStateToNames.TryGetValue(keyColumnValue, out systemState)) |  | ||||||
|                 continue; |  | ||||||
|             if (results.Contains(systemState)) |  | ||||||
|                 continue; |  | ||||||
|             results.Add(systemState); |  | ||||||
|         } |  | ||||||
|         return new(results); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private void MoveFile(string reportFullPath) |  | ||||||
|     { |  | ||||||
|         string equipment; |  | ||||||
|         string timestamp; |  | ||||||
|         string[] columns; |  | ||||||
|         DateTime dateTime; |  | ||||||
|         List<string> lines; |  | ||||||
|         string systemState; |  | ||||||
|         int? keyColumnIndex; |  | ||||||
|         string checkFileName; |  | ||||||
|         List<string> headerLines = new(); |  | ||||||
|         ReadOnlyCollection<string> systemStateValues; |  | ||||||
|         string missingKeyDirectory = Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, "Missing-Key"); |  | ||||||
|         if (!Directory.Exists(missingKeyDirectory)) |  | ||||||
|             _ = Directory.CreateDirectory(missingKeyDirectory); |  | ||||||
|         string fileName = Path.GetFileName(reportFullPath); |  | ||||||
|         string[] segments = fileName.Split('_'); |  | ||||||
|         for (int z = 0; z < 1; z++) |  | ||||||
|         { |  | ||||||
|             if (segments.Length != 2) |  | ||||||
|                 continue; |  | ||||||
|             equipment = segments[0]; |  | ||||||
|             timestamp = segments[1].Split('.')[0]; |  | ||||||
|             if (timestamp.Length != _TimestampFormat.Length) |  | ||||||
|                 continue; |  | ||||||
|             headerLines.Clear(); |  | ||||||
|             lines = File.ReadAllLines(reportFullPath).ToList(); |  | ||||||
|             if (lines.Count < 8) |  | ||||||
|                 continue; |  | ||||||
|             for (int i = 0; i < 6; i++) |  | ||||||
|             { |  | ||||||
|                 headerLines.Add(lines[0]); |  | ||||||
|                 lines.RemoveAt(0); |  | ||||||
|             } |  | ||||||
|             if (lines[0].Length < 1 || lines[0][0] != '"' || !lines[0].StartsWith("\"Time\"")) |  | ||||||
|                 continue; |  | ||||||
|             columns = lines[0].Split('\t'); |  | ||||||
|             if (columns.Length < 3) |  | ||||||
|                 continue; |  | ||||||
|             keyColumnIndex = GetKeyColumnIndex(columns, _KeyColumn); |  | ||||||
|             if (keyColumnIndex is null) |  | ||||||
|             { |  | ||||||
|                 File.Move(reportFullPath, Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, missingKeyDirectory, fileName)); |  | ||||||
|                 continue; |  | ||||||
|             } |  | ||||||
|             systemStateValues = GetSystemStateValues(lines, columns, keyColumnIndex.Value); |  | ||||||
|             if (systemStateValues.Count == 0) |  | ||||||
|             { |  | ||||||
|                 File.Move(reportFullPath, Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, missingKeyDirectory, fileName)); |  | ||||||
|                 continue; |  | ||||||
|             } |  | ||||||
|             lines.AddRange(headerLines); |  | ||||||
|             systemState = string.Join("-", systemStateValues); |  | ||||||
|             checkFileName = Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, $"{equipment}-{timestamp}-{systemState}.pdsf"); |  | ||||||
|             File.WriteAllLines(checkFileName, lines); |  | ||||||
|             // File.Delete(reportFullPath); |  | ||||||
|             if (DateTime.TryParseExact(timestamp, _TimestampFormat, CultureInfo.InvariantCulture, DateTimeStyles.None, out dateTime)) |  | ||||||
|                 File.SetLastWriteTime(checkFileName, dateTime); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private Tuple<string, Test[], JsonElement[], List<FileInfo>> GetExtractResult(string reportFullPath, DateTime _) |  | ||||||
|     { |  | ||||||
|         Tuple<string, Test[], JsonElement[], List<FileInfo>> results; |  | ||||||
|         ProcessDataStandardFormat processDataStandardFormat = ProcessDataStandardFormat.GetProcessDataStandardFormat(reportFullPath); |  | ||||||
|         _Logistics = new Logistics(reportFullPath, processDataStandardFormat); |  | ||||||
|         SetFileParameterLotIDToLogisticsMID(); |  | ||||||
|         JsonElement[] jsonElements = ProcessDataStandardFormat.GetArray(processDataStandardFormat); |  | ||||||
|         List<Shared.Properties.IDescription> descriptions = GetDuplicatorDescriptions(jsonElements); |  | ||||||
|         Test[] tests = (from l in descriptions select (Test)l.Test).ToArray(); |  | ||||||
|         if (_IsEAFHosted && _FileConnectorConfiguration.FileScanningIntervalInSeconds > 0) |  | ||||||
|             MoveFile(reportFullPath); |  | ||||||
|         results = new Tuple<string, Test[], JsonElement[], List<FileInfo>>(string.Join(Environment.NewLine, processDataStandardFormat.Logistics[0]), tests, jsonElements, new List<FileInfo>()); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } |  | ||||||
							
								
								
									
										238
									
								
								Adaptation/FileHandlers/R6/FileRead.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										238
									
								
								Adaptation/FileHandlers/R6/FileRead.cs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,238 @@ | |||||||
|  | using Adaptation.Eaf.Management.ConfigurationData.CellAutomation; | ||||||
|  | using Adaptation.Ifx.Eaf.EquipmentConnector.File.Configuration; | ||||||
|  | using Adaptation.Shared; | ||||||
|  | using Adaptation.Shared.Duplicator; | ||||||
|  | using Adaptation.Shared.Methods; | ||||||
|  | using System; | ||||||
|  | using System.Collections.Generic; | ||||||
|  | using System.Collections.ObjectModel; | ||||||
|  | using System.Globalization; | ||||||
|  | using System.IO; | ||||||
|  | using System.Linq; | ||||||
|  | using System.Text.Json; | ||||||
|  |  | ||||||
|  | namespace Adaptation.FileHandlers.R6; | ||||||
|  |  | ||||||
|  | public class FileRead : Shared.FileRead, IFileRead | ||||||
|  | { | ||||||
|  |  | ||||||
|  |     private readonly string _KeyColumn; | ||||||
|  |     private readonly string _TimestampFormat; | ||||||
|  |     private readonly ReadOnlyDictionary<string, string> _SystemStateToNames; | ||||||
|  |  | ||||||
|  |     public FileRead(ISMTP smtp, Dictionary<string, string> fileParameter, string cellInstanceName, int? connectionCount, string cellInstanceConnectionName, FileConnectorConfiguration fileConnectorConfiguration, string equipmentTypeName, string parameterizedModelObjectDefinitionType, IList<ModelObjectParameterDefinition> modelObjectParameters, string equipmentDictionaryName, Dictionary<string, List<long>> dummyRuns, Dictionary<long, List<Shared.Metrology.WS.Results>> staticRuns, bool useCyclicalForDescription, bool isEAFHosted) : | ||||||
|  |         base(new Description(), false, smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null) | ||||||
|  |     { | ||||||
|  |         _MinFileLength = 10; | ||||||
|  |         _NullData = string.Empty; | ||||||
|  |         _Logistics = new(this); | ||||||
|  |         if (_FileParameter is null) | ||||||
|  |             throw new Exception(cellInstanceConnectionName); | ||||||
|  |         if (_ModelObjectParameterDefinitions is null) | ||||||
|  |             throw new Exception(cellInstanceConnectionName); | ||||||
|  |         if (!_IsDuplicator) | ||||||
|  |             throw new Exception(cellInstanceConnectionName); | ||||||
|  |         string[] segments; | ||||||
|  |         Dictionary<string, string> systemStateToNames = new(); | ||||||
|  |         _KeyColumn = GetPropertyValue(cellInstanceConnectionName, modelObjectParameters, "ProcessDataStandardFormat.KeyColumn"); | ||||||
|  |         _TimestampFormat = GetPropertyValue(cellInstanceConnectionName, modelObjectParameters, "ProcessDataStandardFormat.TimestampFormat"); | ||||||
|  |         ModelObjectParameterDefinition[] systemStates = GetProperties(cellInstanceConnectionName, modelObjectParameters, "ProcessDataStandardFormat.SystemState"); | ||||||
|  |         foreach (ModelObjectParameterDefinition modelObjectParameterDefinition in systemStates) | ||||||
|  |         { | ||||||
|  |             segments = modelObjectParameterDefinition.Value.Split('|'); | ||||||
|  |             if (segments.Length != 2) | ||||||
|  |                 continue; | ||||||
|  |             systemStateToNames.Add(segments[0], segments[1]); | ||||||
|  |         } | ||||||
|  |         _SystemStateToNames = new(systemStateToNames); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     void IFileRead.Move(Tuple<string, Test[], JsonElement[], List<FileInfo>> extractResults, Exception exception) | ||||||
|  |     { | ||||||
|  |         bool isErrorFile = exception is not null; | ||||||
|  |         if (!isErrorFile && !string.IsNullOrEmpty(_Logistics.ReportFullPath)) | ||||||
|  |         { | ||||||
|  |             FileInfo fileInfo = new(_Logistics.ReportFullPath); | ||||||
|  |             if (fileInfo.Exists && fileInfo.LastWriteTime < fileInfo.CreationTime) | ||||||
|  |                 File.SetLastWriteTime(_Logistics.ReportFullPath, fileInfo.CreationTime); | ||||||
|  |         } | ||||||
|  |         Move(extractResults); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     void IFileRead.WaitForThread() => WaitForThread(thread: null, threadExceptions: null); | ||||||
|  |  | ||||||
|  |     string IFileRead.GetEventDescription() | ||||||
|  |     { | ||||||
|  |         string result = _Description.GetEventDescription(); | ||||||
|  |         return result; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     List<string> IFileRead.GetHeaderNames() | ||||||
|  |     { | ||||||
|  |         List<string> results = _Description.GetHeaderNames(); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     string[] IFileRead.Move(Tuple<string, Test[], JsonElement[], List<FileInfo>> extractResults, string to, string from, string resolvedFileLocation, Exception exception) | ||||||
|  |     { | ||||||
|  |         string[] results = Move(extractResults, to, from, resolvedFileLocation, exception); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     JsonProperty[] IFileRead.GetDefault() | ||||||
|  |     { | ||||||
|  |         JsonProperty[] results = _Description.GetDefault(this, _Logistics); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     Dictionary<string, string> IFileRead.GetDisplayNamesJsonElement() | ||||||
|  |     { | ||||||
|  |         Dictionary<string, string> results = _Description.GetDisplayNamesJsonElement(this); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     List<IDescription> IFileRead.GetDescriptions(IFileRead fileRead, List<Test> tests, IProcessData processData) | ||||||
|  |     { | ||||||
|  |         List<IDescription> results = _Description.GetDescriptions(fileRead, _Logistics, tests, processData); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     Tuple<string, Test[], JsonElement[], List<FileInfo>> IFileRead.GetExtractResult(string reportFullPath, string eventName) | ||||||
|  |     { | ||||||
|  |         Tuple<string, Test[], JsonElement[], List<FileInfo>> results; | ||||||
|  |         if (string.IsNullOrEmpty(eventName)) | ||||||
|  |             throw new Exception(); | ||||||
|  |         _ReportFullPath = reportFullPath; | ||||||
|  |         DateTime dateTime = DateTime.Now; | ||||||
|  |         results = GetExtractResult(reportFullPath, dateTime); | ||||||
|  |         if (results.Item3 is null) | ||||||
|  |             results = new Tuple<string, Test[], JsonElement[], List<FileInfo>>(results.Item1, Array.Empty<Test>(), JsonSerializer.Deserialize<JsonElement[]>("[]"), results.Item4); | ||||||
|  |         if (results.Item3.Length > 0 && _IsEAFHosted) | ||||||
|  |             WritePDSF(this, results.Item3); | ||||||
|  |         UpdateLastTicksDuration(DateTime.Now.Ticks - dateTime.Ticks); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     Tuple<string, Test[], JsonElement[], List<FileInfo>> IFileRead.ReExtract() | ||||||
|  |     { | ||||||
|  |         Tuple<string, Test[], JsonElement[], List<FileInfo>> results; | ||||||
|  |         List<string> headerNames = _Description.GetHeaderNames(); | ||||||
|  |         Dictionary<string, string> keyValuePairs = _Description.GetDisplayNamesJsonElement(this); | ||||||
|  |         results = ReExtract(this, headerNames, keyValuePairs); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private static int? GetKeyColumnIndex(string[] columns, string keyColumn) | ||||||
|  |     { | ||||||
|  | #nullable enable | ||||||
|  |         int? result = null; | ||||||
|  |         for (int i = 0; i < columns.Length; i++) | ||||||
|  |         { | ||||||
|  |             if (columns[i] != keyColumn) | ||||||
|  |                 continue; | ||||||
|  |             result = i; | ||||||
|  |             break; | ||||||
|  |         } | ||||||
|  |         return result; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private ReadOnlyCollection<string> GetSystemStateValues(List<string> lines, string[] columns, int keyColumnIndex) | ||||||
|  |     { | ||||||
|  |         List<string> results = new(); | ||||||
|  |         string[] values; | ||||||
|  |         string? systemState; | ||||||
|  |         string keyColumnValue; | ||||||
|  |         for (int i = 7; i < lines.Count; i++) | ||||||
|  |         { | ||||||
|  |             values = lines[i].Split('\t'); | ||||||
|  |             if (values.Length != columns.Length) | ||||||
|  |                 continue; | ||||||
|  |             keyColumnValue = values[keyColumnIndex]; | ||||||
|  |             if (string.IsNullOrEmpty(keyColumnValue)) | ||||||
|  |                 continue; | ||||||
|  |             if (!_SystemStateToNames.TryGetValue(keyColumnValue, out systemState)) | ||||||
|  |                 continue; | ||||||
|  |             if (results.Contains(systemState)) | ||||||
|  |                 continue; | ||||||
|  |             results.Add(systemState); | ||||||
|  |         } | ||||||
|  |         return new(results); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private void CopyFile(string reportFullPath) | ||||||
|  |     { | ||||||
|  |         string equipment; | ||||||
|  |         string timestamp; | ||||||
|  |         string[] columns; | ||||||
|  |         DateTime dateTime; | ||||||
|  |         List<string> lines; | ||||||
|  |         string systemState; | ||||||
|  |         int? keyColumnIndex; | ||||||
|  |         string checkFileName; | ||||||
|  |         List<string> headerLines = new(); | ||||||
|  |         ReadOnlyCollection<string> systemStateValues; | ||||||
|  |         string missingKeyDirectory = Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, "Missing-Key"); | ||||||
|  |         if (!Directory.Exists(missingKeyDirectory)) | ||||||
|  |             _ = Directory.CreateDirectory(missingKeyDirectory); | ||||||
|  |         string fileName = Path.GetFileName(reportFullPath); | ||||||
|  |         string[] segments = fileName.Split('_'); | ||||||
|  |         for (int z = 0; z < 1; z++) | ||||||
|  |         { | ||||||
|  |             if (segments.Length != 2) | ||||||
|  |                 continue; | ||||||
|  |             equipment = segments[0]; | ||||||
|  |             timestamp = segments[1].Split('.')[0]; | ||||||
|  |             if (timestamp.Length != _TimestampFormat.Length) | ||||||
|  |                 continue; | ||||||
|  |             headerLines.Clear(); | ||||||
|  |             lines = File.ReadAllLines(reportFullPath).ToList(); | ||||||
|  |             if (lines.Count < 8) | ||||||
|  |                 continue; | ||||||
|  |             for (int i = 0; i < 6; i++) | ||||||
|  |             { | ||||||
|  |                 headerLines.Add(lines[0]); | ||||||
|  |                 lines.RemoveAt(0); | ||||||
|  |             } | ||||||
|  |             if (lines[0].Length < 1 || lines[0][0] != '"' || !lines[0].StartsWith("\"Time\"")) | ||||||
|  |                 continue; | ||||||
|  |             columns = lines[0].Split('\t'); | ||||||
|  |             if (columns.Length < 3) | ||||||
|  |                 continue; | ||||||
|  |             keyColumnIndex = GetKeyColumnIndex(columns, _KeyColumn); | ||||||
|  |             if (keyColumnIndex is null) | ||||||
|  |             { | ||||||
|  |                 File.Copy(reportFullPath, Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, missingKeyDirectory, fileName)); | ||||||
|  |                 continue; | ||||||
|  |             } | ||||||
|  |             systemStateValues = GetSystemStateValues(lines, columns, keyColumnIndex.Value); | ||||||
|  |             if (systemStateValues.Count == 0) | ||||||
|  |             { | ||||||
|  |                 File.Copy(reportFullPath, Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, missingKeyDirectory, fileName)); | ||||||
|  |                 continue; | ||||||
|  |             } | ||||||
|  |             lines.AddRange(headerLines); | ||||||
|  |             systemState = string.Join("-", systemStateValues); | ||||||
|  |             checkFileName = Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, $"{equipment}-{timestamp}-{systemState}.pdsf"); | ||||||
|  |             File.WriteAllLines(checkFileName, lines); | ||||||
|  |             // File.Delete(reportFullPath); | ||||||
|  |             if (DateTime.TryParseExact(timestamp, _TimestampFormat, CultureInfo.InvariantCulture, DateTimeStyles.None, out dateTime)) | ||||||
|  |                 File.SetLastWriteTime(checkFileName, dateTime); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private Tuple<string, Test[], JsonElement[], List<FileInfo>> GetExtractResult(string reportFullPath, DateTime _) | ||||||
|  |     { | ||||||
|  |         Tuple<string, Test[], JsonElement[], List<FileInfo>> results; | ||||||
|  |         ProcessDataStandardFormat processDataStandardFormat = ProcessDataStandardFormat.GetProcessDataStandardFormat(reportFullPath); | ||||||
|  |         _Logistics = new Logistics(reportFullPath, processDataStandardFormat); | ||||||
|  |         SetFileParameterLotIDToLogisticsMID(); | ||||||
|  |         JsonElement[] jsonElements = ProcessDataStandardFormat.GetArray(processDataStandardFormat); | ||||||
|  |         List<Shared.Properties.IDescription> descriptions = GetDuplicatorDescriptions(jsonElements); | ||||||
|  |         Test[] tests = (from l in descriptions select (Test)l.Test).ToArray(); | ||||||
|  |         if (_IsEAFHosted && _FileConnectorConfiguration.FileScanningIntervalInSeconds > 0) | ||||||
|  |             CopyFile(reportFullPath); | ||||||
|  |         results = new Tuple<string, Test[], JsonElement[], List<FileInfo>>(string.Join(Environment.NewLine, processDataStandardFormat.Logistics), tests, jsonElements, new List<FileInfo>()); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -1,238 +0,0 @@ | |||||||
| using Adaptation.Eaf.Management.ConfigurationData.CellAutomation; |  | ||||||
| using Adaptation.Ifx.Eaf.EquipmentConnector.File.Configuration; |  | ||||||
| using Adaptation.Shared; |  | ||||||
| using Adaptation.Shared.Duplicator; |  | ||||||
| using Adaptation.Shared.Methods; |  | ||||||
| using System; |  | ||||||
| using System.Collections.Generic; |  | ||||||
| using System.Collections.ObjectModel; |  | ||||||
| using System.Globalization; |  | ||||||
| using System.IO; |  | ||||||
| using System.Linq; |  | ||||||
| using System.Text.Json; |  | ||||||
|  |  | ||||||
| namespace Adaptation.FileHandlers.R61; |  | ||||||
|  |  | ||||||
| public class FileRead : Shared.FileRead, IFileRead |  | ||||||
| { |  | ||||||
|  |  | ||||||
|     private readonly string _KeyColumn; |  | ||||||
|     private readonly string _TimestampFormat; |  | ||||||
|     private readonly ReadOnlyDictionary<string, string> _SystemStateToNames; |  | ||||||
|  |  | ||||||
|     public FileRead(ISMTP smtp, Dictionary<string, string> fileParameter, string cellInstanceName, int? connectionCount, string cellInstanceConnectionName, FileConnectorConfiguration fileConnectorConfiguration, string equipmentTypeName, string parameterizedModelObjectDefinitionType, IList<ModelObjectParameterDefinition> modelObjectParameters, string equipmentDictionaryName, Dictionary<string, List<long>> dummyRuns, Dictionary<long, List<Shared.Metrology.WS.Results>> staticRuns, bool useCyclicalForDescription, bool isEAFHosted) : |  | ||||||
|         base(new Description(), false, smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null) |  | ||||||
|     { |  | ||||||
|         _MinFileLength = 10; |  | ||||||
|         _NullData = string.Empty; |  | ||||||
|         _Logistics = new(this); |  | ||||||
|         if (_FileParameter is null) |  | ||||||
|             throw new Exception(cellInstanceConnectionName); |  | ||||||
|         if (_ModelObjectParameterDefinitions is null) |  | ||||||
|             throw new Exception(cellInstanceConnectionName); |  | ||||||
|         if (!_IsDuplicator) |  | ||||||
|             throw new Exception(cellInstanceConnectionName); |  | ||||||
|         string[] segments; |  | ||||||
|         Dictionary<string, string> systemStateToNames = new(); |  | ||||||
|         _KeyColumn = GetPropertyValue(cellInstanceConnectionName, modelObjectParameters, "ProcessDataStandardFormat.KeyColumn"); |  | ||||||
|         _TimestampFormat = GetPropertyValue(cellInstanceConnectionName, modelObjectParameters, "ProcessDataStandardFormat.TimestampFormat"); |  | ||||||
|         ModelObjectParameterDefinition[] systemStates = GetProperties(cellInstanceConnectionName, modelObjectParameters, "ProcessDataStandardFormat.SystemState"); |  | ||||||
|         foreach (ModelObjectParameterDefinition modelObjectParameterDefinition in systemStates) |  | ||||||
|         { |  | ||||||
|             segments = modelObjectParameterDefinition.Value.Split('|'); |  | ||||||
|             if (segments.Length != 2) |  | ||||||
|                 continue; |  | ||||||
|             systemStateToNames.Add(segments[0], segments[1]); |  | ||||||
|         } |  | ||||||
|         _SystemStateToNames = new(systemStateToNames); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     void IFileRead.Move(Tuple<string, Test[], JsonElement[], List<FileInfo>> extractResults, Exception exception) |  | ||||||
|     { |  | ||||||
|         bool isErrorFile = exception is not null; |  | ||||||
|         if (!isErrorFile && !string.IsNullOrEmpty(_Logistics.ReportFullPath)) |  | ||||||
|         { |  | ||||||
|             FileInfo fileInfo = new(_Logistics.ReportFullPath); |  | ||||||
|             if (fileInfo.Exists && fileInfo.LastWriteTime < fileInfo.CreationTime) |  | ||||||
|                 File.SetLastWriteTime(_Logistics.ReportFullPath, fileInfo.CreationTime); |  | ||||||
|         } |  | ||||||
|         Move(extractResults); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     void IFileRead.WaitForThread() => WaitForThread(thread: null, threadExceptions: null); |  | ||||||
|  |  | ||||||
|     string IFileRead.GetEventDescription() |  | ||||||
|     { |  | ||||||
|         string result = _Description.GetEventDescription(); |  | ||||||
|         return result; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     List<string> IFileRead.GetHeaderNames() |  | ||||||
|     { |  | ||||||
|         List<string> results = _Description.GetHeaderNames(); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     string[] IFileRead.Move(Tuple<string, Test[], JsonElement[], List<FileInfo>> extractResults, string to, string from, string resolvedFileLocation, Exception exception) |  | ||||||
|     { |  | ||||||
|         string[] results = Move(extractResults, to, from, resolvedFileLocation, exception); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     JsonProperty[] IFileRead.GetDefault() |  | ||||||
|     { |  | ||||||
|         JsonProperty[] results = _Description.GetDefault(this, _Logistics); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     Dictionary<string, string> IFileRead.GetDisplayNamesJsonElement() |  | ||||||
|     { |  | ||||||
|         Dictionary<string, string> results = _Description.GetDisplayNamesJsonElement(this); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     List<IDescription> IFileRead.GetDescriptions(IFileRead fileRead, List<Test> tests, IProcessData processData) |  | ||||||
|     { |  | ||||||
|         List<IDescription> results = _Description.GetDescriptions(fileRead, _Logistics, tests, processData); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     Tuple<string, Test[], JsonElement[], List<FileInfo>> IFileRead.GetExtractResult(string reportFullPath, string eventName) |  | ||||||
|     { |  | ||||||
|         Tuple<string, Test[], JsonElement[], List<FileInfo>> results; |  | ||||||
|         if (string.IsNullOrEmpty(eventName)) |  | ||||||
|             throw new Exception(); |  | ||||||
|         _ReportFullPath = reportFullPath; |  | ||||||
|         DateTime dateTime = DateTime.Now; |  | ||||||
|         results = GetExtractResult(reportFullPath, dateTime); |  | ||||||
|         if (results.Item3 is null) |  | ||||||
|             results = new Tuple<string, Test[], JsonElement[], List<FileInfo>>(results.Item1, Array.Empty<Test>(), JsonSerializer.Deserialize<JsonElement[]>("[]"), results.Item4); |  | ||||||
|         if (results.Item3.Length > 0 && _IsEAFHosted) |  | ||||||
|             WritePDSF(this, results.Item3); |  | ||||||
|         UpdateLastTicksDuration(DateTime.Now.Ticks - dateTime.Ticks); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     Tuple<string, Test[], JsonElement[], List<FileInfo>> IFileRead.ReExtract() |  | ||||||
|     { |  | ||||||
|         Tuple<string, Test[], JsonElement[], List<FileInfo>> results; |  | ||||||
|         List<string> headerNames = _Description.GetHeaderNames(); |  | ||||||
|         Dictionary<string, string> keyValuePairs = _Description.GetDisplayNamesJsonElement(this); |  | ||||||
|         results = ReExtract(this, headerNames, keyValuePairs); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private static int? GetKeyColumnIndex(string[] columns, string keyColumn) |  | ||||||
|     { |  | ||||||
| #nullable enable |  | ||||||
|         int? result = null; |  | ||||||
|         for (int i = 0; i < columns.Length; i++) |  | ||||||
|         { |  | ||||||
|             if (columns[i] != keyColumn) |  | ||||||
|                 continue; |  | ||||||
|             result = i; |  | ||||||
|             break; |  | ||||||
|         } |  | ||||||
|         return result; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private ReadOnlyCollection<string> GetSystemStateValues(List<string> lines, string[] columns, int keyColumnIndex) |  | ||||||
|     { |  | ||||||
|         List<string> results = new(); |  | ||||||
|         string[] values; |  | ||||||
|         string? systemState; |  | ||||||
|         string keyColumnValue; |  | ||||||
|         for (int i = 7; i < lines.Count; i++) |  | ||||||
|         { |  | ||||||
|             values = lines[i].Split('\t'); |  | ||||||
|             if (values.Length != columns.Length) |  | ||||||
|                 continue; |  | ||||||
|             keyColumnValue = values[keyColumnIndex]; |  | ||||||
|             if (string.IsNullOrEmpty(keyColumnValue)) |  | ||||||
|                 continue; |  | ||||||
|             if (!_SystemStateToNames.TryGetValue(keyColumnValue, out systemState)) |  | ||||||
|                 continue; |  | ||||||
|             if (results.Contains(systemState)) |  | ||||||
|                 continue; |  | ||||||
|             results.Add(systemState); |  | ||||||
|         } |  | ||||||
|         return new(results); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private void MoveFile(string reportFullPath) |  | ||||||
|     { |  | ||||||
|         string equipment; |  | ||||||
|         string timestamp; |  | ||||||
|         string[] columns; |  | ||||||
|         DateTime dateTime; |  | ||||||
|         List<string> lines; |  | ||||||
|         string systemState; |  | ||||||
|         int? keyColumnIndex; |  | ||||||
|         string checkFileName; |  | ||||||
|         List<string> headerLines = new(); |  | ||||||
|         ReadOnlyCollection<string> systemStateValues; |  | ||||||
|         string missingKeyDirectory = Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, "Missing-Key"); |  | ||||||
|         if (!Directory.Exists(missingKeyDirectory)) |  | ||||||
|             _ = Directory.CreateDirectory(missingKeyDirectory); |  | ||||||
|         string fileName = Path.GetFileName(reportFullPath); |  | ||||||
|         string[] segments = fileName.Split('_'); |  | ||||||
|         for (int z = 0; z < 1; z++) |  | ||||||
|         { |  | ||||||
|             if (segments.Length != 2) |  | ||||||
|                 continue; |  | ||||||
|             equipment = segments[0]; |  | ||||||
|             timestamp = segments[1].Split('.')[0]; |  | ||||||
|             if (timestamp.Length != _TimestampFormat.Length) |  | ||||||
|                 continue; |  | ||||||
|             headerLines.Clear(); |  | ||||||
|             lines = File.ReadAllLines(reportFullPath).ToList(); |  | ||||||
|             if (lines.Count < 8) |  | ||||||
|                 continue; |  | ||||||
|             for (int i = 0; i < 6; i++) |  | ||||||
|             { |  | ||||||
|                 headerLines.Add(lines[0]); |  | ||||||
|                 lines.RemoveAt(0); |  | ||||||
|             } |  | ||||||
|             if (lines[0].Length < 1 || lines[0][0] != '"' || !lines[0].StartsWith("\"Time\"")) |  | ||||||
|                 continue; |  | ||||||
|             columns = lines[0].Split('\t'); |  | ||||||
|             if (columns.Length < 3) |  | ||||||
|                 continue; |  | ||||||
|             keyColumnIndex = GetKeyColumnIndex(columns, _KeyColumn); |  | ||||||
|             if (keyColumnIndex is null) |  | ||||||
|             { |  | ||||||
|                 File.Move(reportFullPath, Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, missingKeyDirectory, fileName)); |  | ||||||
|                 continue; |  | ||||||
|             } |  | ||||||
|             systemStateValues = GetSystemStateValues(lines, columns, keyColumnIndex.Value); |  | ||||||
|             if (systemStateValues.Count == 0) |  | ||||||
|             { |  | ||||||
|                 File.Move(reportFullPath, Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, missingKeyDirectory, fileName)); |  | ||||||
|                 continue; |  | ||||||
|             } |  | ||||||
|             lines.AddRange(headerLines); |  | ||||||
|             systemState = string.Join("-", systemStateValues); |  | ||||||
|             checkFileName = Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, $"{equipment}-{timestamp}-{systemState}.pdsf"); |  | ||||||
|             File.WriteAllLines(checkFileName, lines); |  | ||||||
|             // File.Delete(reportFullPath); |  | ||||||
|             if (DateTime.TryParseExact(timestamp, _TimestampFormat, CultureInfo.InvariantCulture, DateTimeStyles.None, out dateTime)) |  | ||||||
|                 File.SetLastWriteTime(checkFileName, dateTime); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private Tuple<string, Test[], JsonElement[], List<FileInfo>> GetExtractResult(string reportFullPath, DateTime _) |  | ||||||
|     { |  | ||||||
|         Tuple<string, Test[], JsonElement[], List<FileInfo>> results; |  | ||||||
|         ProcessDataStandardFormat processDataStandardFormat = ProcessDataStandardFormat.GetProcessDataStandardFormat(reportFullPath); |  | ||||||
|         _Logistics = new Logistics(reportFullPath, processDataStandardFormat); |  | ||||||
|         SetFileParameterLotIDToLogisticsMID(); |  | ||||||
|         JsonElement[] jsonElements = ProcessDataStandardFormat.GetArray(processDataStandardFormat); |  | ||||||
|         List<Shared.Properties.IDescription> descriptions = GetDuplicatorDescriptions(jsonElements); |  | ||||||
|         Test[] tests = (from l in descriptions select (Test)l.Test).ToArray(); |  | ||||||
|         if (_IsEAFHosted && _FileConnectorConfiguration.FileScanningIntervalInSeconds > 0) |  | ||||||
|             MoveFile(reportFullPath); |  | ||||||
|         results = new Tuple<string, Test[], JsonElement[], List<FileInfo>>(string.Join(Environment.NewLine, processDataStandardFormat.Logistics[0]), tests, jsonElements, new List<FileInfo>()); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @ -1,238 +0,0 @@ | |||||||
| using Adaptation.Eaf.Management.ConfigurationData.CellAutomation; |  | ||||||
| using Adaptation.Ifx.Eaf.EquipmentConnector.File.Configuration; |  | ||||||
| using Adaptation.Shared; |  | ||||||
| using Adaptation.Shared.Duplicator; |  | ||||||
| using Adaptation.Shared.Methods; |  | ||||||
| using System; |  | ||||||
| using System.Collections.Generic; |  | ||||||
| using System.Collections.ObjectModel; |  | ||||||
| using System.Globalization; |  | ||||||
| using System.IO; |  | ||||||
| using System.Linq; |  | ||||||
| using System.Text.Json; |  | ||||||
|  |  | ||||||
| namespace Adaptation.FileHandlers.R62; |  | ||||||
|  |  | ||||||
| public class FileRead : Shared.FileRead, IFileRead |  | ||||||
| { |  | ||||||
|  |  | ||||||
|     private readonly string _KeyColumn; |  | ||||||
|     private readonly string _TimestampFormat; |  | ||||||
|     private readonly ReadOnlyDictionary<string, string> _SystemStateToNames; |  | ||||||
|  |  | ||||||
|     public FileRead(ISMTP smtp, Dictionary<string, string> fileParameter, string cellInstanceName, int? connectionCount, string cellInstanceConnectionName, FileConnectorConfiguration fileConnectorConfiguration, string equipmentTypeName, string parameterizedModelObjectDefinitionType, IList<ModelObjectParameterDefinition> modelObjectParameters, string equipmentDictionaryName, Dictionary<string, List<long>> dummyRuns, Dictionary<long, List<Shared.Metrology.WS.Results>> staticRuns, bool useCyclicalForDescription, bool isEAFHosted) : |  | ||||||
|         base(new Description(), false, smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null) |  | ||||||
|     { |  | ||||||
|         _MinFileLength = 10; |  | ||||||
|         _NullData = string.Empty; |  | ||||||
|         _Logistics = new(this); |  | ||||||
|         if (_FileParameter is null) |  | ||||||
|             throw new Exception(cellInstanceConnectionName); |  | ||||||
|         if (_ModelObjectParameterDefinitions is null) |  | ||||||
|             throw new Exception(cellInstanceConnectionName); |  | ||||||
|         if (!_IsDuplicator) |  | ||||||
|             throw new Exception(cellInstanceConnectionName); |  | ||||||
|         string[] segments; |  | ||||||
|         Dictionary<string, string> systemStateToNames = new(); |  | ||||||
|         _KeyColumn = GetPropertyValue(cellInstanceConnectionName, modelObjectParameters, "ProcessDataStandardFormat.KeyColumn"); |  | ||||||
|         _TimestampFormat = GetPropertyValue(cellInstanceConnectionName, modelObjectParameters, "ProcessDataStandardFormat.TimestampFormat"); |  | ||||||
|         ModelObjectParameterDefinition[] systemStates = GetProperties(cellInstanceConnectionName, modelObjectParameters, "ProcessDataStandardFormat.SystemState"); |  | ||||||
|         foreach (ModelObjectParameterDefinition modelObjectParameterDefinition in systemStates) |  | ||||||
|         { |  | ||||||
|             segments = modelObjectParameterDefinition.Value.Split('|'); |  | ||||||
|             if (segments.Length != 2) |  | ||||||
|                 continue; |  | ||||||
|             systemStateToNames.Add(segments[0], segments[1]); |  | ||||||
|         } |  | ||||||
|         _SystemStateToNames = new(systemStateToNames); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     void IFileRead.Move(Tuple<string, Test[], JsonElement[], List<FileInfo>> extractResults, Exception exception) |  | ||||||
|     { |  | ||||||
|         bool isErrorFile = exception is not null; |  | ||||||
|         if (!isErrorFile && !string.IsNullOrEmpty(_Logistics.ReportFullPath)) |  | ||||||
|         { |  | ||||||
|             FileInfo fileInfo = new(_Logistics.ReportFullPath); |  | ||||||
|             if (fileInfo.Exists && fileInfo.LastWriteTime < fileInfo.CreationTime) |  | ||||||
|                 File.SetLastWriteTime(_Logistics.ReportFullPath, fileInfo.CreationTime); |  | ||||||
|         } |  | ||||||
|         Move(extractResults); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     void IFileRead.WaitForThread() => WaitForThread(thread: null, threadExceptions: null); |  | ||||||
|  |  | ||||||
|     string IFileRead.GetEventDescription() |  | ||||||
|     { |  | ||||||
|         string result = _Description.GetEventDescription(); |  | ||||||
|         return result; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     List<string> IFileRead.GetHeaderNames() |  | ||||||
|     { |  | ||||||
|         List<string> results = _Description.GetHeaderNames(); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     string[] IFileRead.Move(Tuple<string, Test[], JsonElement[], List<FileInfo>> extractResults, string to, string from, string resolvedFileLocation, Exception exception) |  | ||||||
|     { |  | ||||||
|         string[] results = Move(extractResults, to, from, resolvedFileLocation, exception); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     JsonProperty[] IFileRead.GetDefault() |  | ||||||
|     { |  | ||||||
|         JsonProperty[] results = _Description.GetDefault(this, _Logistics); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     Dictionary<string, string> IFileRead.GetDisplayNamesJsonElement() |  | ||||||
|     { |  | ||||||
|         Dictionary<string, string> results = _Description.GetDisplayNamesJsonElement(this); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     List<IDescription> IFileRead.GetDescriptions(IFileRead fileRead, List<Test> tests, IProcessData processData) |  | ||||||
|     { |  | ||||||
|         List<IDescription> results = _Description.GetDescriptions(fileRead, _Logistics, tests, processData); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     Tuple<string, Test[], JsonElement[], List<FileInfo>> IFileRead.GetExtractResult(string reportFullPath, string eventName) |  | ||||||
|     { |  | ||||||
|         Tuple<string, Test[], JsonElement[], List<FileInfo>> results; |  | ||||||
|         if (string.IsNullOrEmpty(eventName)) |  | ||||||
|             throw new Exception(); |  | ||||||
|         _ReportFullPath = reportFullPath; |  | ||||||
|         DateTime dateTime = DateTime.Now; |  | ||||||
|         results = GetExtractResult(reportFullPath, dateTime); |  | ||||||
|         if (results.Item3 is null) |  | ||||||
|             results = new Tuple<string, Test[], JsonElement[], List<FileInfo>>(results.Item1, Array.Empty<Test>(), JsonSerializer.Deserialize<JsonElement[]>("[]"), results.Item4); |  | ||||||
|         if (results.Item3.Length > 0 && _IsEAFHosted) |  | ||||||
|             WritePDSF(this, results.Item3); |  | ||||||
|         UpdateLastTicksDuration(DateTime.Now.Ticks - dateTime.Ticks); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     Tuple<string, Test[], JsonElement[], List<FileInfo>> IFileRead.ReExtract() |  | ||||||
|     { |  | ||||||
|         Tuple<string, Test[], JsonElement[], List<FileInfo>> results; |  | ||||||
|         List<string> headerNames = _Description.GetHeaderNames(); |  | ||||||
|         Dictionary<string, string> keyValuePairs = _Description.GetDisplayNamesJsonElement(this); |  | ||||||
|         results = ReExtract(this, headerNames, keyValuePairs); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private static int? GetKeyColumnIndex(string[] columns, string keyColumn) |  | ||||||
|     { |  | ||||||
| #nullable enable |  | ||||||
|         int? result = null; |  | ||||||
|         for (int i = 0; i < columns.Length; i++) |  | ||||||
|         { |  | ||||||
|             if (columns[i] != keyColumn) |  | ||||||
|                 continue; |  | ||||||
|             result = i; |  | ||||||
|             break; |  | ||||||
|         } |  | ||||||
|         return result; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private ReadOnlyCollection<string> GetSystemStateValues(List<string> lines, string[] columns, int keyColumnIndex) |  | ||||||
|     { |  | ||||||
|         List<string> results = new(); |  | ||||||
|         string[] values; |  | ||||||
|         string? systemState; |  | ||||||
|         string keyColumnValue; |  | ||||||
|         for (int i = 7; i < lines.Count; i++) |  | ||||||
|         { |  | ||||||
|             values = lines[i].Split('\t'); |  | ||||||
|             if (values.Length != columns.Length) |  | ||||||
|                 continue; |  | ||||||
|             keyColumnValue = values[keyColumnIndex]; |  | ||||||
|             if (string.IsNullOrEmpty(keyColumnValue)) |  | ||||||
|                 continue; |  | ||||||
|             if (!_SystemStateToNames.TryGetValue(keyColumnValue, out systemState)) |  | ||||||
|                 continue; |  | ||||||
|             if (results.Contains(systemState)) |  | ||||||
|                 continue; |  | ||||||
|             results.Add(systemState); |  | ||||||
|         } |  | ||||||
|         return new(results); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private void MoveFile(string reportFullPath) |  | ||||||
|     { |  | ||||||
|         string equipment; |  | ||||||
|         string timestamp; |  | ||||||
|         string[] columns; |  | ||||||
|         DateTime dateTime; |  | ||||||
|         List<string> lines; |  | ||||||
|         string systemState; |  | ||||||
|         int? keyColumnIndex; |  | ||||||
|         string checkFileName; |  | ||||||
|         List<string> headerLines = new(); |  | ||||||
|         ReadOnlyCollection<string> systemStateValues; |  | ||||||
|         string missingKeyDirectory = Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, "Missing-Key"); |  | ||||||
|         if (!Directory.Exists(missingKeyDirectory)) |  | ||||||
|             _ = Directory.CreateDirectory(missingKeyDirectory); |  | ||||||
|         string fileName = Path.GetFileName(reportFullPath); |  | ||||||
|         string[] segments = fileName.Split('_'); |  | ||||||
|         for (int z = 0; z < 1; z++) |  | ||||||
|         { |  | ||||||
|             if (segments.Length != 2) |  | ||||||
|                 continue; |  | ||||||
|             equipment = segments[0]; |  | ||||||
|             timestamp = segments[1].Split('.')[0]; |  | ||||||
|             if (timestamp.Length != _TimestampFormat.Length) |  | ||||||
|                 continue; |  | ||||||
|             headerLines.Clear(); |  | ||||||
|             lines = File.ReadAllLines(reportFullPath).ToList(); |  | ||||||
|             if (lines.Count < 8) |  | ||||||
|                 continue; |  | ||||||
|             for (int i = 0; i < 6; i++) |  | ||||||
|             { |  | ||||||
|                 headerLines.Add(lines[0]); |  | ||||||
|                 lines.RemoveAt(0); |  | ||||||
|             } |  | ||||||
|             if (lines[0].Length < 1 || lines[0][0] != '"' || !lines[0].StartsWith("\"Time\"")) |  | ||||||
|                 continue; |  | ||||||
|             columns = lines[0].Split('\t'); |  | ||||||
|             if (columns.Length < 3) |  | ||||||
|                 continue; |  | ||||||
|             keyColumnIndex = GetKeyColumnIndex(columns, _KeyColumn); |  | ||||||
|             if (keyColumnIndex is null) |  | ||||||
|             { |  | ||||||
|                 File.Move(reportFullPath, Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, missingKeyDirectory, fileName)); |  | ||||||
|                 continue; |  | ||||||
|             } |  | ||||||
|             systemStateValues = GetSystemStateValues(lines, columns, keyColumnIndex.Value); |  | ||||||
|             if (systemStateValues.Count == 0) |  | ||||||
|             { |  | ||||||
|                 File.Move(reportFullPath, Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, missingKeyDirectory, fileName)); |  | ||||||
|                 continue; |  | ||||||
|             } |  | ||||||
|             lines.AddRange(headerLines); |  | ||||||
|             systemState = string.Join("-", systemStateValues); |  | ||||||
|             checkFileName = Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, $"{equipment}-{timestamp}-{systemState}.pdsf"); |  | ||||||
|             File.WriteAllLines(checkFileName, lines); |  | ||||||
|             // File.Delete(reportFullPath); |  | ||||||
|             if (DateTime.TryParseExact(timestamp, _TimestampFormat, CultureInfo.InvariantCulture, DateTimeStyles.None, out dateTime)) |  | ||||||
|                 File.SetLastWriteTime(checkFileName, dateTime); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private Tuple<string, Test[], JsonElement[], List<FileInfo>> GetExtractResult(string reportFullPath, DateTime _) |  | ||||||
|     { |  | ||||||
|         Tuple<string, Test[], JsonElement[], List<FileInfo>> results; |  | ||||||
|         ProcessDataStandardFormat processDataStandardFormat = ProcessDataStandardFormat.GetProcessDataStandardFormat(reportFullPath); |  | ||||||
|         _Logistics = new Logistics(reportFullPath, processDataStandardFormat); |  | ||||||
|         SetFileParameterLotIDToLogisticsMID(); |  | ||||||
|         JsonElement[] jsonElements = ProcessDataStandardFormat.GetArray(processDataStandardFormat); |  | ||||||
|         List<Shared.Properties.IDescription> descriptions = GetDuplicatorDescriptions(jsonElements); |  | ||||||
|         Test[] tests = (from l in descriptions select (Test)l.Test).ToArray(); |  | ||||||
|         if (_IsEAFHosted && _FileConnectorConfiguration.FileScanningIntervalInSeconds > 0) |  | ||||||
|             MoveFile(reportFullPath); |  | ||||||
|         results = new Tuple<string, Test[], JsonElement[], List<FileInfo>>(string.Join(Environment.NewLine, processDataStandardFormat.Logistics[0]), tests, jsonElements, new List<FileInfo>()); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @ -1,238 +0,0 @@ | |||||||
| using Adaptation.Eaf.Management.ConfigurationData.CellAutomation; |  | ||||||
| using Adaptation.Ifx.Eaf.EquipmentConnector.File.Configuration; |  | ||||||
| using Adaptation.Shared; |  | ||||||
| using Adaptation.Shared.Duplicator; |  | ||||||
| using Adaptation.Shared.Methods; |  | ||||||
| using System; |  | ||||||
| using System.Collections.Generic; |  | ||||||
| using System.Collections.ObjectModel; |  | ||||||
| using System.Globalization; |  | ||||||
| using System.IO; |  | ||||||
| using System.Linq; |  | ||||||
| using System.Text.Json; |  | ||||||
|  |  | ||||||
| namespace Adaptation.FileHandlers.R65; |  | ||||||
|  |  | ||||||
| public class FileRead : Shared.FileRead, IFileRead |  | ||||||
| { |  | ||||||
|  |  | ||||||
|     private readonly string _KeyColumn; |  | ||||||
|     private readonly string _TimestampFormat; |  | ||||||
|     private readonly ReadOnlyDictionary<string, string> _SystemStateToNames; |  | ||||||
|  |  | ||||||
|     public FileRead(ISMTP smtp, Dictionary<string, string> fileParameter, string cellInstanceName, int? connectionCount, string cellInstanceConnectionName, FileConnectorConfiguration fileConnectorConfiguration, string equipmentTypeName, string parameterizedModelObjectDefinitionType, IList<ModelObjectParameterDefinition> modelObjectParameters, string equipmentDictionaryName, Dictionary<string, List<long>> dummyRuns, Dictionary<long, List<Shared.Metrology.WS.Results>> staticRuns, bool useCyclicalForDescription, bool isEAFHosted) : |  | ||||||
|         base(new Description(), false, smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null) |  | ||||||
|     { |  | ||||||
|         _MinFileLength = 10; |  | ||||||
|         _NullData = string.Empty; |  | ||||||
|         _Logistics = new(this); |  | ||||||
|         if (_FileParameter is null) |  | ||||||
|             throw new Exception(cellInstanceConnectionName); |  | ||||||
|         if (_ModelObjectParameterDefinitions is null) |  | ||||||
|             throw new Exception(cellInstanceConnectionName); |  | ||||||
|         if (!_IsDuplicator) |  | ||||||
|             throw new Exception(cellInstanceConnectionName); |  | ||||||
|         string[] segments; |  | ||||||
|         Dictionary<string, string> systemStateToNames = new(); |  | ||||||
|         _KeyColumn = GetPropertyValue(cellInstanceConnectionName, modelObjectParameters, "ProcessDataStandardFormat.KeyColumn"); |  | ||||||
|         _TimestampFormat = GetPropertyValue(cellInstanceConnectionName, modelObjectParameters, "ProcessDataStandardFormat.TimestampFormat"); |  | ||||||
|         ModelObjectParameterDefinition[] systemStates = GetProperties(cellInstanceConnectionName, modelObjectParameters, "ProcessDataStandardFormat.SystemState"); |  | ||||||
|         foreach (ModelObjectParameterDefinition modelObjectParameterDefinition in systemStates) |  | ||||||
|         { |  | ||||||
|             segments = modelObjectParameterDefinition.Value.Split('|'); |  | ||||||
|             if (segments.Length != 2) |  | ||||||
|                 continue; |  | ||||||
|             systemStateToNames.Add(segments[0], segments[1]); |  | ||||||
|         } |  | ||||||
|         _SystemStateToNames = new(systemStateToNames); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     void IFileRead.Move(Tuple<string, Test[], JsonElement[], List<FileInfo>> extractResults, Exception exception) |  | ||||||
|     { |  | ||||||
|         bool isErrorFile = exception is not null; |  | ||||||
|         if (!isErrorFile && !string.IsNullOrEmpty(_Logistics.ReportFullPath)) |  | ||||||
|         { |  | ||||||
|             FileInfo fileInfo = new(_Logistics.ReportFullPath); |  | ||||||
|             if (fileInfo.Exists && fileInfo.LastWriteTime < fileInfo.CreationTime) |  | ||||||
|                 File.SetLastWriteTime(_Logistics.ReportFullPath, fileInfo.CreationTime); |  | ||||||
|         } |  | ||||||
|         Move(extractResults); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     void IFileRead.WaitForThread() => WaitForThread(thread: null, threadExceptions: null); |  | ||||||
|  |  | ||||||
|     string IFileRead.GetEventDescription() |  | ||||||
|     { |  | ||||||
|         string result = _Description.GetEventDescription(); |  | ||||||
|         return result; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     List<string> IFileRead.GetHeaderNames() |  | ||||||
|     { |  | ||||||
|         List<string> results = _Description.GetHeaderNames(); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     string[] IFileRead.Move(Tuple<string, Test[], JsonElement[], List<FileInfo>> extractResults, string to, string from, string resolvedFileLocation, Exception exception) |  | ||||||
|     { |  | ||||||
|         string[] results = Move(extractResults, to, from, resolvedFileLocation, exception); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     JsonProperty[] IFileRead.GetDefault() |  | ||||||
|     { |  | ||||||
|         JsonProperty[] results = _Description.GetDefault(this, _Logistics); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     Dictionary<string, string> IFileRead.GetDisplayNamesJsonElement() |  | ||||||
|     { |  | ||||||
|         Dictionary<string, string> results = _Description.GetDisplayNamesJsonElement(this); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     List<IDescription> IFileRead.GetDescriptions(IFileRead fileRead, List<Test> tests, IProcessData processData) |  | ||||||
|     { |  | ||||||
|         List<IDescription> results = _Description.GetDescriptions(fileRead, _Logistics, tests, processData); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     Tuple<string, Test[], JsonElement[], List<FileInfo>> IFileRead.GetExtractResult(string reportFullPath, string eventName) |  | ||||||
|     { |  | ||||||
|         Tuple<string, Test[], JsonElement[], List<FileInfo>> results; |  | ||||||
|         if (string.IsNullOrEmpty(eventName)) |  | ||||||
|             throw new Exception(); |  | ||||||
|         _ReportFullPath = reportFullPath; |  | ||||||
|         DateTime dateTime = DateTime.Now; |  | ||||||
|         results = GetExtractResult(reportFullPath, dateTime); |  | ||||||
|         if (results.Item3 is null) |  | ||||||
|             results = new Tuple<string, Test[], JsonElement[], List<FileInfo>>(results.Item1, Array.Empty<Test>(), JsonSerializer.Deserialize<JsonElement[]>("[]"), results.Item4); |  | ||||||
|         if (results.Item3.Length > 0 && _IsEAFHosted) |  | ||||||
|             WritePDSF(this, results.Item3); |  | ||||||
|         UpdateLastTicksDuration(DateTime.Now.Ticks - dateTime.Ticks); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     Tuple<string, Test[], JsonElement[], List<FileInfo>> IFileRead.ReExtract() |  | ||||||
|     { |  | ||||||
|         Tuple<string, Test[], JsonElement[], List<FileInfo>> results; |  | ||||||
|         List<string> headerNames = _Description.GetHeaderNames(); |  | ||||||
|         Dictionary<string, string> keyValuePairs = _Description.GetDisplayNamesJsonElement(this); |  | ||||||
|         results = ReExtract(this, headerNames, keyValuePairs); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private static int? GetKeyColumnIndex(string[] columns, string keyColumn) |  | ||||||
|     { |  | ||||||
| #nullable enable |  | ||||||
|         int? result = null; |  | ||||||
|         for (int i = 0; i < columns.Length; i++) |  | ||||||
|         { |  | ||||||
|             if (columns[i] != keyColumn) |  | ||||||
|                 continue; |  | ||||||
|             result = i; |  | ||||||
|             break; |  | ||||||
|         } |  | ||||||
|         return result; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private ReadOnlyCollection<string> GetSystemStateValues(List<string> lines, string[] columns, int keyColumnIndex) |  | ||||||
|     { |  | ||||||
|         List<string> results = new(); |  | ||||||
|         string[] values; |  | ||||||
|         string? systemState; |  | ||||||
|         string keyColumnValue; |  | ||||||
|         for (int i = 7; i < lines.Count; i++) |  | ||||||
|         { |  | ||||||
|             values = lines[i].Split('\t'); |  | ||||||
|             if (values.Length != columns.Length) |  | ||||||
|                 continue; |  | ||||||
|             keyColumnValue = values[keyColumnIndex]; |  | ||||||
|             if (string.IsNullOrEmpty(keyColumnValue)) |  | ||||||
|                 continue; |  | ||||||
|             if (!_SystemStateToNames.TryGetValue(keyColumnValue, out systemState)) |  | ||||||
|                 continue; |  | ||||||
|             if (results.Contains(systemState)) |  | ||||||
|                 continue; |  | ||||||
|             results.Add(systemState); |  | ||||||
|         } |  | ||||||
|         return new(results); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private void MoveFile(string reportFullPath) |  | ||||||
|     { |  | ||||||
|         string equipment; |  | ||||||
|         string timestamp; |  | ||||||
|         string[] columns; |  | ||||||
|         DateTime dateTime; |  | ||||||
|         List<string> lines; |  | ||||||
|         string systemState; |  | ||||||
|         int? keyColumnIndex; |  | ||||||
|         string checkFileName; |  | ||||||
|         List<string> headerLines = new(); |  | ||||||
|         ReadOnlyCollection<string> systemStateValues; |  | ||||||
|         string missingKeyDirectory = Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, "Missing-Key"); |  | ||||||
|         if (!Directory.Exists(missingKeyDirectory)) |  | ||||||
|             _ = Directory.CreateDirectory(missingKeyDirectory); |  | ||||||
|         string fileName = Path.GetFileName(reportFullPath); |  | ||||||
|         string[] segments = fileName.Split('_'); |  | ||||||
|         for (int z = 0; z < 1; z++) |  | ||||||
|         { |  | ||||||
|             if (segments.Length != 2) |  | ||||||
|                 continue; |  | ||||||
|             equipment = segments[0]; |  | ||||||
|             timestamp = segments[1].Split('.')[0]; |  | ||||||
|             if (timestamp.Length != _TimestampFormat.Length) |  | ||||||
|                 continue; |  | ||||||
|             headerLines.Clear(); |  | ||||||
|             lines = File.ReadAllLines(reportFullPath).ToList(); |  | ||||||
|             if (lines.Count < 8) |  | ||||||
|                 continue; |  | ||||||
|             for (int i = 0; i < 6; i++) |  | ||||||
|             { |  | ||||||
|                 headerLines.Add(lines[0]); |  | ||||||
|                 lines.RemoveAt(0); |  | ||||||
|             } |  | ||||||
|             if (lines[0].Length < 1 || lines[0][0] != '"' || !lines[0].StartsWith("\"Time\"")) |  | ||||||
|                 continue; |  | ||||||
|             columns = lines[0].Split('\t'); |  | ||||||
|             if (columns.Length < 3) |  | ||||||
|                 continue; |  | ||||||
|             keyColumnIndex = GetKeyColumnIndex(columns, _KeyColumn); |  | ||||||
|             if (keyColumnIndex is null) |  | ||||||
|             { |  | ||||||
|                 File.Move(reportFullPath, Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, missingKeyDirectory, fileName)); |  | ||||||
|                 continue; |  | ||||||
|             } |  | ||||||
|             systemStateValues = GetSystemStateValues(lines, columns, keyColumnIndex.Value); |  | ||||||
|             if (systemStateValues.Count == 0) |  | ||||||
|             { |  | ||||||
|                 File.Move(reportFullPath, Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, missingKeyDirectory, fileName)); |  | ||||||
|                 continue; |  | ||||||
|             } |  | ||||||
|             lines.AddRange(headerLines); |  | ||||||
|             systemState = string.Join("-", systemStateValues); |  | ||||||
|             checkFileName = Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, $"{equipment}-{timestamp}-{systemState}.pdsf"); |  | ||||||
|             File.WriteAllLines(checkFileName, lines); |  | ||||||
|             // File.Delete(reportFullPath); |  | ||||||
|             if (DateTime.TryParseExact(timestamp, _TimestampFormat, CultureInfo.InvariantCulture, DateTimeStyles.None, out dateTime)) |  | ||||||
|                 File.SetLastWriteTime(checkFileName, dateTime); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private Tuple<string, Test[], JsonElement[], List<FileInfo>> GetExtractResult(string reportFullPath, DateTime _) |  | ||||||
|     { |  | ||||||
|         Tuple<string, Test[], JsonElement[], List<FileInfo>> results; |  | ||||||
|         ProcessDataStandardFormat processDataStandardFormat = ProcessDataStandardFormat.GetProcessDataStandardFormat(reportFullPath); |  | ||||||
|         _Logistics = new Logistics(reportFullPath, processDataStandardFormat); |  | ||||||
|         SetFileParameterLotIDToLogisticsMID(); |  | ||||||
|         JsonElement[] jsonElements = ProcessDataStandardFormat.GetArray(processDataStandardFormat); |  | ||||||
|         List<Shared.Properties.IDescription> descriptions = GetDuplicatorDescriptions(jsonElements); |  | ||||||
|         Test[] tests = (from l in descriptions select (Test)l.Test).ToArray(); |  | ||||||
|         if (_IsEAFHosted && _FileConnectorConfiguration.FileScanningIntervalInSeconds > 0) |  | ||||||
|             MoveFile(reportFullPath); |  | ||||||
|         results = new Tuple<string, Test[], JsonElement[], List<FileInfo>>(string.Join(Environment.NewLine, processDataStandardFormat.Logistics[0]), tests, jsonElements, new List<FileInfo>()); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } |  | ||||||
							
								
								
									
										238
									
								
								Adaptation/FileHandlers/R7/FileRead.cs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										238
									
								
								Adaptation/FileHandlers/R7/FileRead.cs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,238 @@ | |||||||
|  | using Adaptation.Eaf.Management.ConfigurationData.CellAutomation; | ||||||
|  | using Adaptation.Ifx.Eaf.EquipmentConnector.File.Configuration; | ||||||
|  | using Adaptation.Shared; | ||||||
|  | using Adaptation.Shared.Duplicator; | ||||||
|  | using Adaptation.Shared.Methods; | ||||||
|  | using System; | ||||||
|  | using System.Collections.Generic; | ||||||
|  | using System.Collections.ObjectModel; | ||||||
|  | using System.Globalization; | ||||||
|  | using System.IO; | ||||||
|  | using System.Linq; | ||||||
|  | using System.Text.Json; | ||||||
|  |  | ||||||
|  | namespace Adaptation.FileHandlers.R7; | ||||||
|  |  | ||||||
|  | public class FileRead : Shared.FileRead, IFileRead | ||||||
|  | { | ||||||
|  |  | ||||||
|  |     private readonly string _KeyColumn; | ||||||
|  |     private readonly string _TimestampFormat; | ||||||
|  |     private readonly ReadOnlyDictionary<string, string> _SystemStateToNames; | ||||||
|  |  | ||||||
|  |     public FileRead(ISMTP smtp, Dictionary<string, string> fileParameter, string cellInstanceName, int? connectionCount, string cellInstanceConnectionName, FileConnectorConfiguration fileConnectorConfiguration, string equipmentTypeName, string parameterizedModelObjectDefinitionType, IList<ModelObjectParameterDefinition> modelObjectParameters, string equipmentDictionaryName, Dictionary<string, List<long>> dummyRuns, Dictionary<long, List<Shared.Metrology.WS.Results>> staticRuns, bool useCyclicalForDescription, bool isEAFHosted) : | ||||||
|  |         base(new Description(), false, smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null) | ||||||
|  |     { | ||||||
|  |         _MinFileLength = 10; | ||||||
|  |         _NullData = string.Empty; | ||||||
|  |         _Logistics = new(this); | ||||||
|  |         if (_FileParameter is null) | ||||||
|  |             throw new Exception(cellInstanceConnectionName); | ||||||
|  |         if (_ModelObjectParameterDefinitions is null) | ||||||
|  |             throw new Exception(cellInstanceConnectionName); | ||||||
|  |         if (!_IsDuplicator) | ||||||
|  |             throw new Exception(cellInstanceConnectionName); | ||||||
|  |         string[] segments; | ||||||
|  |         Dictionary<string, string> systemStateToNames = new(); | ||||||
|  |         _KeyColumn = GetPropertyValue(cellInstanceConnectionName, modelObjectParameters, "ProcessDataStandardFormat.KeyColumn"); | ||||||
|  |         _TimestampFormat = GetPropertyValue(cellInstanceConnectionName, modelObjectParameters, "ProcessDataStandardFormat.TimestampFormat"); | ||||||
|  |         ModelObjectParameterDefinition[] systemStates = GetProperties(cellInstanceConnectionName, modelObjectParameters, "ProcessDataStandardFormat.SystemState"); | ||||||
|  |         foreach (ModelObjectParameterDefinition modelObjectParameterDefinition in systemStates) | ||||||
|  |         { | ||||||
|  |             segments = modelObjectParameterDefinition.Value.Split('|'); | ||||||
|  |             if (segments.Length != 2) | ||||||
|  |                 continue; | ||||||
|  |             systemStateToNames.Add(segments[0], segments[1]); | ||||||
|  |         } | ||||||
|  |         _SystemStateToNames = new(systemStateToNames); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     void IFileRead.Move(Tuple<string, Test[], JsonElement[], List<FileInfo>> extractResults, Exception exception) | ||||||
|  |     { | ||||||
|  |         bool isErrorFile = exception is not null; | ||||||
|  |         if (!isErrorFile && !string.IsNullOrEmpty(_Logistics.ReportFullPath)) | ||||||
|  |         { | ||||||
|  |             FileInfo fileInfo = new(_Logistics.ReportFullPath); | ||||||
|  |             if (fileInfo.Exists && fileInfo.LastWriteTime < fileInfo.CreationTime) | ||||||
|  |                 File.SetLastWriteTime(_Logistics.ReportFullPath, fileInfo.CreationTime); | ||||||
|  |         } | ||||||
|  |         Move(extractResults); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     void IFileRead.WaitForThread() => WaitForThread(thread: null, threadExceptions: null); | ||||||
|  |  | ||||||
|  |     string IFileRead.GetEventDescription() | ||||||
|  |     { | ||||||
|  |         string result = _Description.GetEventDescription(); | ||||||
|  |         return result; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     List<string> IFileRead.GetHeaderNames() | ||||||
|  |     { | ||||||
|  |         List<string> results = _Description.GetHeaderNames(); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     string[] IFileRead.Move(Tuple<string, Test[], JsonElement[], List<FileInfo>> extractResults, string to, string from, string resolvedFileLocation, Exception exception) | ||||||
|  |     { | ||||||
|  |         string[] results = Move(extractResults, to, from, resolvedFileLocation, exception); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     JsonProperty[] IFileRead.GetDefault() | ||||||
|  |     { | ||||||
|  |         JsonProperty[] results = _Description.GetDefault(this, _Logistics); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     Dictionary<string, string> IFileRead.GetDisplayNamesJsonElement() | ||||||
|  |     { | ||||||
|  |         Dictionary<string, string> results = _Description.GetDisplayNamesJsonElement(this); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     List<IDescription> IFileRead.GetDescriptions(IFileRead fileRead, List<Test> tests, IProcessData processData) | ||||||
|  |     { | ||||||
|  |         List<IDescription> results = _Description.GetDescriptions(fileRead, _Logistics, tests, processData); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     Tuple<string, Test[], JsonElement[], List<FileInfo>> IFileRead.GetExtractResult(string reportFullPath, string eventName) | ||||||
|  |     { | ||||||
|  |         Tuple<string, Test[], JsonElement[], List<FileInfo>> results; | ||||||
|  |         if (string.IsNullOrEmpty(eventName)) | ||||||
|  |             throw new Exception(); | ||||||
|  |         _ReportFullPath = reportFullPath; | ||||||
|  |         DateTime dateTime = DateTime.Now; | ||||||
|  |         results = GetExtractResult(reportFullPath, dateTime); | ||||||
|  |         if (results.Item3 is null) | ||||||
|  |             results = new Tuple<string, Test[], JsonElement[], List<FileInfo>>(results.Item1, Array.Empty<Test>(), JsonSerializer.Deserialize<JsonElement[]>("[]"), results.Item4); | ||||||
|  |         if (results.Item3.Length > 0 && _IsEAFHosted) | ||||||
|  |             WritePDSF(this, results.Item3); | ||||||
|  |         UpdateLastTicksDuration(DateTime.Now.Ticks - dateTime.Ticks); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     Tuple<string, Test[], JsonElement[], List<FileInfo>> IFileRead.ReExtract() | ||||||
|  |     { | ||||||
|  |         Tuple<string, Test[], JsonElement[], List<FileInfo>> results; | ||||||
|  |         List<string> headerNames = _Description.GetHeaderNames(); | ||||||
|  |         Dictionary<string, string> keyValuePairs = _Description.GetDisplayNamesJsonElement(this); | ||||||
|  |         results = ReExtract(this, headerNames, keyValuePairs); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private static int? GetKeyColumnIndex(string[] columns, string keyColumn) | ||||||
|  |     { | ||||||
|  | #nullable enable | ||||||
|  |         int? result = null; | ||||||
|  |         for (int i = 0; i < columns.Length; i++) | ||||||
|  |         { | ||||||
|  |             if (columns[i] != keyColumn) | ||||||
|  |                 continue; | ||||||
|  |             result = i; | ||||||
|  |             break; | ||||||
|  |         } | ||||||
|  |         return result; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private ReadOnlyCollection<string> GetSystemStateValues(List<string> lines, string[] columns, int keyColumnIndex) | ||||||
|  |     { | ||||||
|  |         List<string> results = new(); | ||||||
|  |         string[] values; | ||||||
|  |         string? systemState; | ||||||
|  |         string keyColumnValue; | ||||||
|  |         for (int i = 7; i < lines.Count; i++) | ||||||
|  |         { | ||||||
|  |             values = lines[i].Split('\t'); | ||||||
|  |             if (values.Length != columns.Length) | ||||||
|  |                 continue; | ||||||
|  |             keyColumnValue = values[keyColumnIndex]; | ||||||
|  |             if (string.IsNullOrEmpty(keyColumnValue)) | ||||||
|  |                 continue; | ||||||
|  |             if (!_SystemStateToNames.TryGetValue(keyColumnValue, out systemState)) | ||||||
|  |                 continue; | ||||||
|  |             if (results.Contains(systemState)) | ||||||
|  |                 continue; | ||||||
|  |             results.Add(systemState); | ||||||
|  |         } | ||||||
|  |         return new(results); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private void CopyFile(string reportFullPath) | ||||||
|  |     { | ||||||
|  |         string equipment; | ||||||
|  |         string timestamp; | ||||||
|  |         string[] columns; | ||||||
|  |         DateTime dateTime; | ||||||
|  |         List<string> lines; | ||||||
|  |         string systemState; | ||||||
|  |         int? keyColumnIndex; | ||||||
|  |         string checkFileName; | ||||||
|  |         List<string> headerLines = new(); | ||||||
|  |         ReadOnlyCollection<string> systemStateValues; | ||||||
|  |         string missingKeyDirectory = Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, "Missing-Key"); | ||||||
|  |         if (!Directory.Exists(missingKeyDirectory)) | ||||||
|  |             _ = Directory.CreateDirectory(missingKeyDirectory); | ||||||
|  |         string fileName = Path.GetFileName(reportFullPath); | ||||||
|  |         string[] segments = fileName.Split('_'); | ||||||
|  |         for (int z = 0; z < 1; z++) | ||||||
|  |         { | ||||||
|  |             if (segments.Length != 2) | ||||||
|  |                 continue; | ||||||
|  |             equipment = segments[0]; | ||||||
|  |             timestamp = segments[1].Split('.')[0]; | ||||||
|  |             if (timestamp.Length != _TimestampFormat.Length) | ||||||
|  |                 continue; | ||||||
|  |             headerLines.Clear(); | ||||||
|  |             lines = File.ReadAllLines(reportFullPath).ToList(); | ||||||
|  |             if (lines.Count < 8) | ||||||
|  |                 continue; | ||||||
|  |             for (int i = 0; i < 6; i++) | ||||||
|  |             { | ||||||
|  |                 headerLines.Add(lines[0]); | ||||||
|  |                 lines.RemoveAt(0); | ||||||
|  |             } | ||||||
|  |             if (lines[0].Length < 1 || lines[0][0] != '"' || !lines[0].StartsWith("\"Time\"")) | ||||||
|  |                 continue; | ||||||
|  |             columns = lines[0].Split('\t'); | ||||||
|  |             if (columns.Length < 3) | ||||||
|  |                 continue; | ||||||
|  |             keyColumnIndex = GetKeyColumnIndex(columns, _KeyColumn); | ||||||
|  |             if (keyColumnIndex is null) | ||||||
|  |             { | ||||||
|  |                 File.Copy(reportFullPath, Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, missingKeyDirectory, fileName)); | ||||||
|  |                 continue; | ||||||
|  |             } | ||||||
|  |             systemStateValues = GetSystemStateValues(lines, columns, keyColumnIndex.Value); | ||||||
|  |             if (systemStateValues.Count == 0) | ||||||
|  |             { | ||||||
|  |                 File.Copy(reportFullPath, Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, missingKeyDirectory, fileName)); | ||||||
|  |                 continue; | ||||||
|  |             } | ||||||
|  |             lines.AddRange(headerLines); | ||||||
|  |             systemState = string.Join("-", systemStateValues); | ||||||
|  |             checkFileName = Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, $"{equipment}-{timestamp}-{systemState}.pdsf"); | ||||||
|  |             File.WriteAllLines(checkFileName, lines); | ||||||
|  |             // File.Delete(reportFullPath); | ||||||
|  |             if (DateTime.TryParseExact(timestamp, _TimestampFormat, CultureInfo.InvariantCulture, DateTimeStyles.None, out dateTime)) | ||||||
|  |                 File.SetLastWriteTime(checkFileName, dateTime); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private Tuple<string, Test[], JsonElement[], List<FileInfo>> GetExtractResult(string reportFullPath, DateTime _) | ||||||
|  |     { | ||||||
|  |         Tuple<string, Test[], JsonElement[], List<FileInfo>> results; | ||||||
|  |         ProcessDataStandardFormat processDataStandardFormat = ProcessDataStandardFormat.GetProcessDataStandardFormat(reportFullPath); | ||||||
|  |         _Logistics = new Logistics(reportFullPath, processDataStandardFormat); | ||||||
|  |         SetFileParameterLotIDToLogisticsMID(); | ||||||
|  |         JsonElement[] jsonElements = ProcessDataStandardFormat.GetArray(processDataStandardFormat); | ||||||
|  |         List<Shared.Properties.IDescription> descriptions = GetDuplicatorDescriptions(jsonElements); | ||||||
|  |         Test[] tests = (from l in descriptions select (Test)l.Test).ToArray(); | ||||||
|  |         if (_IsEAFHosted && _FileConnectorConfiguration.FileScanningIntervalInSeconds > 0) | ||||||
|  |             CopyFile(reportFullPath); | ||||||
|  |         results = new Tuple<string, Test[], JsonElement[], List<FileInfo>>(string.Join(Environment.NewLine, processDataStandardFormat.Logistics), tests, jsonElements, new List<FileInfo>()); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  | } | ||||||
| @ -1,238 +0,0 @@ | |||||||
| using Adaptation.Eaf.Management.ConfigurationData.CellAutomation; |  | ||||||
| using Adaptation.Ifx.Eaf.EquipmentConnector.File.Configuration; |  | ||||||
| using Adaptation.Shared; |  | ||||||
| using Adaptation.Shared.Duplicator; |  | ||||||
| using Adaptation.Shared.Methods; |  | ||||||
| using System; |  | ||||||
| using System.Collections.Generic; |  | ||||||
| using System.Collections.ObjectModel; |  | ||||||
| using System.Globalization; |  | ||||||
| using System.IO; |  | ||||||
| using System.Linq; |  | ||||||
| using System.Text.Json; |  | ||||||
|  |  | ||||||
| namespace Adaptation.FileHandlers.R75; |  | ||||||
|  |  | ||||||
| public class FileRead : Shared.FileRead, IFileRead |  | ||||||
| { |  | ||||||
|  |  | ||||||
|     private readonly string _KeyColumn; |  | ||||||
|     private readonly string _TimestampFormat; |  | ||||||
|     private readonly ReadOnlyDictionary<string, string> _SystemStateToNames; |  | ||||||
|  |  | ||||||
|     public FileRead(ISMTP smtp, Dictionary<string, string> fileParameter, string cellInstanceName, int? connectionCount, string cellInstanceConnectionName, FileConnectorConfiguration fileConnectorConfiguration, string equipmentTypeName, string parameterizedModelObjectDefinitionType, IList<ModelObjectParameterDefinition> modelObjectParameters, string equipmentDictionaryName, Dictionary<string, List<long>> dummyRuns, Dictionary<long, List<Shared.Metrology.WS.Results>> staticRuns, bool useCyclicalForDescription, bool isEAFHosted) : |  | ||||||
|         base(new Description(), false, smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null) |  | ||||||
|     { |  | ||||||
|         _MinFileLength = 10; |  | ||||||
|         _NullData = string.Empty; |  | ||||||
|         _Logistics = new(this); |  | ||||||
|         if (_FileParameter is null) |  | ||||||
|             throw new Exception(cellInstanceConnectionName); |  | ||||||
|         if (_ModelObjectParameterDefinitions is null) |  | ||||||
|             throw new Exception(cellInstanceConnectionName); |  | ||||||
|         if (!_IsDuplicator) |  | ||||||
|             throw new Exception(cellInstanceConnectionName); |  | ||||||
|         string[] segments; |  | ||||||
|         Dictionary<string, string> systemStateToNames = new(); |  | ||||||
|         _KeyColumn = GetPropertyValue(cellInstanceConnectionName, modelObjectParameters, "ProcessDataStandardFormat.KeyColumn"); |  | ||||||
|         _TimestampFormat = GetPropertyValue(cellInstanceConnectionName, modelObjectParameters, "ProcessDataStandardFormat.TimestampFormat"); |  | ||||||
|         ModelObjectParameterDefinition[] systemStates = GetProperties(cellInstanceConnectionName, modelObjectParameters, "ProcessDataStandardFormat.SystemState"); |  | ||||||
|         foreach (ModelObjectParameterDefinition modelObjectParameterDefinition in systemStates) |  | ||||||
|         { |  | ||||||
|             segments = modelObjectParameterDefinition.Value.Split('|'); |  | ||||||
|             if (segments.Length != 2) |  | ||||||
|                 continue; |  | ||||||
|             systemStateToNames.Add(segments[0], segments[1]); |  | ||||||
|         } |  | ||||||
|         _SystemStateToNames = new(systemStateToNames); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     void IFileRead.Move(Tuple<string, Test[], JsonElement[], List<FileInfo>> extractResults, Exception exception) |  | ||||||
|     { |  | ||||||
|         bool isErrorFile = exception is not null; |  | ||||||
|         if (!isErrorFile && !string.IsNullOrEmpty(_Logistics.ReportFullPath)) |  | ||||||
|         { |  | ||||||
|             FileInfo fileInfo = new(_Logistics.ReportFullPath); |  | ||||||
|             if (fileInfo.Exists && fileInfo.LastWriteTime < fileInfo.CreationTime) |  | ||||||
|                 File.SetLastWriteTime(_Logistics.ReportFullPath, fileInfo.CreationTime); |  | ||||||
|         } |  | ||||||
|         Move(extractResults); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     void IFileRead.WaitForThread() => WaitForThread(thread: null, threadExceptions: null); |  | ||||||
|  |  | ||||||
|     string IFileRead.GetEventDescription() |  | ||||||
|     { |  | ||||||
|         string result = _Description.GetEventDescription(); |  | ||||||
|         return result; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     List<string> IFileRead.GetHeaderNames() |  | ||||||
|     { |  | ||||||
|         List<string> results = _Description.GetHeaderNames(); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     string[] IFileRead.Move(Tuple<string, Test[], JsonElement[], List<FileInfo>> extractResults, string to, string from, string resolvedFileLocation, Exception exception) |  | ||||||
|     { |  | ||||||
|         string[] results = Move(extractResults, to, from, resolvedFileLocation, exception); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     JsonProperty[] IFileRead.GetDefault() |  | ||||||
|     { |  | ||||||
|         JsonProperty[] results = _Description.GetDefault(this, _Logistics); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     Dictionary<string, string> IFileRead.GetDisplayNamesJsonElement() |  | ||||||
|     { |  | ||||||
|         Dictionary<string, string> results = _Description.GetDisplayNamesJsonElement(this); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     List<IDescription> IFileRead.GetDescriptions(IFileRead fileRead, List<Test> tests, IProcessData processData) |  | ||||||
|     { |  | ||||||
|         List<IDescription> results = _Description.GetDescriptions(fileRead, _Logistics, tests, processData); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     Tuple<string, Test[], JsonElement[], List<FileInfo>> IFileRead.GetExtractResult(string reportFullPath, string eventName) |  | ||||||
|     { |  | ||||||
|         Tuple<string, Test[], JsonElement[], List<FileInfo>> results; |  | ||||||
|         if (string.IsNullOrEmpty(eventName)) |  | ||||||
|             throw new Exception(); |  | ||||||
|         _ReportFullPath = reportFullPath; |  | ||||||
|         DateTime dateTime = DateTime.Now; |  | ||||||
|         results = GetExtractResult(reportFullPath, dateTime); |  | ||||||
|         if (results.Item3 is null) |  | ||||||
|             results = new Tuple<string, Test[], JsonElement[], List<FileInfo>>(results.Item1, Array.Empty<Test>(), JsonSerializer.Deserialize<JsonElement[]>("[]"), results.Item4); |  | ||||||
|         if (results.Item3.Length > 0 && _IsEAFHosted) |  | ||||||
|             WritePDSF(this, results.Item3); |  | ||||||
|         UpdateLastTicksDuration(DateTime.Now.Ticks - dateTime.Ticks); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     Tuple<string, Test[], JsonElement[], List<FileInfo>> IFileRead.ReExtract() |  | ||||||
|     { |  | ||||||
|         Tuple<string, Test[], JsonElement[], List<FileInfo>> results; |  | ||||||
|         List<string> headerNames = _Description.GetHeaderNames(); |  | ||||||
|         Dictionary<string, string> keyValuePairs = _Description.GetDisplayNamesJsonElement(this); |  | ||||||
|         results = ReExtract(this, headerNames, keyValuePairs); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private static int? GetKeyColumnIndex(string[] columns, string keyColumn) |  | ||||||
|     { |  | ||||||
| #nullable enable |  | ||||||
|         int? result = null; |  | ||||||
|         for (int i = 0; i < columns.Length; i++) |  | ||||||
|         { |  | ||||||
|             if (columns[i] != keyColumn) |  | ||||||
|                 continue; |  | ||||||
|             result = i; |  | ||||||
|             break; |  | ||||||
|         } |  | ||||||
|         return result; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private ReadOnlyCollection<string> GetSystemStateValues(List<string> lines, string[] columns, int keyColumnIndex) |  | ||||||
|     { |  | ||||||
|         List<string> results = new(); |  | ||||||
|         string[] values; |  | ||||||
|         string? systemState; |  | ||||||
|         string keyColumnValue; |  | ||||||
|         for (int i = 7; i < lines.Count; i++) |  | ||||||
|         { |  | ||||||
|             values = lines[i].Split('\t'); |  | ||||||
|             if (values.Length != columns.Length) |  | ||||||
|                 continue; |  | ||||||
|             keyColumnValue = values[keyColumnIndex]; |  | ||||||
|             if (string.IsNullOrEmpty(keyColumnValue)) |  | ||||||
|                 continue; |  | ||||||
|             if (!_SystemStateToNames.TryGetValue(keyColumnValue, out systemState)) |  | ||||||
|                 continue; |  | ||||||
|             if (results.Contains(systemState)) |  | ||||||
|                 continue; |  | ||||||
|             results.Add(systemState); |  | ||||||
|         } |  | ||||||
|         return new(results); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private void MoveFile(string reportFullPath) |  | ||||||
|     { |  | ||||||
|         string equipment; |  | ||||||
|         string timestamp; |  | ||||||
|         string[] columns; |  | ||||||
|         DateTime dateTime; |  | ||||||
|         List<string> lines; |  | ||||||
|         string systemState; |  | ||||||
|         int? keyColumnIndex; |  | ||||||
|         string checkFileName; |  | ||||||
|         List<string> headerLines = new(); |  | ||||||
|         ReadOnlyCollection<string> systemStateValues; |  | ||||||
|         string missingKeyDirectory = Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, "Missing-Key"); |  | ||||||
|         if (!Directory.Exists(missingKeyDirectory)) |  | ||||||
|             _ = Directory.CreateDirectory(missingKeyDirectory); |  | ||||||
|         string fileName = Path.GetFileName(reportFullPath); |  | ||||||
|         string[] segments = fileName.Split('_'); |  | ||||||
|         for (int z = 0; z < 1; z++) |  | ||||||
|         { |  | ||||||
|             if (segments.Length != 2) |  | ||||||
|                 continue; |  | ||||||
|             equipment = segments[0]; |  | ||||||
|             timestamp = segments[1].Split('.')[0]; |  | ||||||
|             if (timestamp.Length != _TimestampFormat.Length) |  | ||||||
|                 continue; |  | ||||||
|             headerLines.Clear(); |  | ||||||
|             lines = File.ReadAllLines(reportFullPath).ToList(); |  | ||||||
|             if (lines.Count < 8) |  | ||||||
|                 continue; |  | ||||||
|             for (int i = 0; i < 6; i++) |  | ||||||
|             { |  | ||||||
|                 headerLines.Add(lines[0]); |  | ||||||
|                 lines.RemoveAt(0); |  | ||||||
|             } |  | ||||||
|             if (lines[0].Length < 1 || lines[0][0] != '"' || !lines[0].StartsWith("\"Time\"")) |  | ||||||
|                 continue; |  | ||||||
|             columns = lines[0].Split('\t'); |  | ||||||
|             if (columns.Length < 3) |  | ||||||
|                 continue; |  | ||||||
|             keyColumnIndex = GetKeyColumnIndex(columns, _KeyColumn); |  | ||||||
|             if (keyColumnIndex is null) |  | ||||||
|             { |  | ||||||
|                 File.Move(reportFullPath, Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, missingKeyDirectory, fileName)); |  | ||||||
|                 continue; |  | ||||||
|             } |  | ||||||
|             systemStateValues = GetSystemStateValues(lines, columns, keyColumnIndex.Value); |  | ||||||
|             if (systemStateValues.Count == 0) |  | ||||||
|             { |  | ||||||
|                 File.Move(reportFullPath, Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, missingKeyDirectory, fileName)); |  | ||||||
|                 continue; |  | ||||||
|             } |  | ||||||
|             lines.AddRange(headerLines); |  | ||||||
|             systemState = string.Join("-", systemStateValues); |  | ||||||
|             checkFileName = Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, $"{equipment}-{timestamp}-{systemState}.pdsf"); |  | ||||||
|             File.WriteAllLines(checkFileName, lines); |  | ||||||
|             // File.Delete(reportFullPath); |  | ||||||
|             if (DateTime.TryParseExact(timestamp, _TimestampFormat, CultureInfo.InvariantCulture, DateTimeStyles.None, out dateTime)) |  | ||||||
|                 File.SetLastWriteTime(checkFileName, dateTime); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private Tuple<string, Test[], JsonElement[], List<FileInfo>> GetExtractResult(string reportFullPath, DateTime _) |  | ||||||
|     { |  | ||||||
|         Tuple<string, Test[], JsonElement[], List<FileInfo>> results; |  | ||||||
|         ProcessDataStandardFormat processDataStandardFormat = ProcessDataStandardFormat.GetProcessDataStandardFormat(reportFullPath); |  | ||||||
|         _Logistics = new Logistics(reportFullPath, processDataStandardFormat); |  | ||||||
|         SetFileParameterLotIDToLogisticsMID(); |  | ||||||
|         JsonElement[] jsonElements = ProcessDataStandardFormat.GetArray(processDataStandardFormat); |  | ||||||
|         List<Shared.Properties.IDescription> descriptions = GetDuplicatorDescriptions(jsonElements); |  | ||||||
|         Test[] tests = (from l in descriptions select (Test)l.Test).ToArray(); |  | ||||||
|         if (_IsEAFHosted && _FileConnectorConfiguration.FileScanningIntervalInSeconds > 0) |  | ||||||
|             MoveFile(reportFullPath); |  | ||||||
|         results = new Tuple<string, Test[], JsonElement[], List<FileInfo>>(string.Join(Environment.NewLine, processDataStandardFormat.Logistics[0]), tests, jsonElements, new List<FileInfo>()); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @ -1,238 +0,0 @@ | |||||||
| using Adaptation.Eaf.Management.ConfigurationData.CellAutomation; |  | ||||||
| using Adaptation.Ifx.Eaf.EquipmentConnector.File.Configuration; |  | ||||||
| using Adaptation.Shared; |  | ||||||
| using Adaptation.Shared.Duplicator; |  | ||||||
| using Adaptation.Shared.Methods; |  | ||||||
| using System; |  | ||||||
| using System.Collections.Generic; |  | ||||||
| using System.Collections.ObjectModel; |  | ||||||
| using System.Globalization; |  | ||||||
| using System.IO; |  | ||||||
| using System.Linq; |  | ||||||
| using System.Text.Json; |  | ||||||
|  |  | ||||||
| namespace Adaptation.FileHandlers.R77; |  | ||||||
|  |  | ||||||
| public class FileRead : Shared.FileRead, IFileRead |  | ||||||
| { |  | ||||||
|  |  | ||||||
|     private readonly string _KeyColumn; |  | ||||||
|     private readonly string _TimestampFormat; |  | ||||||
|     private readonly ReadOnlyDictionary<string, string> _SystemStateToNames; |  | ||||||
|  |  | ||||||
|     public FileRead(ISMTP smtp, Dictionary<string, string> fileParameter, string cellInstanceName, int? connectionCount, string cellInstanceConnectionName, FileConnectorConfiguration fileConnectorConfiguration, string equipmentTypeName, string parameterizedModelObjectDefinitionType, IList<ModelObjectParameterDefinition> modelObjectParameters, string equipmentDictionaryName, Dictionary<string, List<long>> dummyRuns, Dictionary<long, List<Shared.Metrology.WS.Results>> staticRuns, bool useCyclicalForDescription, bool isEAFHosted) : |  | ||||||
|         base(new Description(), false, smtp, fileParameter, cellInstanceName, connectionCount, cellInstanceConnectionName, fileConnectorConfiguration, equipmentTypeName, parameterizedModelObjectDefinitionType, modelObjectParameters, equipmentDictionaryName, dummyRuns, staticRuns, useCyclicalForDescription, isEAFHosted: connectionCount is null) |  | ||||||
|     { |  | ||||||
|         _MinFileLength = 10; |  | ||||||
|         _NullData = string.Empty; |  | ||||||
|         _Logistics = new(this); |  | ||||||
|         if (_FileParameter is null) |  | ||||||
|             throw new Exception(cellInstanceConnectionName); |  | ||||||
|         if (_ModelObjectParameterDefinitions is null) |  | ||||||
|             throw new Exception(cellInstanceConnectionName); |  | ||||||
|         if (!_IsDuplicator) |  | ||||||
|             throw new Exception(cellInstanceConnectionName); |  | ||||||
|         string[] segments; |  | ||||||
|         Dictionary<string, string> systemStateToNames = new(); |  | ||||||
|         _KeyColumn = GetPropertyValue(cellInstanceConnectionName, modelObjectParameters, "ProcessDataStandardFormat.KeyColumn"); |  | ||||||
|         _TimestampFormat = GetPropertyValue(cellInstanceConnectionName, modelObjectParameters, "ProcessDataStandardFormat.TimestampFormat"); |  | ||||||
|         ModelObjectParameterDefinition[] systemStates = GetProperties(cellInstanceConnectionName, modelObjectParameters, "ProcessDataStandardFormat.SystemState"); |  | ||||||
|         foreach (ModelObjectParameterDefinition modelObjectParameterDefinition in systemStates) |  | ||||||
|         { |  | ||||||
|             segments = modelObjectParameterDefinition.Value.Split('|'); |  | ||||||
|             if (segments.Length != 2) |  | ||||||
|                 continue; |  | ||||||
|             systemStateToNames.Add(segments[0], segments[1]); |  | ||||||
|         } |  | ||||||
|         _SystemStateToNames = new(systemStateToNames); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     void IFileRead.Move(Tuple<string, Test[], JsonElement[], List<FileInfo>> extractResults, Exception exception) |  | ||||||
|     { |  | ||||||
|         bool isErrorFile = exception is not null; |  | ||||||
|         if (!isErrorFile && !string.IsNullOrEmpty(_Logistics.ReportFullPath)) |  | ||||||
|         { |  | ||||||
|             FileInfo fileInfo = new(_Logistics.ReportFullPath); |  | ||||||
|             if (fileInfo.Exists && fileInfo.LastWriteTime < fileInfo.CreationTime) |  | ||||||
|                 File.SetLastWriteTime(_Logistics.ReportFullPath, fileInfo.CreationTime); |  | ||||||
|         } |  | ||||||
|         Move(extractResults); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     void IFileRead.WaitForThread() => WaitForThread(thread: null, threadExceptions: null); |  | ||||||
|  |  | ||||||
|     string IFileRead.GetEventDescription() |  | ||||||
|     { |  | ||||||
|         string result = _Description.GetEventDescription(); |  | ||||||
|         return result; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     List<string> IFileRead.GetHeaderNames() |  | ||||||
|     { |  | ||||||
|         List<string> results = _Description.GetHeaderNames(); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     string[] IFileRead.Move(Tuple<string, Test[], JsonElement[], List<FileInfo>> extractResults, string to, string from, string resolvedFileLocation, Exception exception) |  | ||||||
|     { |  | ||||||
|         string[] results = Move(extractResults, to, from, resolvedFileLocation, exception); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     JsonProperty[] IFileRead.GetDefault() |  | ||||||
|     { |  | ||||||
|         JsonProperty[] results = _Description.GetDefault(this, _Logistics); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     Dictionary<string, string> IFileRead.GetDisplayNamesJsonElement() |  | ||||||
|     { |  | ||||||
|         Dictionary<string, string> results = _Description.GetDisplayNamesJsonElement(this); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     List<IDescription> IFileRead.GetDescriptions(IFileRead fileRead, List<Test> tests, IProcessData processData) |  | ||||||
|     { |  | ||||||
|         List<IDescription> results = _Description.GetDescriptions(fileRead, _Logistics, tests, processData); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     Tuple<string, Test[], JsonElement[], List<FileInfo>> IFileRead.GetExtractResult(string reportFullPath, string eventName) |  | ||||||
|     { |  | ||||||
|         Tuple<string, Test[], JsonElement[], List<FileInfo>> results; |  | ||||||
|         if (string.IsNullOrEmpty(eventName)) |  | ||||||
|             throw new Exception(); |  | ||||||
|         _ReportFullPath = reportFullPath; |  | ||||||
|         DateTime dateTime = DateTime.Now; |  | ||||||
|         results = GetExtractResult(reportFullPath, dateTime); |  | ||||||
|         if (results.Item3 is null) |  | ||||||
|             results = new Tuple<string, Test[], JsonElement[], List<FileInfo>>(results.Item1, Array.Empty<Test>(), JsonSerializer.Deserialize<JsonElement[]>("[]"), results.Item4); |  | ||||||
|         if (results.Item3.Length > 0 && _IsEAFHosted) |  | ||||||
|             WritePDSF(this, results.Item3); |  | ||||||
|         UpdateLastTicksDuration(DateTime.Now.Ticks - dateTime.Ticks); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     Tuple<string, Test[], JsonElement[], List<FileInfo>> IFileRead.ReExtract() |  | ||||||
|     { |  | ||||||
|         Tuple<string, Test[], JsonElement[], List<FileInfo>> results; |  | ||||||
|         List<string> headerNames = _Description.GetHeaderNames(); |  | ||||||
|         Dictionary<string, string> keyValuePairs = _Description.GetDisplayNamesJsonElement(this); |  | ||||||
|         results = ReExtract(this, headerNames, keyValuePairs); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private static int? GetKeyColumnIndex(string[] columns, string keyColumn) |  | ||||||
|     { |  | ||||||
| #nullable enable |  | ||||||
|         int? result = null; |  | ||||||
|         for (int i = 0; i < columns.Length; i++) |  | ||||||
|         { |  | ||||||
|             if (columns[i] != keyColumn) |  | ||||||
|                 continue; |  | ||||||
|             result = i; |  | ||||||
|             break; |  | ||||||
|         } |  | ||||||
|         return result; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private ReadOnlyCollection<string> GetSystemStateValues(List<string> lines, string[] columns, int keyColumnIndex) |  | ||||||
|     { |  | ||||||
|         List<string> results = new(); |  | ||||||
|         string[] values; |  | ||||||
|         string? systemState; |  | ||||||
|         string keyColumnValue; |  | ||||||
|         for (int i = 7; i < lines.Count; i++) |  | ||||||
|         { |  | ||||||
|             values = lines[i].Split('\t'); |  | ||||||
|             if (values.Length != columns.Length) |  | ||||||
|                 continue; |  | ||||||
|             keyColumnValue = values[keyColumnIndex]; |  | ||||||
|             if (string.IsNullOrEmpty(keyColumnValue)) |  | ||||||
|                 continue; |  | ||||||
|             if (!_SystemStateToNames.TryGetValue(keyColumnValue, out systemState)) |  | ||||||
|                 continue; |  | ||||||
|             if (results.Contains(systemState)) |  | ||||||
|                 continue; |  | ||||||
|             results.Add(systemState); |  | ||||||
|         } |  | ||||||
|         return new(results); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private void MoveFile(string reportFullPath) |  | ||||||
|     { |  | ||||||
|         string equipment; |  | ||||||
|         string timestamp; |  | ||||||
|         string[] columns; |  | ||||||
|         DateTime dateTime; |  | ||||||
|         List<string> lines; |  | ||||||
|         string systemState; |  | ||||||
|         int? keyColumnIndex; |  | ||||||
|         string checkFileName; |  | ||||||
|         List<string> headerLines = new(); |  | ||||||
|         ReadOnlyCollection<string> systemStateValues; |  | ||||||
|         string missingKeyDirectory = Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, "Missing-Key"); |  | ||||||
|         if (!Directory.Exists(missingKeyDirectory)) |  | ||||||
|             _ = Directory.CreateDirectory(missingKeyDirectory); |  | ||||||
|         string fileName = Path.GetFileName(reportFullPath); |  | ||||||
|         string[] segments = fileName.Split('_'); |  | ||||||
|         for (int z = 0; z < 1; z++) |  | ||||||
|         { |  | ||||||
|             if (segments.Length != 2) |  | ||||||
|                 continue; |  | ||||||
|             equipment = segments[0]; |  | ||||||
|             timestamp = segments[1].Split('.')[0]; |  | ||||||
|             if (timestamp.Length != _TimestampFormat.Length) |  | ||||||
|                 continue; |  | ||||||
|             headerLines.Clear(); |  | ||||||
|             lines = File.ReadAllLines(reportFullPath).ToList(); |  | ||||||
|             if (lines.Count < 8) |  | ||||||
|                 continue; |  | ||||||
|             for (int i = 0; i < 6; i++) |  | ||||||
|             { |  | ||||||
|                 headerLines.Add(lines[0]); |  | ||||||
|                 lines.RemoveAt(0); |  | ||||||
|             } |  | ||||||
|             if (lines[0].Length < 1 || lines[0][0] != '"' || !lines[0].StartsWith("\"Time\"")) |  | ||||||
|                 continue; |  | ||||||
|             columns = lines[0].Split('\t'); |  | ||||||
|             if (columns.Length < 3) |  | ||||||
|                 continue; |  | ||||||
|             keyColumnIndex = GetKeyColumnIndex(columns, _KeyColumn); |  | ||||||
|             if (keyColumnIndex is null) |  | ||||||
|             { |  | ||||||
|                 File.Move(reportFullPath, Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, missingKeyDirectory, fileName)); |  | ||||||
|                 continue; |  | ||||||
|             } |  | ||||||
|             systemStateValues = GetSystemStateValues(lines, columns, keyColumnIndex.Value); |  | ||||||
|             if (systemStateValues.Count == 0) |  | ||||||
|             { |  | ||||||
|                 File.Move(reportFullPath, Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, missingKeyDirectory, fileName)); |  | ||||||
|                 continue; |  | ||||||
|             } |  | ||||||
|             lines.AddRange(headerLines); |  | ||||||
|             systemState = string.Join("-", systemStateValues); |  | ||||||
|             checkFileName = Path.Combine(_FileConnectorConfiguration.AlternateTargetFolder, $"{equipment}-{timestamp}-{systemState}.pdsf"); |  | ||||||
|             File.WriteAllLines(checkFileName, lines); |  | ||||||
|             // File.Delete(reportFullPath); |  | ||||||
|             if (DateTime.TryParseExact(timestamp, _TimestampFormat, CultureInfo.InvariantCulture, DateTimeStyles.None, out dateTime)) |  | ||||||
|                 File.SetLastWriteTime(checkFileName, dateTime); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     private Tuple<string, Test[], JsonElement[], List<FileInfo>> GetExtractResult(string reportFullPath, DateTime _) |  | ||||||
|     { |  | ||||||
|         Tuple<string, Test[], JsonElement[], List<FileInfo>> results; |  | ||||||
|         ProcessDataStandardFormat processDataStandardFormat = ProcessDataStandardFormat.GetProcessDataStandardFormat(reportFullPath); |  | ||||||
|         _Logistics = new Logistics(reportFullPath, processDataStandardFormat); |  | ||||||
|         SetFileParameterLotIDToLogisticsMID(); |  | ||||||
|         JsonElement[] jsonElements = ProcessDataStandardFormat.GetArray(processDataStandardFormat); |  | ||||||
|         List<Shared.Properties.IDescription> descriptions = GetDuplicatorDescriptions(jsonElements); |  | ||||||
|         Test[] tests = (from l in descriptions select (Test)l.Test).ToArray(); |  | ||||||
|         if (_IsEAFHosted && _FileConnectorConfiguration.FileScanningIntervalInSeconds > 0) |  | ||||||
|             MoveFile(reportFullPath); |  | ||||||
|         results = new Tuple<string, Test[], JsonElement[], List<FileInfo>>(string.Join(Environment.NewLine, processDataStandardFormat.Logistics[0]), tests, jsonElements, new List<FileInfo>()); |  | ||||||
|         return results; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
| } |  | ||||||
| @ -3,6 +3,7 @@ using System; | |||||||
| using System.Collections.Generic; | using System.Collections.Generic; | ||||||
| using System.Linq; | using System.Linq; | ||||||
| using System.Text.Json; | using System.Text.Json; | ||||||
|  | using System.Text.Json.Serialization; | ||||||
|  |  | ||||||
| namespace Adaptation.Shared.Duplicator; | namespace Adaptation.Shared.Duplicator; | ||||||
|  |  | ||||||
| @ -178,4 +179,16 @@ public class Description : IDescription, Properties.IDescription | |||||||
|  |  | ||||||
|     internal static string GetDateFormat() => "MM/dd/yyyy hh:mm:ss tt"; |     internal static string GetDateFormat() => "MM/dd/yyyy hh:mm:ss tt"; | ||||||
|  |  | ||||||
|  | } | ||||||
|  |  | ||||||
|  | [JsonSourceGenerationOptions(WriteIndented = true, NumberHandling = JsonNumberHandling.AllowReadingFromString | JsonNumberHandling.WriteAsString)] | ||||||
|  | [JsonSerializable(typeof(Description))] | ||||||
|  | internal partial class SharedDescriptionSourceGenerationContext : JsonSerializerContext | ||||||
|  | { | ||||||
|  | } | ||||||
|  |  | ||||||
|  | [JsonSourceGenerationOptions(WriteIndented = true, NumberHandling = JsonNumberHandling.AllowReadingFromString | JsonNumberHandling.WriteAsString)] | ||||||
|  | [JsonSerializable(typeof(Description[]))] | ||||||
|  | internal partial class SharedDescriptionArraySourceGenerationContext : JsonSerializerContext | ||||||
|  | { | ||||||
| } | } | ||||||
| @ -9,7 +9,6 @@ using System.IO; | |||||||
| using System.Linq; | using System.Linq; | ||||||
| using System.Text; | using System.Text; | ||||||
| using System.Text.Json; | using System.Text.Json; | ||||||
| using System.Text.Json.Serialization; |  | ||||||
| using System.Threading; | using System.Threading; | ||||||
|  |  | ||||||
| namespace Adaptation.Shared; | namespace Adaptation.Shared; | ||||||
| @ -383,17 +382,24 @@ public class FileRead : Properties.IFileRead | |||||||
|         else |         else | ||||||
|         { |         { | ||||||
|             string[] files; |             string[] files; | ||||||
|             string logisticsSequence = _Logistics.Sequence.ToString(); |             string[] directories; | ||||||
|             string[] directories = Directory.GetDirectories(jobIdDirectory, $"*{logisticsSequence}*", SearchOption.TopDirectoryOnly); |             string logisticsSequence; | ||||||
|             foreach (string directory in directories) |             for (int i = 0; i < 10; i++) | ||||||
|             { |             { | ||||||
|                 files = Directory.GetFiles(directory, "*", SearchOption.TopDirectoryOnly); |                 logisticsSequence = (_Logistics.Sequence + -i).ToString(); | ||||||
|                 if (files.Length == 0) |                 directories = Directory.GetDirectories(jobIdDirectory, $"*{logisticsSequence}*", SearchOption.TopDirectoryOnly); | ||||||
|                     continue; |                 foreach (string directory in directories) | ||||||
|                 results.Add(directory); |                 { | ||||||
|  |                     files = Directory.GetFiles(directory, "*", SearchOption.TopDirectoryOnly); | ||||||
|  |                     if (files.Length == 0) | ||||||
|  |                         continue; | ||||||
|  |                     results.Add(directory); | ||||||
|  |                 } | ||||||
|  |                 if (results.Count == 1) | ||||||
|  |                     break; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         if ((results is null) || results.Count != 1) |         if (results.Count != 1) | ||||||
|             throw new Exception("Didn't find directory by logistics sequence"); |             throw new Exception("Didn't find directory by logistics sequence"); | ||||||
|         return results.ToArray(); |         return results.ToArray(); | ||||||
|     } |     } | ||||||
| @ -440,12 +446,13 @@ public class FileRead : Properties.IFileRead | |||||||
|     { |     { | ||||||
|         List<Properties.IDescription> results = new(); |         List<Properties.IDescription> results = new(); | ||||||
|         Duplicator.Description description; |         Duplicator.Description description; | ||||||
|         JsonSerializerOptions jsonSerializerOptions = new() { NumberHandling = JsonNumberHandling.AllowReadingFromString | JsonNumberHandling.WriteAsString }; |  | ||||||
|         foreach (JsonElement jsonElement in jsonElements) |         foreach (JsonElement jsonElement in jsonElements) | ||||||
|         { |         { | ||||||
|             if (jsonElement.ValueKind != JsonValueKind.Object) |             if (jsonElement.ValueKind != JsonValueKind.Object) | ||||||
|                 throw new Exception(); |                 throw new Exception(); | ||||||
|             description = JsonSerializer.Deserialize<Duplicator.Description>(jsonElement.ToString(), jsonSerializerOptions); |             description = JsonSerializer.Deserialize(jsonElement.ToString(), Duplicator.SharedDescriptionSourceGenerationContext.Default.Description); | ||||||
|  |             if (description is null) | ||||||
|  |                 continue; | ||||||
|             results.Add(description); |             results.Add(description); | ||||||
|         } |         } | ||||||
|         return results; |         return results; | ||||||
| @ -478,27 +485,14 @@ public class FileRead : Properties.IFileRead | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     protected void WritePDSF(IFileRead fileRead, JsonElement[] jsonElements) |     protected static void WritePDSF(IFileRead fileRead, JsonElement[] jsonElements) | ||||||
|     { |     { | ||||||
|         string directory; | #pragma warning disable CA1510 | ||||||
|         string day = $"{_Logistics.DateTimeFromSequence:yyyy-MM-dd}"; |         if (fileRead is null) | ||||||
|         string weekOfYear = _Calendar.GetWeekOfYear(_Logistics.DateTimeFromSequence, CalendarWeekRule.FirstDay, DayOfWeek.Sunday).ToString("00"); |             throw new ArgumentNullException(nameof(fileRead)); | ||||||
|         string weekDirectory = $"{_Logistics.DateTimeFromSequence:yyyy}_Week_{weekOfYear}"; |         if (jsonElements is null) | ||||||
|         if (!_CellInstanceConnectionName.StartsWith(_CellInstanceName) && _CellInstanceConnectionNameBase == _EquipmentType) |             throw new ArgumentNullException(nameof(jsonElements)); | ||||||
|             directory = Path.Combine(_TracePath, _EquipmentType, "Target", weekDirectory, day, _CellInstanceName, _CellInstanceConnectionName); | #pragma warning restore CA1510 | ||||||
|         else |  | ||||||
|             directory = Path.Combine(_TracePath, _EquipmentType, "Source", weekDirectory, day, _CellInstanceName, _CellInstanceConnectionName); |  | ||||||
|         if (!Directory.Exists(directory)) |  | ||||||
|             _ = Directory.CreateDirectory(directory); |  | ||||||
|         string file = Path.Combine(directory, string.Concat(_Logistics.MesEntity, "_", _Logistics.Sequence, ".ipdsf")); |  | ||||||
|         string lines = ProcessDataStandardFormat.GetPDSFText(fileRead, _Logistics, jsonElements, logisticsText: string.Empty); |  | ||||||
|         File.WriteAllText(file, lines); |  | ||||||
|         if (_Logistics.TotalSecondsSinceLastWriteTimeFromSequence > 600) |  | ||||||
|         { |  | ||||||
|             try |  | ||||||
|             { File.SetLastWriteTime(file, _Logistics.DateTimeFromSequence); } |  | ||||||
|             catch (Exception) { } |  | ||||||
|         } |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     protected void WaitForThread(Thread thread, List<Exception> threadExceptions) |     protected void WaitForThread(Thread thread, List<Exception> threadExceptions) | ||||||
|  | |||||||
| @ -2,12 +2,14 @@ using Adaptation.Shared.Methods; | |||||||
| using System; | using System; | ||||||
| using System.Collections.Generic; | using System.Collections.Generic; | ||||||
| using System.Collections.ObjectModel; | using System.Collections.ObjectModel; | ||||||
|  | using System.Diagnostics; | ||||||
| using System.Globalization; | using System.Globalization; | ||||||
| using System.IO; | using System.IO; | ||||||
| using System.Linq; | using System.Linq; | ||||||
| using System.Text; | using System.Text; | ||||||
| using System.Text.Json; | using System.Text.Json; | ||||||
| using System.Text.Json.Serialization; | using System.Text.Json.Serialization; | ||||||
|  | using System.Text.RegularExpressions; | ||||||
|  |  | ||||||
| namespace Adaptation.Shared; | namespace Adaptation.Shared; | ||||||
|  |  | ||||||
| @ -136,6 +138,7 @@ internal class ProcessDataStandardFormat | |||||||
|     internal static ProcessDataStandardFormat GetProcessDataStandardFormat(string reportFullPath, string[]? lines = null, int columnsLine = 6) |     internal static ProcessDataStandardFormat GetProcessDataStandardFormat(string reportFullPath, string[]? lines = null, int columnsLine = 6) | ||||||
|     { |     { | ||||||
|         ProcessDataStandardFormat result; |         ProcessDataStandardFormat result; | ||||||
|  |         long? sequence; | ||||||
|         string segment; |         string segment; | ||||||
|         string[] segments; |         string[] segments; | ||||||
|         bool addToFooter = false; |         bool addToFooter = false; | ||||||
| @ -186,13 +189,25 @@ internal class ProcessDataStandardFormat | |||||||
|         } |         } | ||||||
|         string? linesOne = lines.Length > 0 && body.Count == 0 && columns.Count == 0 ? lines[1] : null; |         string? linesOne = lines.Length > 0 && body.Count == 0 && columns.Count == 0 ? lines[1] : null; | ||||||
|         logistics = GetLogistics(footer, linesOne: linesOne); |         logistics = GetLogistics(footer, linesOne: linesOne); | ||||||
|  |         if (logistics.Count == 0) | ||||||
|  |             sequence = null; | ||||||
|  |         else | ||||||
|  |         { | ||||||
|  |             segments = logistics[0].Split(new string[] { "SEQUENCE=" }, StringSplitOptions.None); | ||||||
|  |             sequence = segments.Length < 2 || !long.TryParse(segments[1].Split(';')[0], out long s) ? null : s; | ||||||
|  |         } | ||||||
|  |         if (sequence is null && !string.IsNullOrEmpty(reportFullPath)) | ||||||
|  |         { | ||||||
|  |             FileInfo fileInfo = new(reportFullPath); | ||||||
|  |             sequence = fileInfo.LastWriteTime.Ticks; | ||||||
|  |         } | ||||||
|         result = new(body: body.AsReadOnly(), |         result = new(body: body.AsReadOnly(), | ||||||
|                      columns: columns.AsReadOnly(), |                      columns: columns.AsReadOnly(), | ||||||
|                      footer: footer.AsReadOnly(), |                      footer: footer.AsReadOnly(), | ||||||
|                      header: header.AsReadOnly(), |                      header: header.AsReadOnly(), | ||||||
|                      inputPDSF: null, |                      inputPDSF: null, | ||||||
|                      logistics: logistics, |                      logistics: logistics, | ||||||
|                      sequence: null); |                      sequence: sequence); | ||||||
|         return result; |         return result; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @ -214,19 +229,19 @@ internal class ProcessDataStandardFormat | |||||||
|         return results.AsReadOnly(); |         return results.AsReadOnly(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     internal static ProcessDataStandardFormat GetProcessDataStandardFormat(string reportFullPath, ProcessDataStandardFormatMapping pdsfMapping) |     internal static ProcessDataStandardFormat GetProcessDataStandardFormat(string reportFullPath, ProcessDataStandardFormatMapping processDataStandardFormatMapping) | ||||||
|     { |     { | ||||||
|         ProcessDataStandardFormat result; |         ProcessDataStandardFormat result; | ||||||
|         const int columnsLine = 6; |         const int columnsLine = 6; | ||||||
|         FileInfo fileInfo = new(reportFullPath); |         FileInfo fileInfo = new(reportFullPath); | ||||||
|         ProcessDataStandardFormat processDataStandardFormat = GetProcessDataStandardFormat(fileInfo.LastWriteTime, columnsLine, fileInfo.FullName, lines: null); |         ProcessDataStandardFormat processDataStandardFormat = GetProcessDataStandardFormat(fileInfo.LastWriteTime, columnsLine, fileInfo.FullName, lines: null); | ||||||
|         JsonElement[]? jsonElements = pdsfMapping.OldColumnNames.Count != pdsfMapping.ColumnIndices.Count ? null : GetFullArray(processDataStandardFormat); |         JsonElement[]? jsonElements = processDataStandardFormatMapping.OldColumnNames.Count != processDataStandardFormatMapping.ColumnIndices.Count ? null : GetFullArray(processDataStandardFormat); | ||||||
|         JsonProperty[]? jsonProperties = jsonElements is null || jsonElements.Length == 0 ? null : jsonElements[0].EnumerateObject().ToArray(); |         JsonProperty[]? jsonProperties = jsonElements is null || jsonElements.Length == 0 ? null : jsonElements[0].EnumerateObject().ToArray(); | ||||||
|         if (jsonElements is null || jsonProperties is null || jsonProperties.Length != pdsfMapping.NewColumnNames.Count) |         if (jsonElements is null || jsonProperties is null || jsonProperties.Length != processDataStandardFormatMapping.NewColumnNames.Count) | ||||||
|             result = processDataStandardFormat; |             result = processDataStandardFormat; | ||||||
|         else |         else | ||||||
|         { |         { | ||||||
|             result = GetProcessDataStandardFormat(pdsfMapping, jsonElements, processDataStandardFormat); |             result = GetProcessDataStandardFormat(processDataStandardFormatMapping, jsonElements, processDataStandardFormat); | ||||||
|             if (result.Sequence is null || result.Columns.Count == 0 || result.Body.Count == 0 || result.Logistics.Count == 0) |             if (result.Sequence is null || result.Columns.Count == 0 || result.Body.Count == 0 || result.Logistics.Count == 0) | ||||||
|                 result = processDataStandardFormat; |                 result = processDataStandardFormat; | ||||||
|         } |         } | ||||||
| @ -236,7 +251,7 @@ internal class ProcessDataStandardFormat | |||||||
|     private static ProcessDataStandardFormat GetProcessDataStandardFormat(DateTime lastWriteTime, int columnsLine, string path, string[]? lines) |     private static ProcessDataStandardFormat GetProcessDataStandardFormat(DateTime lastWriteTime, int columnsLine, string path, string[]? lines) | ||||||
|     { |     { | ||||||
|         ProcessDataStandardFormat result; |         ProcessDataStandardFormat result; | ||||||
|         long sequence; |         long? sequence; | ||||||
|         string[] segments; |         string[] segments; | ||||||
|         bool addToFooter = false; |         bool addToFooter = false; | ||||||
|         List<string> body = new(); |         List<string> body = new(); | ||||||
| @ -268,12 +283,13 @@ internal class ProcessDataStandardFormat | |||||||
|         } |         } | ||||||
|         logistics = GetLogistics(footer, linesOne: null); |         logistics = GetLogistics(footer, linesOne: null); | ||||||
|         if (logistics.Count == 0) |         if (logistics.Count == 0) | ||||||
|             sequence = lastWriteTime.Ticks; |             sequence = null; | ||||||
|         else |         else | ||||||
|         { |         { | ||||||
|             segments = logistics[0].Split(new string[] { "SEQUENCE=" }, StringSplitOptions.None); |             segments = logistics[0].Split(new string[] { "SEQUENCE=" }, StringSplitOptions.None); | ||||||
|             sequence = segments.Length < 2 || !long.TryParse(segments[1].Split(';')[0], out long s) ? lastWriteTime.Ticks : s; |             sequence = segments.Length < 2 || !long.TryParse(segments[1].Split(';')[0], out long s) ? null : s; | ||||||
|         } |         } | ||||||
|  |         sequence ??= lastWriteTime.Ticks; | ||||||
|         result = new(body: body.AsReadOnly(), |         result = new(body: body.AsReadOnly(), | ||||||
|                      columns: new(columns), |                      columns: new(columns), | ||||||
|                      footer: footer.AsReadOnly(), |                      footer: footer.AsReadOnly(), | ||||||
| @ -302,7 +318,7 @@ internal class ProcessDataStandardFormat | |||||||
|                 segments = bodyLine.Split('\t').ToList(); |                 segments = bodyLine.Split('\t').ToList(); | ||||||
|                 for (int c = 0; c < segments.Count; c++) |                 for (int c = 0; c < segments.Count; c++) | ||||||
|                 { |                 { | ||||||
|                     value = segments[c].Replace("\"", "\\\"").Replace("\\", "\\\\"); |                     value = segments[c].Replace("\\", "\\\\").Replace("\"", "\\\""); | ||||||
|                     _ = stringBuilder.Append('"').Append(processDataStandardFormat.Columns[c]).Append("\":\"").Append(value).Append("\","); |                     _ = stringBuilder.Append('"').Append(processDataStandardFormat.Columns[c]).Append("\":\"").Append(value).Append("\","); | ||||||
|                 } |                 } | ||||||
|                 _ = stringBuilder.Remove(stringBuilder.Length - 1, 1); |                 _ = stringBuilder.Remove(stringBuilder.Length - 1, 1); | ||||||
| @ -321,12 +337,14 @@ internal class ProcessDataStandardFormat | |||||||
|         int column; |         int column; | ||||||
|         string value; |         string value; | ||||||
|         JsonProperty jsonProperty; |         JsonProperty jsonProperty; | ||||||
|  |         List<string> debug = new(); | ||||||
|         List<string> values = new(); |         List<string> values = new(); | ||||||
|         List<string> results = new(); |         List<string> results = new(); | ||||||
|         JsonProperty[] jsonProperties; |         JsonProperty[] jsonProperties; | ||||||
|         List<string> unknownColumns = new(); |         List<string> unknownColumns = new(); | ||||||
|         for (int i = 0; i < jsonElements.Length; i++) |         for (int i = 0; i < jsonElements.Length; i++) | ||||||
|         { |         { | ||||||
|  |             debug.Clear(); | ||||||
|             values.Clear(); |             values.Clear(); | ||||||
|             if (jsonElements[i].ValueKind != JsonValueKind.Object) |             if (jsonElements[i].ValueKind != JsonValueKind.Object) | ||||||
|             { |             { | ||||||
| @ -340,16 +358,22 @@ internal class ProcessDataStandardFormat | |||||||
|             { |             { | ||||||
|                 column = processDataStandardFormatMapping.ColumnIndices[c]; |                 column = processDataStandardFormatMapping.ColumnIndices[c]; | ||||||
|                 if (column == -1) |                 if (column == -1) | ||||||
|  |                 { | ||||||
|                     value = processDataStandardFormatMapping.OldColumnNames[c]; |                     value = processDataStandardFormatMapping.OldColumnNames[c]; | ||||||
|  |                     debug.Add($"<Item C=-01 Name=\"{value}\" DataType=\"8\" XmlType=\"1\" XPath=\"//records/record/{value}\" />"); | ||||||
|  |                 } | ||||||
|                 else |                 else | ||||||
|                 { |                 { | ||||||
|                     jsonProperty = jsonProperties[column]; |                     jsonProperty = jsonProperties[column]; | ||||||
|                     value = jsonProperty.Value.ToString(); |                     value = jsonProperty.Value.ToString(); | ||||||
|  |                     debug.Add($"<Item C={column + 2:000} Name=\"{processDataStandardFormatMapping.OldColumnNames[c]}\" DataType=\"8\" XmlType=\"1\" XPath=\"//records/record/{jsonProperty.Name}\" />"); | ||||||
|                 } |                 } | ||||||
|                 values.Add(value); |                 values.Add(value); | ||||||
|             } |             } | ||||||
|             results.Add(string.Join("\t", values)); |             results.Add(string.Join("\t", values)); | ||||||
|         } |         } | ||||||
|  |         if (Debugger.IsAttached) | ||||||
|  |             File.WriteAllText("../../.txt", string.Join(Environment.NewLine, debug.OrderBy(l => l))); | ||||||
|         result = new(body: new(results), |         result = new(body: new(results), | ||||||
|                      columns: processDataStandardFormatMapping.OldColumnNames, |                      columns: processDataStandardFormatMapping.OldColumnNames, | ||||||
|                      footer: processDataStandardFormat.Footer, |                      footer: processDataStandardFormat.Footer, | ||||||
| @ -364,7 +388,6 @@ internal class ProcessDataStandardFormat | |||||||
|     { |     { | ||||||
|         if (processDataStandardFormat.InputPDSF is null) |         if (processDataStandardFormat.InputPDSF is null) | ||||||
|             throw new NullReferenceException(nameof(processDataStandardFormat.InputPDSF)); |             throw new NullReferenceException(nameof(processDataStandardFormat.InputPDSF)); | ||||||
| #pragma warning disable CA1845, IDE0057 |  | ||||||
|         string result; |         string result; | ||||||
|         string line; |         string line; | ||||||
|         string value; |         string value; | ||||||
| @ -378,19 +401,27 @@ internal class ProcessDataStandardFormat | |||||||
|                 break; |                 break; | ||||||
|             for (int c = 0; c < segments.Length; c++) |             for (int c = 0; c < segments.Length; c++) | ||||||
|             { |             { | ||||||
|                 value = segments[c].Replace("\"", "\\\"").Replace("\\", "\\\\"); |                 value = segments[c].Replace("\\", "\\\\").Replace("\"", "\\\""); | ||||||
|                 line += string.Concat('"', processDataStandardFormat.InputPDSF.Columns[c].Trim('"'), '"', ':', '"', value, '"', ','); |                 line += string.Concat('"', processDataStandardFormat.InputPDSF.Columns[c].Trim('"'), '"', ':', '"', value, '"', ','); | ||||||
|             } |             } | ||||||
|             line = string.Concat(line.Substring(0, line.Length - 1), '}'); |             line = string.Concat(line.Substring(0, line.Length - 1), '}'); | ||||||
|             lines.Add(line); |             lines.Add(line); | ||||||
|         } |         } | ||||||
|  |         string? json = null; | ||||||
|  |         if (processDataStandardFormat.Footer is not null && processDataStandardFormat.Footer.Count > 0) | ||||||
|  |         { | ||||||
|  |             Dictionary<string, string> footerKeyValuePairs = GetFooterKeyValuePairs(processDataStandardFormat.Footer); | ||||||
|  |             Dictionary<string, Dictionary<string, string>> logisticKeyValuePairs = GetLogisticKeyValuePairs(processDataStandardFormat.Footer, footerKeyValuePairs); | ||||||
|  |             json = JsonSerializer.Serialize(logisticKeyValuePairs, DictionaryStringDictionaryStringStringSourceGenerationContext.Default.DictionaryStringDictionaryStringString); | ||||||
|  |         } | ||||||
|  |         string footerText = string.IsNullOrEmpty(json) || json == "{}" ? string.Empty : $",{Environment.NewLine}\"PDSF\":{Environment.NewLine}{json}"; | ||||||
|         result = string.Concat( |         result = string.Concat( | ||||||
|             '{', |             '{', | ||||||
|             Environment.NewLine, |             Environment.NewLine, | ||||||
|             '"', |             '"', | ||||||
|             "Count", |             "Count", | ||||||
|             '"', |             '"', | ||||||
|             ": ",             |             ": ", | ||||||
|             processDataStandardFormat.Body.Count, |             processDataStandardFormat.Body.Count, | ||||||
|             ',', |             ',', | ||||||
|             Environment.NewLine, |             Environment.NewLine, | ||||||
| @ -409,17 +440,95 @@ internal class ProcessDataStandardFormat | |||||||
|             '"', |             '"', | ||||||
|             "Sequence", |             "Sequence", | ||||||
|             '"', |             '"', | ||||||
|             ": ",             |             ": ", | ||||||
|             processDataStandardFormat.Sequence, |             processDataStandardFormat.Sequence, | ||||||
|             Environment.NewLine, |             Environment.NewLine, | ||||||
|  |             footerText, | ||||||
|  |             Environment.NewLine, | ||||||
|             '}'); |             '}'); | ||||||
|         return result; |         return result; | ||||||
| #pragma warning restore CA1845, IDE0057 |     } | ||||||
|  |  | ||||||
|  |     private static Dictionary<string, string> GetFooterKeyValuePairs(ReadOnlyCollection<string> footerLines) | ||||||
|  |     { | ||||||
|  |         Dictionary<string, string> results = new(); | ||||||
|  |         string[] segments; | ||||||
|  |         foreach (string footerLine in footerLines) | ||||||
|  |         { | ||||||
|  |             segments = footerLine.Split('\t'); | ||||||
|  |             if (segments.Length != 2 || string.IsNullOrEmpty(segments[1].Trim())) | ||||||
|  |             { | ||||||
|  |                 continue; | ||||||
|  |             } | ||||||
|  |             if (segments[1].Contains(';')) | ||||||
|  |             { | ||||||
|  |                 continue; | ||||||
|  |             } | ||||||
|  |             else | ||||||
|  |             { | ||||||
|  |                 if (results.ContainsKey(segments[0])) | ||||||
|  |                 { | ||||||
|  |                     continue; | ||||||
|  |                 } | ||||||
|  |                 results.Add(segments[0], segments[1]); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private static Dictionary<string, Dictionary<string, string>> GetLogisticKeyValuePairs(ReadOnlyCollection<string> footerLines, Dictionary<string, string> footerKeyValuePairs) | ||||||
|  |     { | ||||||
|  |         Dictionary<string, Dictionary<string, string>> results = new(); | ||||||
|  |         string[] segments; | ||||||
|  |         string[] subSegments; | ||||||
|  |         string[] subSubSegments; | ||||||
|  |         Dictionary<string, string>? keyValue; | ||||||
|  |         results.Add("Footer", footerKeyValuePairs); | ||||||
|  |         foreach (string footerLine in footerLines) | ||||||
|  |         { | ||||||
|  |             segments = footerLine.Split('\t'); | ||||||
|  |             if (segments.Length != 2 || string.IsNullOrEmpty(segments[1].Trim())) | ||||||
|  |             { | ||||||
|  |                 continue; | ||||||
|  |             } | ||||||
|  |             if (!segments[1].Contains(';') || !segments[1].Contains('=')) | ||||||
|  |             { | ||||||
|  |                 continue; | ||||||
|  |             } | ||||||
|  |             else | ||||||
|  |             { | ||||||
|  |                 subSegments = segments[1].Split(';'); | ||||||
|  |                 if (subSegments.Length < 1) | ||||||
|  |                 { | ||||||
|  |                     continue; | ||||||
|  |                 } | ||||||
|  |                 if (!results.TryGetValue(segments[0], out keyValue)) | ||||||
|  |                 { | ||||||
|  |                     results.Add(segments[0], new()); | ||||||
|  |                     if (!results.TryGetValue(segments[0], out keyValue)) | ||||||
|  |                     { | ||||||
|  |                         throw new Exception(); | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |                 foreach (string segment in subSegments) | ||||||
|  |                 { | ||||||
|  |                     subSubSegments = segment.Split('='); | ||||||
|  |                     if (subSubSegments.Length != 2) | ||||||
|  |                     { | ||||||
|  |                         continue; | ||||||
|  |                     } | ||||||
|  |                     keyValue.Add(subSubSegments[0], subSubSegments[1]); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return results; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     internal static void Write(string path, ProcessDataStandardFormat processDataStandardFormat, List<Metrology.WS.Results>? wsResults) |     internal static void Write(string path, ProcessDataStandardFormat processDataStandardFormat, List<Metrology.WS.Results>? wsResults) | ||||||
|     { |     { | ||||||
|         List<string> results = new(); |         List<string> results = new(); | ||||||
|  |         if (processDataStandardFormat.InputPDSF is null) | ||||||
|  |             throw new NullReferenceException(nameof(processDataStandardFormat.InputPDSF)); | ||||||
|         if (processDataStandardFormat.Sequence is null) |         if (processDataStandardFormat.Sequence is null) | ||||||
|             throw new NullReferenceException(nameof(processDataStandardFormat.Sequence)); |             throw new NullReferenceException(nameof(processDataStandardFormat.Sequence)); | ||||||
|         string endOffset = "E#######T"; |         string endOffset = "E#######T"; | ||||||
| @ -457,24 +566,25 @@ internal class ProcessDataStandardFormat | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         results.Add("END_HEADER"); |         results.Add("END_HEADER"); | ||||||
|         if (processDataStandardFormat.InputPDSF is not null) |         results.Add(string.Empty); | ||||||
|         { |         List<char> hyphens = new(); | ||||||
|             results.Add(string.Empty); |         results.AddRange(processDataStandardFormat.InputPDSF.Header.Select(l => $"|{l.Replace('\t', '|')}|")); | ||||||
|             List<char> hyphens = new(); |         results.Add(string.Empty); | ||||||
|             results.AddRange(processDataStandardFormat.InputPDSF.Header.Select(l => l.Replace('\t', '|'))); |         results.Add($"|{string.Join("|", processDataStandardFormat.InputPDSF.Columns)}|"); | ||||||
|             results.Add($"|{string.Join("|", processDataStandardFormat.InputPDSF.Columns)}|"); |         for (int i = 0; i < processDataStandardFormat.InputPDSF.Columns.Count; i++) | ||||||
|             for (int i = 0; i < processDataStandardFormat.InputPDSF.Columns.Count; i++) |             hyphens.Add('-'); | ||||||
|                 hyphens.Add('-'); |         results.Add($"|{string.Join("|", hyphens)}|"); | ||||||
|             results.Add($"|{string.Join("|", hyphens)}|"); |         results.AddRange(processDataStandardFormat.InputPDSF.Body.Select(l => $"|{l.Replace('\t', '|')}|")); | ||||||
|             results.AddRange(processDataStandardFormat.InputPDSF.Body.Select(l => l.Replace('\t', '|'))); |         results.Add(string.Empty); | ||||||
|             results.Add(string.Empty); |         results.AddRange(processDataStandardFormat.InputPDSF.Footer.Select(l => $"|{l.Replace('\t', '|')}|")); | ||||||
|             results.AddRange(processDataStandardFormat.InputPDSF.Footer.Select(l => l.Replace('\t', '|'))); |         results.Add(string.Empty); | ||||||
|             results.Add(string.Empty); |         string xml = GetXml(processDataStandardFormat); | ||||||
|             results.Add("EOF"); |         results.Add(xml); | ||||||
|             results.Add(string.Empty); |         results.Add(string.Empty); | ||||||
|             string json = GetJson(processDataStandardFormat); |         results.Add("EOF"); | ||||||
|             results.Add(json); |         results.Add(string.Empty); | ||||||
|         } |         string json = GetJson(processDataStandardFormat); | ||||||
|  |         results.Add(json); | ||||||
|         File.WriteAllText(path, string.Join(Environment.NewLine, results)); |         File.WriteAllText(path, string.Join(Environment.NewLine, results)); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @ -517,7 +627,7 @@ internal class ProcessDataStandardFormat | |||||||
|                 { |                 { | ||||||
|                     for (int c = 1; c < segments.Length; c++) |                     for (int c = 1; c < segments.Length; c++) | ||||||
|                     { |                     { | ||||||
|                         value = segments[c].Replace("\"", "\\\"").Replace("\\", "\\\\"); |                         value = segments[c].Replace("\\", "\\\\").Replace("\"", "\\\""); | ||||||
|                         _ = stringBuilder.Append('"').Append(processDataStandardFormat.Columns[c]).Append("\":\"").Append(value).Append("\","); |                         _ = stringBuilder.Append('"').Append(processDataStandardFormat.Columns[c]).Append("\":\"").Append(value).Append("\","); | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
| @ -525,7 +635,7 @@ internal class ProcessDataStandardFormat | |||||||
|                 { |                 { | ||||||
|                     for (int c = 1; c < segments.Length; c++) |                     for (int c = 1; c < segments.Length; c++) | ||||||
|                     { |                     { | ||||||
|                         value = segments[c].Replace("\"", "\\\"").Replace("\\", "\\\\"); |                         value = segments[c].Replace("\\", "\\\\").Replace("\"", "\\\""); | ||||||
|                         if (string.IsNullOrEmpty(value)) |                         if (string.IsNullOrEmpty(value)) | ||||||
|                             _ = stringBuilder.Append('"').Append(processDataStandardFormat.Columns[c]).Append("\":").Append(value).Append("null,"); |                             _ = stringBuilder.Append('"').Append(processDataStandardFormat.Columns[c]).Append("\":").Append(value).Append("null,"); | ||||||
|                         else if (value.All(char.IsDigit)) |                         else if (value.All(char.IsDigit)) | ||||||
| @ -544,6 +654,17 @@ internal class ProcessDataStandardFormat | |||||||
|         return results; |         return results; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     internal static JsonElement[] GetArray(string reportFullPath, string[] lines, ProcessDataStandardFormat processDataStandardFormat) | ||||||
|  |     { | ||||||
|  |         JsonElement[] results; | ||||||
|  |         string? json = GetRecordsJson(reportFullPath, lines); | ||||||
|  |         if (string.IsNullOrEmpty(json)) | ||||||
|  |             results = GetArray(processDataStandardFormat); | ||||||
|  |         else | ||||||
|  |             results = JsonSerializer.Deserialize(json, JsonElementCollectionSourceGenerationContext.Default.JsonElementArray) ?? throw new Exception(); | ||||||
|  |         return results; | ||||||
|  |     } | ||||||
|  |  | ||||||
|     internal static string GetPDSFText(IFileRead fileRead, Logistics logistics, JsonElement[] jsonElements, string logisticsText) |     internal static string GetPDSFText(IFileRead fileRead, Logistics logistics, JsonElement[] jsonElements, string logisticsText) | ||||||
|     { |     { | ||||||
|         string result; |         string result; | ||||||
| @ -756,10 +877,126 @@ internal class ProcessDataStandardFormat | |||||||
|         return result; |         return result; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     internal static string GetXml(ProcessDataStandardFormat processDataStandardFormat) | ||||||
|  |     { | ||||||
|  |         string result; | ||||||
|  |         string tag; | ||||||
|  |         string value; | ||||||
|  |         string[] segments; | ||||||
|  |         List<string> values; | ||||||
|  |         Dictionary<string, List<string>> results = new(); | ||||||
|  |         ReadOnlyCollection<string> body = processDataStandardFormat.InputPDSF is null ? | ||||||
|  |             processDataStandardFormat.Body : processDataStandardFormat.InputPDSF.Body; | ||||||
|  |         ReadOnlyCollection<string> columns = processDataStandardFormat.InputPDSF is null ? | ||||||
|  |             processDataStandardFormat.Columns : processDataStandardFormat.InputPDSF.Columns; | ||||||
|  |         List<string> lines = new() { "<?xml version=\"1.0\" encoding=\"UTF-8\"?>", "<records>" }; | ||||||
|  |         for (int i = 0; i < body.Count; i++) | ||||||
|  |         { | ||||||
|  |             segments = body[i].Trim().Split('\t'); | ||||||
|  |             if (segments.Length != columns.Count) | ||||||
|  |                 break; | ||||||
|  |             for (int c = 0; c < segments.Length; c++) | ||||||
|  |             { | ||||||
|  |                 value = segments[c].Replace("&", "&") | ||||||
|  |                                    .Replace("<", "<") | ||||||
|  |                                    .Replace(">", ">") | ||||||
|  |                                    .Replace("\"", """) | ||||||
|  |                                    .Replace("'", "'"); | ||||||
|  |                 tag = Regex.Replace(columns[c].Trim('"'), @"[^a-zA-Z0-9]", "_").Split('\r')[0].Split('\n')[0]; | ||||||
|  |                 if (i == 0) | ||||||
|  |                 { | ||||||
|  |                     if (results.ContainsKey(tag)) | ||||||
|  |                         continue; | ||||||
|  |                     results.Add(tag, new List<string>()); | ||||||
|  |                 } | ||||||
|  |                 results[tag].Add(value); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         foreach (KeyValuePair<string, List<string>> keyValuePair in results) | ||||||
|  |         { | ||||||
|  |             if (body.Count < 2) | ||||||
|  |                 break; | ||||||
|  |             if (keyValuePair.Value.Count != body.Count) | ||||||
|  |                 continue; | ||||||
|  |             values = keyValuePair.Value.Distinct().ToList(); | ||||||
|  |             if (values.Count == 2 && (string.IsNullOrEmpty(values[0]) || string.IsNullOrEmpty(values[1]))) | ||||||
|  |             { | ||||||
|  |                 for (int i = 0; i < body.Count; i++) | ||||||
|  |                     keyValuePair.Value[i] = string.Empty; | ||||||
|  |                 foreach (string v in values) | ||||||
|  |                 { | ||||||
|  |                     if (string.IsNullOrEmpty(v)) | ||||||
|  |                         continue; | ||||||
|  |                     keyValuePair.Value[0] = v; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         for (int i = 0; i < body.Count; i++) | ||||||
|  |         { | ||||||
|  |             lines.Add("  <record>"); | ||||||
|  |             foreach (KeyValuePair<string, List<string>> keyValuePair in results) | ||||||
|  |             { | ||||||
|  |                 if (keyValuePair.Value.Count != body.Count) | ||||||
|  |                     continue; | ||||||
|  |                 lines.Add(string.Concat("    <", keyValuePair.Key, '>', keyValuePair.Value[i], "</", keyValuePair.Key, '>')); | ||||||
|  |             } | ||||||
|  |             lines.Add("  </record>"); | ||||||
|  |         } | ||||||
|  |         lines.Add("</records>"); | ||||||
|  |         result = string.Join(Environment.NewLine, lines); | ||||||
|  |         return result; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     internal static string GetXml(string reportFullPath, string[]? lines = null) | ||||||
|  |     { | ||||||
|  |         string result; | ||||||
|  |         bool foundXml = false; | ||||||
|  |         List<string> results = new(); | ||||||
|  |         lines ??= File.ReadAllLines(reportFullPath); | ||||||
|  |         foreach (string line in lines) | ||||||
|  |         { | ||||||
|  |             if (line.StartsWith("<?xml")) | ||||||
|  |                 foundXml = true; | ||||||
|  |             if (!foundXml) | ||||||
|  |                 continue; | ||||||
|  |             if (line.StartsWith("EOF")) | ||||||
|  |                 break; | ||||||
|  |             results.Add(line); | ||||||
|  |         } | ||||||
|  |         result = string.Join(Environment.NewLine, results); | ||||||
|  |         return result; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     private static string? GetRecordsJson(string reportFullPath, string[] lines) | ||||||
|  |     { | ||||||
|  |         string? result; | ||||||
|  |         bool foundRecords = false; | ||||||
|  |         List<string> results = new(); | ||||||
|  |         lines ??= File.ReadAllLines(reportFullPath); | ||||||
|  |         foreach (string line in lines) | ||||||
|  |         { | ||||||
|  |             if (line.StartsWith("\"Records\"")) | ||||||
|  |                 foundRecords = true; | ||||||
|  |             if (!foundRecords) | ||||||
|  |                 continue; | ||||||
|  |             if (line == "],") | ||||||
|  |                 break; | ||||||
|  |             results.Add(line); | ||||||
|  |         } | ||||||
|  |         result = results.Count == 0 ? null : $"{string.Join(Environment.NewLine, results.Skip(1))}{Environment.NewLine}]"; | ||||||
|  |         return result; | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
|  |  | ||||||
| [JsonSourceGenerationOptions(WriteIndented = true)] | [JsonSourceGenerationOptions(WriteIndented = true)] | ||||||
| [JsonSerializable(typeof(JsonElement[]))] | [JsonSerializable(typeof(JsonElement[]))] | ||||||
| internal partial class JsonElementCollectionSourceGenerationContext : JsonSerializerContext | internal partial class JsonElementCollectionSourceGenerationContext : JsonSerializerContext | ||||||
| { | { | ||||||
|  | } | ||||||
|  |  | ||||||
|  | [JsonSourceGenerationOptions(WriteIndented = true, DefaultIgnoreCondition = JsonIgnoreCondition.WhenWritingNull)] | ||||||
|  | [JsonSerializable(typeof(Dictionary<string, Dictionary<string, string>>))] | ||||||
|  | internal partial class DictionaryStringDictionaryStringStringSourceGenerationContext : JsonSerializerContext | ||||||
|  | { | ||||||
| } | } | ||||||
| @ -1,33 +1,34 @@ | |||||||
| using System.Collections.ObjectModel; | using System.Collections.ObjectModel; | ||||||
|  | using System.Linq; | ||||||
|  |  | ||||||
| namespace Adaptation.Shared; | namespace Adaptation.Shared; | ||||||
|  |  | ||||||
| public class ProcessDataStandardFormatMapping | public class ProcessDataStandardFormatMapping | ||||||
| { | { | ||||||
|  |  | ||||||
|     public ReadOnlyCollection<string> BackfillColumns { get; private set; } |  | ||||||
|     public ReadOnlyCollection<int> ColumnIndices { get; private set; } |     public ReadOnlyCollection<int> ColumnIndices { get; private set; } | ||||||
|     public ReadOnlyCollection<string> IgnoreColumns { get; private set; } |  | ||||||
|     public ReadOnlyCollection<string> IndexOnlyColumns { get; private set; } |  | ||||||
|     public ReadOnlyDictionary<string, string> KeyValuePairs { get; private set; } |  | ||||||
|     public ReadOnlyCollection<string> NewColumnNames { get; private set; } |     public ReadOnlyCollection<string> NewColumnNames { get; private set; } | ||||||
|     public ReadOnlyCollection<string> OldColumnNames { get; private set; } |     public ReadOnlyCollection<string> OldColumnNames { get; private set; } | ||||||
|  |  | ||||||
|     public ProcessDataStandardFormatMapping(ReadOnlyCollection<string> backfillColumns, |     public ProcessDataStandardFormatMapping(ReadOnlyCollection<int> columnIndices, | ||||||
|                                             ReadOnlyCollection<int> columnIndices, |  | ||||||
|                                             ReadOnlyCollection<string> ignoreColumns, |  | ||||||
|                                             ReadOnlyCollection<string> indexOnlyColumns, |  | ||||||
|                                             ReadOnlyDictionary<string, string> keyValuePairs, |  | ||||||
|                                             ReadOnlyCollection<string> newColumnNames, |                                             ReadOnlyCollection<string> newColumnNames, | ||||||
|                                             ReadOnlyCollection<string> oldColumnNames) |                                             ReadOnlyCollection<string> oldColumnNames) | ||||||
|     { |     { | ||||||
|         BackfillColumns = backfillColumns; |  | ||||||
|         ColumnIndices = columnIndices; |         ColumnIndices = columnIndices; | ||||||
|         IgnoreColumns = ignoreColumns; |  | ||||||
|         IndexOnlyColumns = indexOnlyColumns; |  | ||||||
|         KeyValuePairs = keyValuePairs; |  | ||||||
|         NewColumnNames = newColumnNames; |         NewColumnNames = newColumnNames; | ||||||
|         OldColumnNames = oldColumnNames; |         OldColumnNames = oldColumnNames; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     internal static ProcessDataStandardFormatMapping Get(string processDataStandardFormatMappingOldColumnNames, string processDataStandardFormatMappingNewColumnNames, string processDataStandardFormatMappingColumnIndices) | ||||||
|  |     { | ||||||
|  |         ProcessDataStandardFormatMapping result; | ||||||
|  |         ReadOnlyCollection<string> newColumnNames = new(processDataStandardFormatMappingNewColumnNames.Split(',')); | ||||||
|  |         ReadOnlyCollection<string> oldColumnNames = new(processDataStandardFormatMappingOldColumnNames.Split(',')); | ||||||
|  |         ReadOnlyCollection<int> columnIndices = new(processDataStandardFormatMappingColumnIndices.Split(',').Select(int.Parse).ToArray()); | ||||||
|  |         result = new(columnIndices: columnIndices, | ||||||
|  |                      newColumnNames: newColumnNames, | ||||||
|  |                      oldColumnNames: oldColumnNames); | ||||||
|  |         return result; | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
| @ -20,6 +20,7 @@ public class DEP08CEPIEPSILON : EAFLoggingUnitTesting | |||||||
|     internal static DEP08CEPIEPSILON EAFLoggingUnitTesting { get; private set; } |     internal static DEP08CEPIEPSILON EAFLoggingUnitTesting { get; private set; } | ||||||
|  |  | ||||||
|     static DEP08CEPIEPSILON() => DummyRoot = @"\\mesfs.infineon.com\EC_Characterization_Si\Dummy"; |     static DEP08CEPIEPSILON() => DummyRoot = @"\\mesfs.infineon.com\EC_Characterization_Si\Dummy"; | ||||||
|  |     // static DEP08CEPIEPSILON() => DummyRoot = @"D:\ProgramData\EC_Characterization_Si\Dummy"; | ||||||
|  |  | ||||||
|     public DEP08CEPIEPSILON() : base(DummyRoot, testContext: null, declaringType: null, skipEquipmentDictionary: false) |     public DEP08CEPIEPSILON() : base(DummyRoot, testContext: null, declaringType: null, skipEquipmentDictionary: false) | ||||||
|     { |     { | ||||||
| @ -136,5 +137,16 @@ public class DEP08CEPIEPSILON : EAFLoggingUnitTesting | |||||||
|         EAFLoggingUnitTesting.Logger.LogInformation(string.Concat(methodBase.Name, " - Exit")); |         EAFLoggingUnitTesting.Logger.LogInformation(string.Concat(methodBase.Name, " - Exit")); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     [Ignore] | ||||||
|  |     [TestMethod] | ||||||
|  |     public void Production__v2_60_0__DEP08CEPIEPSILON__InfinityQS() | ||||||
|  |     { | ||||||
|  |         string check = "*.pdsf"; | ||||||
|  |         MethodBase methodBase = new StackFrame().GetMethod(); | ||||||
|  |         EAFLoggingUnitTesting.Logger.LogInformation(string.Concat(methodBase.Name, " - Getting configuration")); | ||||||
|  |         _ = AdaptationTesting.GetWriteConfigurationGetFileRead(methodBase, check, EAFLoggingUnitTesting.AdaptationTesting); | ||||||
|  |         EAFLoggingUnitTesting.Logger.LogInformation(string.Concat(methodBase.Name, " - Exit")); | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
| @ -96,5 +96,21 @@ public class DEP08CEPIEPSILON | |||||||
|     [TestMethod] |     [TestMethod] | ||||||
|     public void Production__v2_60_0__DEP08CEPIEPSILON__R55() => _DEP08CEPIEPSILON.Production__v2_60_0__DEP08CEPIEPSILON__R55(); |     public void Production__v2_60_0__DEP08CEPIEPSILON__R55() => _DEP08CEPIEPSILON.Production__v2_60_0__DEP08CEPIEPSILON__R55(); | ||||||
|  |  | ||||||
|  | #if DEBUG | ||||||
|  |     [Ignore] | ||||||
|  | #endif | ||||||
|  |     [TestMethod] | ||||||
|  |     public void Production__v2_60_0__DEP08CEPIEPSILON__InfinityQS638895639451629988__First() | ||||||
|  |     { | ||||||
|  |         string check = "*.pdsf"; | ||||||
|  |         MethodBase methodBase = new StackFrame().GetMethod(); | ||||||
|  |         _DEP08CEPIEPSILON.Production__v2_60_0__DEP08CEPIEPSILON__InfinityQS(); | ||||||
|  |         string[] variables = _DEP08CEPIEPSILON.AdaptationTesting.GetVariables(methodBase, check, validatePDSF: false); | ||||||
|  |         IFileRead fileRead = _DEP08CEPIEPSILON.AdaptationTesting.Get(methodBase, sourceFileLocation: variables[2], sourceFileFilter: variables[3], useCyclicalForDescription: false); | ||||||
|  |         Logistics logistics = new(fileRead); | ||||||
|  |         _ = AdaptationTesting.ReExtractCompareUpdatePassDirectory(variables, fileRead, logistics); | ||||||
|  |         NonThrowTryCatch(); | ||||||
|  |     } | ||||||
|  |  | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
							
								
								
									
										94
									
								
								Adaptation/_Tests/Static/eda.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										94
									
								
								Adaptation/_Tests/Static/eda.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,94 @@ | |||||||
|  | getValue($('gv.vp12', '')); | ||||||
|  |  | ||||||
|  | function getValue(values) { | ||||||
|  |     let result = null; | ||||||
|  |     if (values != undefined && values.length > 1) { | ||||||
|  |         let collection = values[0] === '|' ? values.substring(1).split('|') : values.split('|'); | ||||||
|  |         let collectionParseFloat = getCollectionParseFloat(collection); | ||||||
|  |         let raw = getMin(collectionParseFloat); | ||||||
|  |         result = roundNumber(raw, 7); | ||||||
|  |     } | ||||||
|  |     return result; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function getCollectionParseFloat(collection) { | ||||||
|  |     let result = []; | ||||||
|  |     let value; | ||||||
|  |     for (let i = 0; i < collection.length; i++) { | ||||||
|  |         value = parseFloat(collection[i]); | ||||||
|  |         result.push(value); | ||||||
|  |     } | ||||||
|  |     return result; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function getMin(collection) { | ||||||
|  |     let result = 2147483647; | ||||||
|  |     if (collection && collection.length > 0) { | ||||||
|  |         for (let i = 0; i < collection.length; i++) { | ||||||
|  |             if (collection[i] < result) { | ||||||
|  |                 result = collection[i]; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     return result; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function getMax(collection) { | ||||||
|  |     let result = -2147483648; | ||||||
|  |     if (collection && collection.length > 0) { | ||||||
|  |         for (let i = 0; i < collection.length; i++) { | ||||||
|  |             if (collection[i] > result) { | ||||||
|  |                 result = collection[i]; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     return result; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function getSum(collection) { | ||||||
|  |     let result = 0; | ||||||
|  |     if (!collection || collection.length === 0) { | ||||||
|  |         result = 0; | ||||||
|  |     } | ||||||
|  |     else { | ||||||
|  |         for (let i = 0; i < collection.length; i++) { | ||||||
|  |             result += collection[i]; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     return result; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function getAverage(collection) { | ||||||
|  |     let result = null; | ||||||
|  |     if (collection == null || collection.length === 0) { | ||||||
|  |         result = 0; | ||||||
|  |     } | ||||||
|  | 	else { | ||||||
|  |         let sum = getSum(collection); | ||||||
|  |         result = sum / collection.length; | ||||||
|  |     } | ||||||
|  |     return result; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | function roundNumber(number, digits) { | ||||||
|  |     let result; | ||||||
|  |     const multiple = Math.pow(10, digits); | ||||||
|  |     result = Math.round(number * multiple) / multiple; | ||||||
|  |     return result; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | Reactor | ||||||
|  | getContextData('1', 'cds.PROCESS_JOBID', '') | ||||||
|  |  | ||||||
|  | PSN | ||||||
|  | getContextData('1', 'cds.PRODUCT', '') | ||||||
|  |  | ||||||
|  | RDS | ||||||
|  | getContextData('1', 'cds.MID', '') | ||||||
|  |  | ||||||
|  | getValue($('dcp.R61/DEP08CEPIEPSILON_Semi/LL1State', ''), $('dcp.R61/DEP08CEPIEPSILON_Semi/LL2State', '')); | ||||||
|  |  | ||||||
|  | function getValue(id78, id83) { | ||||||
|  |     let result = id78 === '6' ? 'Left' : id83 === '6' ? 'Right' : id78 + '-' + id83; | ||||||
|  |     return result; | ||||||
|  | } | ||||||
| @ -103,18 +103,18 @@ | |||||||
|     <Compile Include="Adaptation\Eaf\Management\ConfigurationData\CellAutomation\ModelObjectParameterDefinition.cs" /> |     <Compile Include="Adaptation\Eaf\Management\ConfigurationData\CellAutomation\ModelObjectParameterDefinition.cs" /> | ||||||
|     <Compile Include="Adaptation\Eaf\Management\ConfigurationData\CellAutomation\ModelObjectParameterType.cs" /> |     <Compile Include="Adaptation\Eaf\Management\ConfigurationData\CellAutomation\ModelObjectParameterType.cs" /> | ||||||
|     <Compile Include="Adaptation\Eaf\Management\ConfigurationData\Semiconductor\CellInstances\SecsConnectionConfiguration.cs" /> |     <Compile Include="Adaptation\Eaf\Management\ConfigurationData\Semiconductor\CellInstances\SecsConnectionConfiguration.cs" /> | ||||||
|  |     <Compile Include="Adaptation\FileHandlers\Aggregation\FileRead.cs" /> | ||||||
|     <Compile Include="Adaptation\FileHandlers\CellInstanceConnectionName.cs" /> |     <Compile Include="Adaptation\FileHandlers\CellInstanceConnectionName.cs" /> | ||||||
|     <Compile Include="Adaptation\FileHandlers\Dummy\FileRead.cs" /> |     <Compile Include="Adaptation\FileHandlers\Dummy\FileRead.cs" /> | ||||||
|     <Compile Include="Adaptation\FileHandlers\R29\FileRead.cs" /> |     <Compile Include="Adaptation\FileHandlers\InfinityQS\FileRead.cs" /> | ||||||
|     <Compile Include="Adaptation\FileHandlers\R32\FileRead.cs" /> |     <Compile Include="Adaptation\FileHandlers\InfinityQS\Six.cs" /> | ||||||
|     <Compile Include="Adaptation\FileHandlers\R36\FileRead.cs" /> |     <Compile Include="Adaptation\FileHandlers\Log\FileRead.cs" /> | ||||||
|     <Compile Include="Adaptation\FileHandlers\R61\FileRead.cs" /> |     <Compile Include="Adaptation\FileHandlers\R2\FileRead.cs" /> | ||||||
|     <Compile Include="Adaptation\FileHandlers\R62\FileRead.cs" /> |     <Compile Include="Adaptation\FileHandlers\R3\FileRead.cs" /> | ||||||
|     <Compile Include="Adaptation\FileHandlers\R65\FileRead.cs" /> |     <Compile Include="Adaptation\FileHandlers\R4\FileRead.cs" /> | ||||||
|     <Compile Include="Adaptation\FileHandlers\R55\FileRead.cs" /> |     <Compile Include="Adaptation\FileHandlers\R5\FileRead.cs" /> | ||||||
|     <Compile Include="Adaptation\FileHandlers\R57\FileRead.cs" /> |     <Compile Include="Adaptation\FileHandlers\R6\FileRead.cs" /> | ||||||
|     <Compile Include="Adaptation\FileHandlers\R75\FileRead.cs" /> |     <Compile Include="Adaptation\FileHandlers\R7\FileRead.cs" /> | ||||||
|     <Compile Include="Adaptation\FileHandlers\R77\FileRead.cs" /> |  | ||||||
|     <Compile Include="Adaptation\Ifx\Eaf\Common\Configuration\ConnectionSetting.cs" /> |     <Compile Include="Adaptation\Ifx\Eaf\Common\Configuration\ConnectionSetting.cs" /> | ||||||
|     <Compile Include="Adaptation\Ifx\Eaf\EquipmentConnector\File\Component\File.cs" /> |     <Compile Include="Adaptation\Ifx\Eaf\EquipmentConnector\File\Component\File.cs" /> | ||||||
|     <Compile Include="Adaptation\Ifx\Eaf\EquipmentConnector\File\Component\FilePathGenerator.cs" /> |     <Compile Include="Adaptation\Ifx\Eaf\EquipmentConnector\File\Component\FilePathGenerator.cs" /> | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user