From 5a001969e4268762aaefb01704ee4312436d55f2 Mon Sep 17 00:00:00 2001 From: cadon Date: Fri, 24 Nov 2023 20:21:40 +0100 Subject: [PATCH] handle export file written when fileWatcher triggers --- .../importExportGun/ImportExportGun.cs | 126 +++++++++++------- 1 file changed, 76 insertions(+), 50 deletions(-) diff --git a/ARKBreedingStats/importExportGun/ImportExportGun.cs b/ARKBreedingStats/importExportGun/ImportExportGun.cs index 0dc1776b..db531457 100644 --- a/ARKBreedingStats/importExportGun/ImportExportGun.cs +++ b/ARKBreedingStats/importExportGun/ImportExportGun.cs @@ -1,5 +1,6 @@ using System; using System.IO; +using System.Threading; using ARKBreedingStats.Library; using ARKBreedingStats.values; using Newtonsoft.Json; @@ -21,35 +22,47 @@ public static Creature ImportCreature(string filePath, out string resultText, ou if (string.IsNullOrEmpty(filePath) || !File.Exists(filePath)) return null; - try + const int tryLoadCount = 3; + const int waitAfterFailedLoadMs = 200; + + for (int tryIndex = 0; tryIndex < tryLoadCount; tryIndex++) { - string jsonText = null; - switch (Path.GetExtension(filePath)) + try { - case ".sav": - jsonText = ReadExportFile.ReadFile(filePath, "DinoExportGunSave_C", out resultText); - break; - case ".json": - jsonText = File.ReadAllText(filePath); - break; + string jsonText = null; + switch (Path.GetExtension(filePath)) + { + case ".sav": + jsonText = ReadExportFile.ReadFile(filePath, "DinoExportGunSave_C", out resultText); + break; + case ".json": + jsonText = File.ReadAllText(filePath); + break; + } + + if (string.IsNullOrEmpty(jsonText)) + { + resultText = $"Error when importing file {filePath}: {resultText}"; + return null; + } + + var exportedCreature = JsonConvert.DeserializeObject(jsonText); + if (exportedCreature == null) return null; + + serverMultipliersHash = exportedCreature.ServerMultipliersHash; + + return ConvertExportGunToCreature(exportedCreature, out resultText); } - - if (string.IsNullOrEmpty(jsonText)) + catch (IOException) when (tryIndex < tryLoadCount - 1) + { + // file is probably still being written. Try up to 3 times again after some time. + Thread.Sleep(waitAfterFailedLoadMs * (1 << tryIndex)); + } + catch (Exception ex) { - resultText = $"Error when importing file {filePath}: {resultText}"; + resultText = $"Error when importing file {filePath}: {ex.Message}"; return null; } - - var exportedCreature = JsonConvert.DeserializeObject(jsonText); - if (exportedCreature == null) return null; - - serverMultipliersHash = exportedCreature.ServerMultipliersHash; - - return ConvertExportGunToCreature(exportedCreature, out resultText); - } - catch (Exception ex) - { - resultText = $"Error when importing file {filePath}: {ex.Message}"; } return null; @@ -142,41 +155,54 @@ internal static ExportGunServerFile ReadServerMultipliers(string filePath, out s if (string.IsNullOrEmpty(filePath) || !File.Exists(filePath)) return null; - try + const int tryLoadCount = 3; + const int waitAfterFailedLoadMs = 200; + + for (int tryIndex = 0; tryIndex < tryLoadCount; tryIndex++) { - string jsonText = null; - string game = null; - switch (Path.GetExtension(filePath)) + try { - case ".sav": - jsonText = ReadExportFile.ReadFile(filePath, "DinoExportGunServerSave_C", out resultText); - game = "ASE"; - break; - case ".json": - jsonText = File.ReadAllText(filePath); - game = "ASA"; - break; + string jsonText = null; + string game = null; + switch (Path.GetExtension(filePath)) + { + case ".sav": + jsonText = ReadExportFile.ReadFile(filePath, "DinoExportGunServerSave_C", out resultText); + game = "ASE"; + break; + case ".json": + jsonText = File.ReadAllText(filePath); + game = "ASA"; + break; + } + + if (jsonText == null) + { + resultText = $"Error when importing file {filePath}: {resultText}"; + return null; + } + + var exportedServerMultipliers = JsonConvert.DeserializeObject(jsonText); + if (exportedServerMultipliers?.WildLevel == null) + { + resultText = $"Unknown error when importing file {filePath}"; + return null; + } + + exportedServerMultipliers.Game = game; + resultText = $"Server multipliers imported from {filePath}"; + return exportedServerMultipliers; } - if (jsonText == null) + catch (IOException) when (tryIndex < tryLoadCount - 1) { - resultText = $"Error when importing file {filePath}: {resultText}"; - return null; + // file is probably still being written. Try up to 3 times again after some time. + Thread.Sleep(waitAfterFailedLoadMs * (1 << tryIndex)); } - - var exportedServerMultipliers = JsonConvert.DeserializeObject(jsonText); - if (exportedServerMultipliers?.WildLevel == null) + catch (Exception ex) { - resultText = $"Unknown error when importing file {filePath}"; + resultText = $"Error when importing file {filePath}: {ex.Message}"; return null; } - - exportedServerMultipliers.Game = game; - resultText = $"Server multipliers imported from {filePath}"; - return exportedServerMultipliers; - } - catch (Exception ex) - { - resultText = $"Error when importing file {filePath}: {ex.Message}"; } return null;