From 0cf8c584f25575025b2163f6e6981d26293dc854 Mon Sep 17 00:00:00 2001 From: Kristian Hellang Date: Thu, 11 Aug 2016 13:27:42 +0200 Subject: [PATCH] Remove Wait call to prevent deadlock --- src/Nancy/IO/RequestStream.cs | 18 ++++-------------- 1 file changed, 4 insertions(+), 14 deletions(-) diff --git a/src/Nancy/IO/RequestStream.cs b/src/Nancy/IO/RequestStream.cs index 8c14745e7f..b7de96a9cb 100644 --- a/src/Nancy/IO/RequestStream.cs +++ b/src/Nancy/IO/RequestStream.cs @@ -2,9 +2,6 @@ { using System; using System.IO; - using System.Threading.Tasks; - - using Nancy.Extensions; /// /// A decorator that can handle moving the stream out from memory and on to disk when the contents reaches a certain length. @@ -74,15 +71,7 @@ public RequestStream(Stream stream, long expectedLength, long thresholdLength, b if (!this.stream.CanSeek) { - var task = - MoveToWritableStream(); - - task.Wait(); - - if (task.IsFaulted) - { - throw new InvalidOperationException("Unable to copy stream", task.Exception); - } + this.MoveToWritableStream(); } this.stream.Position = 0; @@ -93,12 +82,13 @@ public RequestStream(Stream stream, long expectedLength, long thresholdLength, b this.Dispose(false); } - private Task MoveToWritableStream() + private void MoveToWritableStream() { var sourceStream = this.stream; + this.stream = new MemoryStream(BufferSize); - return sourceStream.CopyToAsync(this); + sourceStream.CopyTo(this.stream); } ///