diff --git a/Source/CSharpAnalytics/AutoMeasurement/BaseAutoMeasurement.cs b/Source/CSharpAnalytics/AutoMeasurement/BaseAutoMeasurement.cs index ea0aa7e..aad77a3 100644 --- a/Source/CSharpAnalytics/AutoMeasurement/BaseAutoMeasurement.cs +++ b/Source/CSharpAnalytics/AutoMeasurement/BaseAutoMeasurement.cs @@ -201,8 +201,7 @@ protected async Task StartRequesterAsync() /// /// Suspend the requester and preserve any unsent URIs. /// - /// Task that completes when the requester has been suspended. - protected async Task StopRequesterAsync() + protected void StopRequesterAsync() { var safeBackgroundRequester = backgroundRequester; if (safeBackgroundRequester == null) return; @@ -210,12 +209,12 @@ protected async Task StopRequesterAsync() var recentRequestsToPersist = new List(); if (safeBackgroundRequester.IsStarted) { - var pendingRequests = await safeBackgroundRequester.StopAsync(); + var pendingRequests = safeBackgroundRequester.StopAsync().GetAwaiter().GetResult(); recentRequestsToPersist = pendingRequests.Skip(pendingRequests.Count - MaximumRequestsToPersist).ToList(); } - await Save(recentRequestsToPersist, QueueStorageName); - await Save(sessionManager.GetState(), SessionStorageName); + Save(recentRequestsToPersist, QueueStorageName); + Save(sessionManager.GetState(), SessionStorageName); safeBackgroundRequester.Dispose(); backgroundRequester = null; diff --git a/Source/CSharpAnalytics/AutoMeasurement/WinFormsAutoMeasurement.cs b/Source/CSharpAnalytics/AutoMeasurement/WinFormsAutoMeasurement.cs index 71b4bf4..9ed568b 100644 --- a/Source/CSharpAnalytics/AutoMeasurement/WinFormsAutoMeasurement.cs +++ b/Source/CSharpAnalytics/AutoMeasurement/WinFormsAutoMeasurement.cs @@ -105,10 +105,10 @@ protected override bool IsInternetAvailable() /// /// /// - private async void ApplicationOnExit(object sender, EventArgs eventArgs) + private void ApplicationOnExit(object sender, EventArgs eventArgs) { UnhookEvents(); - await StopRequesterAsync(); + StopRequesterAsync(); } } } \ No newline at end of file diff --git a/Source/CSharpAnalytics/AutoMeasurement/WpfAutoMeasurement.cs b/Source/CSharpAnalytics/AutoMeasurement/WpfAutoMeasurement.cs index 48e8346..42e3264 100644 --- a/Source/CSharpAnalytics/AutoMeasurement/WpfAutoMeasurement.cs +++ b/Source/CSharpAnalytics/AutoMeasurement/WpfAutoMeasurement.cs @@ -114,10 +114,10 @@ protected override bool IsInternetAvailable() /// /// /// - private async void ApplicationOnExit(object sender, EventArgs eventArgs) + private void ApplicationOnExit(object sender, EventArgs eventArgs) { UnhookEvents(); - await StopRequesterAsync(); + StopRequesterAsync(); } } } \ No newline at end of file diff --git a/Source/CSharpAnalytics/Serializers/AppDataContractSerializer.cs b/Source/CSharpAnalytics/Serializers/AppDataContractSerializer.cs index 1ce8243..c8dc82d 100644 --- a/Source/CSharpAnalytics/Serializers/AppDataContractSerializer.cs +++ b/Source/CSharpAnalytics/Serializers/AppDataContractSerializer.cs @@ -3,6 +3,7 @@ using System.Reflection; using System.Runtime.Serialization; using System.Threading.Tasks; +using System.Xml; namespace CSharpAnalytics.Serializers { @@ -48,36 +49,32 @@ private static string GetDefaultFolderPath() public static async Task Restore(string filename = null, bool deleteBadData = false) { var serializer = new DataContractSerializer(typeof(T), new[] { typeof(DateTimeOffset) }); + var settings = new XmlReaderSettings { Async = true }; try { var file = GetFilePath(filename); - try { - using (var inputStream = new FileStream(file, FileMode.Open, FileAccess.Read, FileShare.Read, 4096, true)) + using (var fileStream = new FileStream(file, FileMode.Open, FileAccess.Read, FileShare.Read, 4096, true)) + using (var xmlReader = XmlReader.Create(fileStream, settings)) { - if (inputStream.Length == 0) - { - return default(T); - } - - using (var memoryStream = new MemoryStream()) - { - await inputStream.CopyToAsync(memoryStream); - await inputStream.FlushAsync(); - memoryStream.Seek(0, SeekOrigin.Begin); - - return (T)serializer.ReadObject(memoryStream); - } + await xmlReader.ReadAsync(); + return (T)serializer.ReadObject(xmlReader); } } catch (SerializationException) { if (deleteBadData) File.Delete(file); - throw; } + catch (XmlException) + { + if (deleteBadData) + File.Delete(file); + } + + return default(T); } catch (FileNotFoundException) { @@ -95,20 +92,23 @@ public static async Task Restore(string filename = null, bool deleteBadDat public static async Task Save(T value, string filename = null) { var serializer = new DataContractSerializer(typeof(T), new[] { typeof(DateTimeOffset) }); - + var settings = new XmlWriterSettings { Indent = true, Async = true }; var file = GetFilePath(filename); - using (var memoryStream = new MemoryStream()) + try { - serializer.WriteObject(memoryStream, value); - using (var fileStream = new FileStream(file, FileMode.Create, FileAccess.Write, FileShare.None, 4096, true)) + using (var xmlWriter = XmlWriter.Create(fileStream, settings)) { - memoryStream.Seek(0, SeekOrigin.Begin); - await memoryStream.CopyToAsync(fileStream); - await fileStream.FlushAsync(); + serializer.WriteObject(xmlWriter, value); + await xmlWriter.FlushAsync(); } } + catch (UnauthorizedAccessException) + { + System.Diagnostics.Debug.WriteLine( + "Failed to save to {0}. You may have insufficient rights or a synchronization may be occuring.", file); + } } /// @@ -125,4 +125,4 @@ private static string GetFilePath(string filename) return Path.Combine(FolderPath, filename ?? typeof(T).Name); } } -} \ No newline at end of file +}