Dual write PDSF for Metrology Viewer
Version Error Message Tests passed mesfs.infineon.com Infineon.EAF.Runtime 2.49.3 pool name Kanban net8.0 v2_52_0-Tests editorconfig yml ec fix yml explicit contents dotnet_diagnostic Removed Open Insight API IFX Directory Removed Open Insight API IFX Directory from Save CA1862 and GetWeekOfYear for WritePDSF gitignore cellInstanceVersion.EdaConnection.PortNumber Removed Open Insight API IFX Directory from Save Added Climatec to Test.cs GetJobIdDirectory Remove and 5-Other-Small NETFRAMEWORK mesfs.infineon.com Infineon.EAF.Runtime 2.49.3 pool name Kanban
This commit is contained in:
		| @ -115,7 +115,7 @@ public class Description : IDescription, Properties.IDescription | ||||
|     List<IDescription> IDescription.GetDescriptions(IFileRead fileRead, Logistics logistics, List<Test> tests, IProcessData iProcessData) | ||||
|     { | ||||
|         List<IDescription> results = new(); | ||||
|         if (iProcessData is null || !iProcessData.Details.Any()) | ||||
|         if (iProcessData is null || iProcessData.Details.Count == 0) | ||||
|             results.Add(GetDefault(fileRead, logistics)); | ||||
|         else | ||||
|         { | ||||
|  | ||||
| @ -163,7 +163,7 @@ public class FileRead : Properties.IFileRead | ||||
|     protected static ModelObjectParameterDefinition[] GetProperties(string cellInstanceConnectionName, IList<ModelObjectParameterDefinition> modelObjectParameters, string propertyNamePrefix) | ||||
|     { | ||||
|         ModelObjectParameterDefinition[] results = (from l in modelObjectParameters where l.Name.StartsWith(propertyNamePrefix) select l).ToArray(); | ||||
|         if (!results.Any()) | ||||
|         if (results.Length == 0) | ||||
|             throw new Exception(cellInstanceConnectionName); | ||||
|         return results; | ||||
|     } | ||||
| @ -171,7 +171,7 @@ public class FileRead : Properties.IFileRead | ||||
|     protected static ModelObjectParameterDefinition[] GetProperties(string cellInstanceConnectionName, IList<ModelObjectParameterDefinition> modelObjectParameters, string propertyNamePrefix, string propertyNameSuffix) | ||||
|     { | ||||
|         ModelObjectParameterDefinition[] results = (from l in modelObjectParameters where l.Name.StartsWith(propertyNamePrefix) && l.Name.EndsWith(propertyNameSuffix) select l).ToArray(); | ||||
|         if (!results.Any()) | ||||
|         if (results.Length == 0) | ||||
|             throw new Exception(cellInstanceConnectionName); | ||||
|         return results; | ||||
|     } | ||||
| @ -203,7 +203,7 @@ public class FileRead : Properties.IFileRead | ||||
|             } | ||||
|             lock (threadExceptions) | ||||
|             { | ||||
|                 if (threadExceptions.Any()) | ||||
|                 if (threadExceptions.Count != 0) | ||||
|                 { | ||||
|                     foreach (Exception item in threadExceptions) | ||||
|                         _Log.Error(string.Concat(item.Message, Environment.NewLine, Environment.NewLine, item.StackTrace)); | ||||
| @ -241,7 +241,7 @@ public class FileRead : Properties.IFileRead | ||||
|             if (!_IsDuplicator) | ||||
|                 WriteAllLines(to, results); | ||||
|         } | ||||
|         if (extractResults is not null && extractResults.Item4 is not null && extractResults.Item4.Any()) | ||||
|         if (extractResults is not null && extractResults.Item4 is not null && extractResults.Item4.Count != 0) | ||||
|         { | ||||
|             string itemFile; | ||||
|             List<string> directories = new(); | ||||
| @ -268,7 +268,7 @@ public class FileRead : Properties.IFileRead | ||||
|         string dateValue; | ||||
|         string rdsPlaceholder = "%RDS%"; | ||||
|         string mesEntityPlaceholder = "%MesEntity%"; | ||||
|         if (!descriptions.Any() || string.IsNullOrEmpty(descriptions[0].RDS)) | ||||
|         if (descriptions.Count == 0 || string.IsNullOrEmpty(descriptions[0].RDS)) | ||||
|             rds = logistics.MID; | ||||
|         else | ||||
|             rds = descriptions[0].RDS; | ||||
| @ -312,7 +312,7 @@ public class FileRead : Properties.IFileRead | ||||
|             preWait = dateTime.AddMilliseconds(1234).Ticks; | ||||
|         else | ||||
|             preWait = dateTime.AddMilliseconds(_FileConnectorConfiguration.FileHandleWaitTime.Value).Ticks; | ||||
|         if (!collection.Any()) | ||||
|         if (collection.Count == 0) | ||||
|             duplicateFiles.Add(duplicateFile); | ||||
|         string fileName = Path.GetFileNameWithoutExtension(logistics.ReportFullPath); | ||||
|         string successFile = string.Concat(successDirectory, @"\", Path.GetFileName(logistics.ReportFullPath)); | ||||
| @ -422,10 +422,12 @@ public class FileRead : Properties.IFileRead | ||||
|     protected void WritePDSF(IFileRead fileRead, JsonElement[] jsonElements) | ||||
|     { | ||||
|         string directory; | ||||
|         string weekOfYear = _Calendar.GetWeekOfYear(_Logistics.DateTimeFromSequence, CalendarWeekRule.FirstDay, DayOfWeek.Sunday).ToString("00"); | ||||
|         string weekDirectory = $"{_Logistics.DateTimeFromSequence:yyyy}_Week_{weekOfYear}{@"\"}{_Logistics.DateTimeFromSequence:yyyy-MM-dd}"; | ||||
|         if (!_CellInstanceConnectionName.StartsWith(_CellInstanceName) && _CellInstanceConnectionNameBase == _EquipmentType) | ||||
|             directory = Path.Combine(_TracePath, _EquipmentType, "Target", _CellInstanceName, _CellInstanceConnectionName); | ||||
|             directory = Path.Combine(_TracePath, _EquipmentType, "Target", weekDirectory, _CellInstanceName, _CellInstanceConnectionName); | ||||
|         else | ||||
|             directory = Path.Combine(_TracePath, _EquipmentType, "Source", _CellInstanceName, _CellInstanceConnectionName); | ||||
|             directory = Path.Combine(_TracePath, _EquipmentType, "Source", weekDirectory, _CellInstanceName, _CellInstanceConnectionName); | ||||
|         if (!Directory.Exists(directory)) | ||||
|             _ = Directory.CreateDirectory(directory); | ||||
|         string file = Path.Combine(directory, string.Concat(_Logistics.MesEntity, "_", _Logistics.Sequence, ".ipdsf")); | ||||
| @ -460,6 +462,7 @@ public class FileRead : Properties.IFileRead | ||||
|     protected void TriggerEvents(Tuple<string, Test[], JsonElement[], List<FileInfo>> extractResults, List<string> headerNames, Dictionary<string, string> keyValuePairs) | ||||
|     { | ||||
|         object value; | ||||
|         string segments; | ||||
|         string description; | ||||
|         List<object[]> list; | ||||
|         for (int i = 0; i < extractResults.Item3.Length; i++) | ||||
| @ -467,10 +470,10 @@ public class FileRead : Properties.IFileRead | ||||
|             _Log.Debug(string.Concat("TriggerEvent - {", _Logistics.ReportFullPath, "} ", i, " of ", extractResults.Item3.Length)); | ||||
|             foreach (JsonProperty jsonProperty in extractResults.Item3[i].EnumerateObject()) | ||||
|             { | ||||
|                 if (jsonProperty.Value.ValueKind != JsonValueKind.String || !keyValuePairs.ContainsKey(jsonProperty.Name)) | ||||
|                 if (jsonProperty.Value.ValueKind != JsonValueKind.String || !keyValuePairs.TryGetValue(jsonProperty.Name, out segments)) | ||||
|                     description = string.Empty; | ||||
|                 else | ||||
|                     description = keyValuePairs[jsonProperty.Name].Split('|')[0]; | ||||
|                     description = segments.Split('|')[0]; | ||||
|                 if (!_UseCyclicalForDescription || headerNames.Contains(jsonProperty.Name)) | ||||
|                     value = jsonProperty.Value.ToString(); | ||||
|                 else | ||||
| @ -502,10 +505,10 @@ public class FileRead : Properties.IFileRead | ||||
|                     matches = Directory.GetFiles(_FileConnectorConfiguration.SourceFileLocation, segments.Last(), SearchOption.AllDirectories); | ||||
|                 else | ||||
|                     matches = Directory.GetFiles(_FileConnectorConfiguration.SourceFileLocation, segments.Last(), SearchOption.TopDirectoryOnly); | ||||
|                 if (matches.Any()) | ||||
|                 if (matches.Length != 0) | ||||
|                     break; | ||||
|             } | ||||
|             if (matches is null || !matches.Any()) | ||||
|             if (matches is null || matches.Length == 0) | ||||
|                 results = null; | ||||
|             else | ||||
|             { | ||||
| @ -568,16 +571,99 @@ public class FileRead : Properties.IFileRead | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     internal static List<string> GetDirectoryNames(string directory) | ||||
|     { | ||||
| #nullable enable | ||||
|         List<string> results = new(); | ||||
|         string? fileName; | ||||
|         string? checkDirectory = directory; | ||||
|         string? pathRoot = Path.GetPathRoot(directory); | ||||
|         string extension = Path.GetExtension(directory); | ||||
|         if (string.IsNullOrEmpty(pathRoot)) | ||||
|             throw new NullReferenceException(nameof(pathRoot)); | ||||
|         if (Directory.Exists(directory)) | ||||
|         { | ||||
|             fileName = Path.GetFileName(directory); | ||||
|             if (!string.IsNullOrEmpty(fileName)) | ||||
|                 results.Add(fileName); | ||||
|         } | ||||
|         else if ((string.IsNullOrEmpty(extension) || extension.Length > 3) && !File.Exists(directory)) | ||||
|         { | ||||
|             fileName = Path.GetFileName(directory); | ||||
|             if (!string.IsNullOrEmpty(fileName)) | ||||
|                 results.Add(fileName); | ||||
|         } | ||||
|         for (int i = 0; i < int.MaxValue; i++) | ||||
|         { | ||||
|             checkDirectory = Path.GetDirectoryName(checkDirectory); | ||||
|             if (string.IsNullOrEmpty(checkDirectory) || checkDirectory == pathRoot) | ||||
|                 break; | ||||
|             fileName = Path.GetFileName(checkDirectory); | ||||
|             if (string.IsNullOrEmpty(fileName)) | ||||
|                 continue; | ||||
|             results.Add(fileName); | ||||
|         } | ||||
|         results.Add(pathRoot); | ||||
|         results.Reverse(); | ||||
|         return results; | ||||
| #nullable disable | ||||
|     } | ||||
|  | ||||
|     private string GetJobIdDirectory(string path) | ||||
|     { | ||||
|         string result; | ||||
|         List<string> directoryNames = GetDirectoryNames(path); | ||||
|         if (!directoryNames.Contains(_Logistics.JobID)) | ||||
|             result = Path.GetDirectoryName(path); | ||||
|         else | ||||
|         { | ||||
|             result = string.Empty; | ||||
|             foreach (string directoryName in directoryNames) | ||||
|             { | ||||
|                 result = Path.Combine(result, directoryName); | ||||
|                 if (directoryName == _Logistics.JobID) | ||||
|                     break; | ||||
|             } | ||||
|         } | ||||
|         return result; | ||||
|     } | ||||
|  | ||||
|     private static void DeleteEmptyTopDirectories(string rootDirectory) | ||||
|     { | ||||
|         if (Directory.Exists(rootDirectory)) | ||||
|         { | ||||
|             string[] files; | ||||
|             string[] directories; | ||||
|             string[] subDirectories = Directory.GetDirectories(rootDirectory, "*", SearchOption.TopDirectoryOnly); | ||||
|             foreach (string subDirectory in subDirectories) | ||||
|             { | ||||
|                 files = Directory.GetFiles(subDirectory, "*", SearchOption.AllDirectories); | ||||
|                 if (files.Length > 0) | ||||
|                     continue; | ||||
|                 directories = Directory.GetDirectories(subDirectory, "*", SearchOption.TopDirectoryOnly); | ||||
|                 if (directories.Length > 0) | ||||
|                     continue; | ||||
|                 try | ||||
|                 { Directory.Delete(subDirectory); } | ||||
|                 catch (UnauthorizedAccessException) | ||||
|                 { | ||||
|                     new DirectoryInfo(subDirectory).Attributes = FileAttributes.Normal; | ||||
|                     Directory.Delete(subDirectory); | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     private void Shared1811(string to, FileInfo sourceFile) | ||||
|     { | ||||
|         if (!_IsDuplicator && _FileConnectorConfiguration.SourceFileFilter != "*" && sourceFile.Exists && sourceFile.Length < _MinFileLength) | ||||
|         { | ||||
|             string directoryName = Path.GetFileName(to); | ||||
|             string jobIdDirectory = Path.GetDirectoryName(to); | ||||
|             string jobIdDirectory = GetJobIdDirectory(to); | ||||
|             DateTime dateTime = DateTime.Now.AddMinutes(-15); | ||||
|             string weekOfYear = _Calendar.GetWeekOfYear(_Logistics.DateTimeFromSequence, CalendarWeekRule.FirstDay, DayOfWeek.Sunday).ToString("00"); | ||||
|             string weekDirectory = $"{_Logistics.DateTimeFromSequence:yyyy}_Week_{weekOfYear}{@"\"}{_Logistics.DateTimeFromSequence:yyyy-MM-dd}"; | ||||
|             string destinationDirectory = string.Concat(jobIdDirectory, @"\_ Ignore 100 bytes\", weekDirectory, @"\", directoryName); | ||||
|             string destinationDirectory = Path.Combine(jobIdDirectory, "_ Ignore 100 bytes", weekDirectory, directoryName); | ||||
|             if (!Directory.Exists(destinationDirectory)) | ||||
|                 _ = Directory.CreateDirectory(destinationDirectory); | ||||
|             File.Move(sourceFile.FullName, string.Concat(destinationDirectory, @"\", sourceFile.Name)); | ||||
| @ -588,13 +674,13 @@ public class FileRead : Properties.IFileRead | ||||
|                 { | ||||
|                     if (!checkDirectory.Contains('_')) | ||||
|                         continue; | ||||
|                     if (Directory.GetDirectories(checkDirectory, "*", SearchOption.TopDirectoryOnly).Any()) | ||||
|                     if (Directory.GetDirectories(checkDirectory, "*", SearchOption.TopDirectoryOnly).Length != 0) | ||||
|                         continue; | ||||
|                     if (Directory.GetFiles(checkDirectory, "*", SearchOption.TopDirectoryOnly).Any()) | ||||
|                     if (Directory.GetFiles(checkDirectory, "*", SearchOption.TopDirectoryOnly).Length != 0) | ||||
|                         continue; | ||||
|                     if (Directory.GetDirectories(checkDirectory, "*", SearchOption.AllDirectories).Any()) | ||||
|                     if (Directory.GetDirectories(checkDirectory, "*", SearchOption.AllDirectories).Length != 0) | ||||
|                         continue; | ||||
|                     if (Directory.GetFiles(checkDirectory, "*", SearchOption.AllDirectories).Any()) | ||||
|                     if (Directory.GetFiles(checkDirectory, "*", SearchOption.AllDirectories).Length != 0) | ||||
|                         continue; | ||||
|                     if (new DirectoryInfo(checkDirectory).CreationTime > dateTime) | ||||
|                         continue; | ||||
| @ -602,6 +688,7 @@ public class FileRead : Properties.IFileRead | ||||
|                 } | ||||
|             } | ||||
|             catch (Exception) { throw; } | ||||
|             DeleteEmptyTopDirectories(jobIdDirectory); | ||||
|         } | ||||
|     } | ||||
|  | ||||
| @ -611,7 +698,7 @@ public class FileRead : Properties.IFileRead | ||||
|         { | ||||
|             foreach (string directory in (from l in directories orderby l.Split('\\').Length descending select l).Distinct()) | ||||
|             { | ||||
|                 if (Directory.Exists(directory) && !Directory.GetFiles(directory).Any()) | ||||
|                 if (Directory.Exists(directory) && Directory.GetFiles(directory).Length == 0) | ||||
|                     Directory.Delete(directory); | ||||
|             } | ||||
|         } | ||||
|  | ||||
| @ -91,7 +91,7 @@ public class Logistics : ILogistics | ||||
|         string[] segments; | ||||
|         _FileInfo = new(reportFullPath); | ||||
|         _Logistics1 = logistics.Split(new string[] { Environment.NewLine }, StringSplitOptions.RemoveEmptyEntries).ToList(); | ||||
|         if (!Logistics1.Any() || !Logistics1[0].StartsWith("LOGISTICS_1")) | ||||
|         if (Logistics1.Count == 0 || !Logistics1[0].StartsWith("LOGISTICS_1")) | ||||
|         { | ||||
|             _NullData = null; | ||||
|             _JobID = "null"; | ||||
|  | ||||
| @ -2,18 +2,27 @@ | ||||
|  | ||||
| public partial class WS | ||||
| { | ||||
|  | ||||
|     public class Attachment | ||||
|     { | ||||
|  | ||||
|         public string SubGroupId { get; set; } | ||||
|         public long HeaderId { get; set; } | ||||
|         public string HeaderIdDirectory { get; set; } | ||||
|         public string UniqueId { get; set; } | ||||
|         public string DestinationFileName { get; set; } | ||||
|         public string SourceFileName { get; set; } | ||||
|         public string AttachmentId { get; set; } | ||||
|  | ||||
|         public Attachment(string uniqueId, string destinationFileName, string sourceFileName) | ||||
|         public Attachment(string subGroupId, long headerId, string headerIdDirectory, string uniqueId, string destinationFileName, string sourceFileName) | ||||
|         { | ||||
|             SubGroupId = subGroupId; | ||||
|             HeaderId = headerId; | ||||
|             HeaderIdDirectory = headerIdDirectory; | ||||
|             UniqueId = uniqueId; | ||||
|             DestinationFileName = destinationFileName; | ||||
|             SourceFileName = sourceFileName; | ||||
|             AttachmentId = System.Guid.NewGuid().ToString(); | ||||
|         } | ||||
|  | ||||
|     } | ||||
|  | ||||
| @ -10,7 +10,7 @@ namespace Adaptation.Shared.Metrology; | ||||
| public partial class WS | ||||
| { | ||||
|  | ||||
|     public static (string, Results) SendData(string url, object payload, int timeoutSeconds = 120) | ||||
|     public static (string, Results) SendData(string url, long sequence, string directory, object payload, int timeoutSeconds = 120) | ||||
|     { | ||||
|         Results results = new(); | ||||
|         string resultsJson = string.Empty; | ||||
| @ -31,6 +31,10 @@ public partial class WS | ||||
|                 HttpResponseMessage httpResponseMessage = httpClient.SendAsync(httpRequestMessage, HttpCompletionOption.ResponseContentRead).Result; | ||||
|                 resultsJson = httpResponseMessage.Content.ReadAsStringAsync().Result; | ||||
|                 results = JsonSerializer.Deserialize<Results>(resultsJson, new JsonSerializerOptions { PropertyNameCaseInsensitive = true }); | ||||
|                 string checkDirectory = Path.Combine(directory, $"-{results.HeaderID}"); | ||||
|                 if (!Directory.Exists(checkDirectory)) | ||||
|                     _ = Directory.CreateDirectory(checkDirectory); | ||||
|                 File.WriteAllText(Path.Combine(checkDirectory, $"{sequence}.json"), json); | ||||
|             } | ||||
|             if (!results.Success) | ||||
|                 results.Errors.Add(results.ToString()); | ||||
| @ -51,58 +55,42 @@ public partial class WS | ||||
|         return new(resultsJson, results); | ||||
|     } | ||||
|  | ||||
|     // this method is a wrapper for attaching a file to either a header or data record | ||||
|     //   URL is the same URL used for SendData, ex: http://localhost/api/inbound/CDE | ||||
|     //   attachToHeaderId is the ID returned by SendData  | ||||
|     //   attachToDataUniqueId is the string unique ID for the data record, aka the Title of the Sharepoint list entry | ||||
|     //   fileContents is a byte array with the contents of the file | ||||
|     //   fileName is which attachment this is, image.pdf, data.pdf, data.txt, header.pdf, etc | ||||
|     //   timeoutSeconds is configured as the request timeout | ||||
|     // this method will either succeed or throw an exception | ||||
|     // also, this has been made synchronous | ||||
|     public static void AttachFile(string url, long attachToHeaderId, string attachToDataUniqueId, byte[] fileContents, string fileName, int timeoutSeconds = 60) | ||||
|     public static void AttachFile(string url, Attachment attachment, int timeoutSeconds = 60) | ||||
|     { | ||||
|         using HttpClient httpClient = new(); | ||||
|         string requestUrl = url + "/attachment?headerid=" + attachToHeaderId.ToString(); | ||||
|         if (!string.IsNullOrWhiteSpace(attachToDataUniqueId)) | ||||
|         { | ||||
|             requestUrl += "&datauniqueid="; | ||||
|             requestUrl += System.Net.WebUtility.UrlEncode(attachToDataUniqueId); | ||||
|         } | ||||
|         requestUrl += "&filename="; // this is just so the web server log shows the filename | ||||
|         requestUrl += System.Net.WebUtility.UrlEncode(fileName); | ||||
|  | ||||
|         string json = JsonSerializer.Serialize(attachment); | ||||
|         httpClient.Timeout = new TimeSpan(0, 0, 0, timeoutSeconds, 0); | ||||
|  | ||||
|         MultipartFormDataContent multipartFormDataContent = new(); | ||||
|         ByteArrayContent byteArrayContent = new(fileContents); | ||||
|         byteArrayContent.Headers.ContentType = new System.Net.Http.Headers.MediaTypeHeaderValue("application/octet-stream"); | ||||
|  | ||||
|         multipartFormDataContent.Add(byteArrayContent, "attachment", fileName); | ||||
|  | ||||
|         HttpResponseMessage httpResponseMessage = httpClient.PostAsync(requestUrl, multipartFormDataContent).Result; | ||||
|  | ||||
|         if (httpResponseMessage.IsSuccessStatusCode) | ||||
|             return; | ||||
|  | ||||
|         string resultBody = httpResponseMessage.Content.ReadAsStringAsync().Result; | ||||
|  | ||||
|         throw new Exception("Attachment failed: " + resultBody); | ||||
|         StringContent httpContent = new(json, Encoding.UTF8, "application/json"); | ||||
|         HttpResponseMessage httpResponseMessage = httpClient.PostAsync($"{url}/attachment", httpContent).Result; | ||||
|         if (!httpResponseMessage.IsSuccessStatusCode) | ||||
|         { | ||||
|             string resultBody = httpResponseMessage.Content.ReadAsStringAsync().Result; | ||||
|             throw new Exception($"Attachment failed: {resultBody}"); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     public static void AttachFiles(string url, long headerID, List<Attachment> headerAttachments = null, List<Attachment> dataAttachments = null) | ||||
|     public static void AttachFiles(string url, List<Attachment> headerAttachments = null, List<Attachment> dataAttachments = null) | ||||
|     { | ||||
|         string directory; | ||||
|         try | ||||
|         { | ||||
|             if (headerAttachments is not null) | ||||
|             { | ||||
|                 foreach (Attachment attachment in headerAttachments) | ||||
|                     AttachFile(url, headerID, "", File.ReadAllBytes(attachment.SourceFileName), attachment.DestinationFileName); | ||||
|                 { | ||||
|                     directory = Path.GetDirectoryName(attachment.HeaderIdDirectory) ?? throw new Exception(); | ||||
|                     File.Copy(attachment.SourceFileName, Path.Combine(directory, attachment.AttachmentId, attachment.DestinationFileName), overwrite: true); | ||||
|                     AttachFile(url, attachment); | ||||
|                 } | ||||
|             } | ||||
|             if (dataAttachments is not null) | ||||
|             { | ||||
|                 foreach (Attachment attachment in dataAttachments) | ||||
|                     AttachFile(url, headerID, attachment.UniqueId, File.ReadAllBytes(attachment.SourceFileName), attachment.DestinationFileName); | ||||
|                 { | ||||
|                     directory = Path.GetDirectoryName(attachment.HeaderIdDirectory) ?? throw new Exception(); | ||||
|                     File.Copy(attachment.SourceFileName, Path.Combine(directory, attachment.AttachmentId, attachment.DestinationFileName), overwrite: true); | ||||
|                     AttachFile(url, attachment); | ||||
|                 } | ||||
|             } | ||||
|             //MessageBox.Show(r.ToString()); | ||||
|         } | ||||
|  | ||||
| @ -23,7 +23,7 @@ public class ProcessDataStandardFormat | ||||
|     public static string GetPDSFText(IFileRead fileRead, Logistics logistics, JsonElement[] jsonElements, string logisticsText) | ||||
|     { | ||||
|         string result; | ||||
|         if (!jsonElements.Any()) | ||||
|         if (jsonElements.Length == 0) | ||||
|             result = string.Empty; | ||||
|         else | ||||
|         { | ||||
| @ -146,7 +146,7 @@ public class ProcessDataStandardFormat | ||||
|         string logistics = pdsf.Item1; | ||||
|         string[] columns = pdsf.Item2; | ||||
|         string[] bodyLines = pdsf.Item3; | ||||
|         if (!bodyLines.Any() || !bodyLines[0].Contains('\t')) | ||||
|         if (bodyLines.Length == 0 || !bodyLines[0].Contains('\t')) | ||||
|             results = JsonSerializer.Deserialize<JsonElement[]>("[]"); | ||||
|         else | ||||
|         { | ||||
| @ -211,9 +211,10 @@ public class ProcessDataStandardFormat | ||||
|     public static Tuple<string, Dictionary<Test, Dictionary<string, List<string>>>> GetTestDictionary(Tuple<string, string[], string[]> pdsf) | ||||
|     { | ||||
|         Dictionary<Test, Dictionary<string, List<string>>> results = new(); | ||||
|         List<string> collection; | ||||
|         string testColumn = nameof(Test); | ||||
|         Dictionary<string, List<string>> keyValuePairs = GetDictionary(pdsf); | ||||
|         if (!keyValuePairs.ContainsKey(testColumn)) | ||||
|         if (!keyValuePairs.TryGetValue(testColumn, out collection)) | ||||
|             throw new Exception(); | ||||
|         int min; | ||||
|         int max; | ||||
| @ -221,9 +222,9 @@ public class ProcessDataStandardFormat | ||||
|         List<string> vs; | ||||
|         string columnKey; | ||||
|         Dictionary<Test, List<int>> tests = new(); | ||||
|         for (int i = 0; i < keyValuePairs[testColumn].Count; i++) | ||||
|         for (int i = 0; i < collection.Count; i++) | ||||
|         { | ||||
|             if (Enum.TryParse(keyValuePairs[testColumn][i], out Test test)) | ||||
|             if (Enum.TryParse(collection[i], out Test test)) | ||||
|             { | ||||
|                 if (!results.ContainsKey(test)) | ||||
|                 { | ||||
| @ -325,7 +326,7 @@ public class ProcessDataStandardFormat | ||||
|                     _ = line.Append(';'); | ||||
|                 } | ||||
|             } | ||||
|             if (!pairedParameterNames.Any()) | ||||
|             if (pairedParameterNames.Count == 0) | ||||
|             { | ||||
|                 _ = line.Remove(line.Length - 1, 1); | ||||
|                 _ = result.AppendLine(line.ToString()); | ||||
|  | ||||
| @ -14,6 +14,7 @@ public enum Test | ||||
|     CandelaPSL = 38, | ||||
|     CandelaVerify = 37, | ||||
|     CDE = 24, | ||||
|     Climatec = 54, //Largest | ||||
|     CV = 3, | ||||
|     DailyRPMAverage = 19, | ||||
|     DailyRPMPLRatio = 20, | ||||
| @ -38,7 +39,7 @@ public enum Test | ||||
|     RPMPLRatio = 17, | ||||
|     RPMXY = 15, | ||||
|     SP1 = 8, | ||||
|     SRP2100 = 53, //Largest | ||||
|     SRP2100 = 53, | ||||
|     Tencor = 7, | ||||
|     UV = 35, | ||||
|     VerificationLehighton = 14, | ||||
|  | ||||
		Reference in New Issue
	
	Block a user