Compare commits
	
		
			1 Commits
		
	
	
		
			10-14-a
			...
			65b8bc0e6f
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 65b8bc0e6f | 
| @ -9,7 +9,5 @@ internal class Constant | |||||||
|     public string Date { get; } = "Date:"; |     public string Date { get; } = "Date:"; | ||||||
|     public string StdDev { get; } = "Std Dev:"; |     public string StdDev { get; } = "Std Dev:"; | ||||||
|     public string Average { get; } = "Average:"; |     public string Average { get; } = "Average:"; | ||||||
|     public string Statistics { get; } = "Statistics:"; |  | ||||||
|     public string DatabaseId { get; } = "Database ID:"; |  | ||||||
|  |  | ||||||
| } | } | ||||||
| @ -1,7 +1,6 @@ | |||||||
| using System; | using System; | ||||||
| using System.Collections.Generic; | using System.Collections.Generic; | ||||||
| using System.Collections.ObjectModel; | using System.Collections.ObjectModel; | ||||||
| using System.Linq; |  | ||||||
| using System.Text.Json.Serialization; | using System.Text.Json.Serialization; | ||||||
|  |  | ||||||
| namespace Adaptation.FileHandlers.pcl; | namespace Adaptation.FileHandlers.pcl; | ||||||
| @ -216,35 +215,17 @@ public class Header | |||||||
|         return GetBefore(text, i, "\n", false); |         return GetBefore(text, i, "\n", false); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private static string? GetText(ReadOnlyDictionary<string, string> pages, Constant constant) |     internal static Header Get(ReadOnlyDictionary<string, string> pages, Constant constant, string headerFileName) | ||||||
|     { |  | ||||||
|         string? text; |  | ||||||
|         string? headerFileName = null; |  | ||||||
|         foreach (KeyValuePair<string, string> keyValuePair in pages) |  | ||||||
|         { |  | ||||||
|             if (!pages.TryGetValue(keyValuePair.Key, out text)) |  | ||||||
|                 throw new Exception(); |  | ||||||
|             if (!text.Contains(constant.Statistics)) |  | ||||||
|                 continue; |  | ||||||
|             headerFileName = keyValuePair.Key; |  | ||||||
|         } |  | ||||||
|         headerFileName ??= pages.Count == 0 ? string.Empty : pages.ElementAt(pages.Count - 1).Key; |  | ||||||
|         if (pages.Count == 0 || !pages.TryGetValue(headerFileName, out text)) |  | ||||||
|             text = null; |  | ||||||
|         return text; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     internal static Header Get(ReadOnlyDictionary<string, string> pages, Constant constant) |  | ||||||
|     { |     { | ||||||
|         Header? result; |         Header? result; | ||||||
|         string id; |         string id; | ||||||
|  |         string? text; | ||||||
|         string[] segmentsB; |         string[] segmentsB; | ||||||
|         string[] segmentsC; |         string[] segmentsC; | ||||||
|         int[] i = new int[] { 0 }; |         int[] i = new int[] { 0 }; | ||||||
|         WaferSummary waferSummary; |         WaferSummary waferSummary; | ||||||
|         List<WaferSummary> collection = new(); |         List<WaferSummary> collection = new(); | ||||||
|         string? text = GetText(pages, constant); |         if (!pages.TryGetValue(headerFileName, out text)) | ||||||
|         if (string.IsNullOrEmpty(text)) |  | ||||||
|             throw new Exception(); |             throw new Exception(); | ||||||
|         ScanPast(text, i, constant.Date); |         ScanPast(text, i, constant.Date); | ||||||
|         string date = GetToEOL(text, i); |         string date = GetToEOL(text, i); | ||||||
|  | |||||||
| @ -24,13 +24,13 @@ internal class Run | |||||||
|         Wafers = wafers; |         Wafers = wafers; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private static ReadOnlyCollection<Wafer> GetLastWaferForEachSlot(ReadOnlyDictionary<string, string> pages, Constant constant, Header header) |     private static ReadOnlyCollection<Wafer> GetLastWaferForEachSlot(ReadOnlyDictionary<string, string> pages, Constant constant, string headerFileName, Header header) | ||||||
|     { |     { | ||||||
|         List<Wafer> results = new(); |         List<Wafer> results = new(); | ||||||
|         string id; |         string id; | ||||||
|         Wafer wafer; |         Wafer wafer; | ||||||
|         ReadOnlyCollection<Wafer>? wafers; |         ReadOnlyCollection<Wafer>? wafers; | ||||||
|         ReadOnlyDictionary<string, ReadOnlyCollection<Wafer>> keyValuePairs = Wafer.Get(pages, constant); |         ReadOnlyDictionary<string, ReadOnlyCollection<Wafer>> keyValuePairs = Wafer.Get(pages, constant, headerFileName); | ||||||
|         ReadOnlyCollection<string> waferIds = GetWaferIds(header); |         ReadOnlyCollection<string> waferIds = GetWaferIds(header); | ||||||
|         for (int i = 0; i < waferIds.Count; i++) |         for (int i = 0; i < waferIds.Count; i++) | ||||||
|         { |         { | ||||||
| @ -123,12 +123,13 @@ internal class Run | |||||||
|     { |     { | ||||||
|         Run? result; |         Run? result; | ||||||
|         Constant constant = new(); |         Constant constant = new(); | ||||||
|         Header? header = Header.Get(pages, constant); |         string headerFileName = pages.ElementAt(pages.Count - 1).Key; | ||||||
|  |         Header? header = Header.Get(pages, constant, headerFileName); | ||||||
|         if (header is null) |         if (header is null) | ||||||
|             result = null; |             result = null; | ||||||
|         else |         else | ||||||
|         { |         { | ||||||
|             ReadOnlyCollection<Wafer> wafers = GetLastWaferForEachSlot(pages, constant, header); |             ReadOnlyCollection<Wafer> wafers = GetLastWaferForEachSlot(pages, constant, headerFileName, header); | ||||||
|             result = new(header, wafers); |             result = new(header, wafers); | ||||||
|             WriteJson(logistics, fileInfoCollection, result); |             WriteJson(logistics, fileInfoCollection, result); | ||||||
|             WriteCommaSeparatedValues(logistics, result); |             WriteCommaSeparatedValues(logistics, result); | ||||||
|  | |||||||
| @ -114,7 +114,7 @@ public class Wafer | |||||||
|     public string Thruput { get; } |     public string Thruput { get; } | ||||||
|     public string Recipe { get; } |     public string Recipe { get; } | ||||||
|  |  | ||||||
|     internal static ReadOnlyDictionary<string, ReadOnlyCollection<Wafer>> Get(ReadOnlyDictionary<string, string> pages, Constant constant) |     internal static ReadOnlyDictionary<string, ReadOnlyCollection<Wafer>> Get(ReadOnlyDictionary<string, string> pages, Constant constant, string headerFileName) | ||||||
|     { |     { | ||||||
|         Dictionary<string, ReadOnlyCollection<Wafer>> results = new(); |         Dictionary<string, ReadOnlyCollection<Wafer>> results = new(); | ||||||
|         Wafer wafer; |         Wafer wafer; | ||||||
| @ -124,11 +124,15 @@ public class Wafer | |||||||
|         Dictionary<string, List<Wafer>> keyValuePairs = new(); |         Dictionary<string, List<Wafer>> keyValuePairs = new(); | ||||||
|         foreach (KeyValuePair<string, string> keyValuePair in pages) |         foreach (KeyValuePair<string, string> keyValuePair in pages) | ||||||
|         { |         { | ||||||
|  |             if (keyValuePair.Key == headerFileName) | ||||||
|  |                 continue; | ||||||
|  |             if (!pages.ContainsKey(keyValuePair.Key)) | ||||||
|  |                 throw new Exception(); | ||||||
|             i[0] = 0; |             i[0] = 0; | ||||||
|             stringList = new(); |             stringList = new(); | ||||||
|             if (!pages.TryGetValue(keyValuePair.Key, out text)) |             if (!pages.TryGetValue(keyValuePair.Key, out text)) | ||||||
|                 throw new Exception(); |                 throw new Exception(); | ||||||
|             if (string.IsNullOrEmpty(text) || !text.Contains(constant.Id) || text.Contains(constant.Statistics) || text.Contains(constant.DatabaseId)) |             if (string.IsNullOrEmpty(text) || !text.Contains(constant.Id)) | ||||||
|                 continue; |                 continue; | ||||||
|             Header.ScanPast(text, i, constant.Date); |             Header.ScanPast(text, i, constant.Date); | ||||||
|             string date = Header.GetToEOL(text, i); |             string date = Header.GetToEOL(text, i); | ||||||
|  | |||||||
| @ -9,7 +9,5 @@ internal class Constant | |||||||
|     public string Date { get; } = "Date:"; |     public string Date { get; } = "Date:"; | ||||||
|     public string StdDev { get; } = "Std Dev:"; |     public string StdDev { get; } = "Std Dev:"; | ||||||
|     public string Average { get; } = "Average:"; |     public string Average { get; } = "Average:"; | ||||||
|     public string Statistics { get; } = "Statistics:"; |  | ||||||
|     public string DatabaseId { get; } = "Database ID:"; |  | ||||||
|  |  | ||||||
| } | } | ||||||
| @ -1,7 +1,6 @@ | |||||||
| using System; | using System; | ||||||
| using System.Collections.Generic; | using System.Collections.Generic; | ||||||
| using System.Collections.ObjectModel; | using System.Collections.ObjectModel; | ||||||
| using System.Linq; |  | ||||||
| using System.Text.Json.Serialization; | using System.Text.Json.Serialization; | ||||||
|  |  | ||||||
| namespace Adaptation.FileHandlers.pdsf; | namespace Adaptation.FileHandlers.pdsf; | ||||||
| @ -216,35 +215,17 @@ public class Header | |||||||
|         return GetBefore(text, i, "\n", false); |         return GetBefore(text, i, "\n", false); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private static string? GetText(ReadOnlyDictionary<string, string> pages, Constant constant) |     internal static Header Get(ReadOnlyDictionary<string, string> pages, Constant constant, string headerFileName) | ||||||
|     { |  | ||||||
|         string? text; |  | ||||||
|         string? headerFileName = null; |  | ||||||
|         foreach (KeyValuePair<string, string> keyValuePair in pages) |  | ||||||
|         { |  | ||||||
|             if (!pages.TryGetValue(keyValuePair.Key, out text)) |  | ||||||
|                 throw new Exception(); |  | ||||||
|             if (!text.Contains(constant.Statistics)) |  | ||||||
|                 continue; |  | ||||||
|             headerFileName = keyValuePair.Key; |  | ||||||
|         } |  | ||||||
|         headerFileName ??= pages.Count == 0 ? string.Empty : pages.ElementAt(pages.Count - 1).Key; |  | ||||||
|         if (pages.Count == 0 || !pages.TryGetValue(headerFileName, out text)) |  | ||||||
|             text = null; |  | ||||||
|         return text; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     internal static Header Get(ReadOnlyDictionary<string, string> pages, Constant constant) |  | ||||||
|     { |     { | ||||||
|         Header? result; |         Header? result; | ||||||
|         string id; |         string id; | ||||||
|  |         string? text; | ||||||
|         string[] segmentsB; |         string[] segmentsB; | ||||||
|         string[] segmentsC; |         string[] segmentsC; | ||||||
|         int[] i = new int[] { 0 }; |         int[] i = new int[] { 0 }; | ||||||
|         WaferSummary waferSummary; |         WaferSummary waferSummary; | ||||||
|         List<WaferSummary> collection = new(); |         List<WaferSummary> collection = new(); | ||||||
|         string? text = GetText(pages, constant); |         if (!pages.TryGetValue(headerFileName, out text)) | ||||||
|         if (string.IsNullOrEmpty(text)) |  | ||||||
|             throw new Exception(); |             throw new Exception(); | ||||||
|         ScanPast(text, i, constant.Date); |         ScanPast(text, i, constant.Date); | ||||||
|         string date = GetToEOL(text, i); |         string date = GetToEOL(text, i); | ||||||
|  | |||||||
| @ -24,13 +24,13 @@ internal class Run | |||||||
|         Wafers = wafers; |         Wafers = wafers; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     private static ReadOnlyCollection<Wafer> GetLastWaferForEachSlot(ReadOnlyDictionary<string, string> pages, Constant constant, Header header) |     private static ReadOnlyCollection<Wafer> GetLastWaferForEachSlot(ReadOnlyDictionary<string, string> pages, Constant constant, string headerFileName, Header header) | ||||||
|     { |     { | ||||||
|         List<Wafer> results = new(); |         List<Wafer> results = new(); | ||||||
|         string id; |         string id; | ||||||
|         Wafer wafer; |         Wafer wafer; | ||||||
|         ReadOnlyCollection<Wafer>? wafers; |         ReadOnlyCollection<Wafer>? wafers; | ||||||
|         ReadOnlyDictionary<string, ReadOnlyCollection<Wafer>> keyValuePairs = Wafer.Get(pages, constant); |         ReadOnlyDictionary<string, ReadOnlyCollection<Wafer>> keyValuePairs = Wafer.Get(pages, constant, headerFileName); | ||||||
|         ReadOnlyCollection<string> waferIds = GetWaferIds(header); |         ReadOnlyCollection<string> waferIds = GetWaferIds(header); | ||||||
|         for (int i = 0; i < waferIds.Count; i++) |         for (int i = 0; i < waferIds.Count; i++) | ||||||
|         { |         { | ||||||
| @ -123,12 +123,13 @@ internal class Run | |||||||
|     { |     { | ||||||
|         Run? result; |         Run? result; | ||||||
|         Constant constant = new(); |         Constant constant = new(); | ||||||
|         Header? header = Header.Get(pages, constant); |         string headerFileName = pages.ElementAt(pages.Count - 1).Key; | ||||||
|  |         Header? header = Header.Get(pages, constant, headerFileName); | ||||||
|         if (header is null) |         if (header is null) | ||||||
|             result = null; |             result = null; | ||||||
|         else |         else | ||||||
|         { |         { | ||||||
|             ReadOnlyCollection<Wafer> wafers = GetLastWaferForEachSlot(pages, constant, header); |             ReadOnlyCollection<Wafer> wafers = GetLastWaferForEachSlot(pages, constant, headerFileName, header); | ||||||
|             result = new(header, wafers); |             result = new(header, wafers); | ||||||
|             WriteJson(logistics, fileInfoCollection, result); |             WriteJson(logistics, fileInfoCollection, result); | ||||||
|             WriteCommaSeparatedValues(logistics, result); |             WriteCommaSeparatedValues(logistics, result); | ||||||
|  | |||||||
| @ -114,7 +114,7 @@ public class Wafer | |||||||
|     public string Thruput { get; } |     public string Thruput { get; } | ||||||
|     public string Recipe { get; } |     public string Recipe { get; } | ||||||
|  |  | ||||||
|     internal static ReadOnlyDictionary<string, ReadOnlyCollection<Wafer>> Get(ReadOnlyDictionary<string, string> pages, Constant constant) |     internal static ReadOnlyDictionary<string, ReadOnlyCollection<Wafer>> Get(ReadOnlyDictionary<string, string> pages, Constant constant, string headerFileName) | ||||||
|     { |     { | ||||||
|         Dictionary<string, ReadOnlyCollection<Wafer>> results = new(); |         Dictionary<string, ReadOnlyCollection<Wafer>> results = new(); | ||||||
|         Wafer wafer; |         Wafer wafer; | ||||||
| @ -124,12 +124,10 @@ public class Wafer | |||||||
|         Dictionary<string, List<Wafer>> keyValuePairs = new(); |         Dictionary<string, List<Wafer>> keyValuePairs = new(); | ||||||
|         foreach (KeyValuePair<string, string> keyValuePair in pages) |         foreach (KeyValuePair<string, string> keyValuePair in pages) | ||||||
|         { |         { | ||||||
|             i[0] = 0; |             if (keyValuePair.Key == headerFileName) | ||||||
|             stringList = new(); |  | ||||||
|             if (!pages.TryGetValue(keyValuePair.Key, out text)) |  | ||||||
|                 throw new Exception(); |  | ||||||
|             if (string.IsNullOrEmpty(text) || !text.Contains(constant.Id) || text.Contains(constant.Statistics) || text.Contains(constant.DatabaseId)) |  | ||||||
|                 continue; |                 continue; | ||||||
|  |             if (!pages.ContainsKey(keyValuePair.Key)) | ||||||
|  |                 throw new Exception(); | ||||||
|             i[0] = 0; |             i[0] = 0; | ||||||
|             stringList = new(); |             stringList = new(); | ||||||
|             if (!pages.TryGetValue(keyValuePair.Key, out text)) |             if (!pages.TryGetValue(keyValuePair.Key, out text)) | ||||||
|  | |||||||
| @ -54,7 +54,9 @@ public class TENCOR1 | |||||||
|         NonThrowTryCatch(); |         NonThrowTryCatch(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | #if DEBUG | ||||||
|     [Ignore] |     [Ignore] | ||||||
|  | #endif | ||||||
|     [TestMethod] |     [TestMethod] | ||||||
|     public void Production__v2_61_1__TENCOR1__pcl638959627725124236__Extra() |     public void Production__v2_61_1__TENCOR1__pcl638959627725124236__Extra() | ||||||
|     { |     { | ||||||
|  | |||||||
| @ -195,13 +195,13 @@ | |||||||
|       <Version>7.2.4630.5</Version> |       <Version>7.2.4630.5</Version> | ||||||
|     </PackageReference> |     </PackageReference> | ||||||
|     <PackageReference Include="Infineon.EAF.Runtime"> |     <PackageReference Include="Infineon.EAF.Runtime"> | ||||||
|       <Version>2.61.1</Version> |       <Version>2.60.0</Version> | ||||||
|     </PackageReference> |     </PackageReference> | ||||||
|     <PackageReference Include="Pdfbox"> |     <PackageReference Include="Pdfbox"> | ||||||
|       <Version>1.1.1</Version> |       <Version>1.1.1</Version> | ||||||
|     </PackageReference> |     </PackageReference> | ||||||
|     <PackageReference Include="System.Text.Json"> |     <PackageReference Include="System.Text.Json"> | ||||||
|       <Version>8.0.3</Version> |       <Version>8.0.5</Version> | ||||||
|     </PackageReference> |     </PackageReference> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
|   <Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" /> |   <Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" /> | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user