diff options
| author | Luke <luke.pulverenti@gmail.com> | 2017-06-01 03:57:22 -0400 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2017-06-01 03:57:22 -0400 |
| commit | 442d4e669969558256cf16f01a4018292609ba05 (patch) | |
| tree | 82131b8028197a4f5de7b7d3ce40fe61aa60da6a /MediaBrowser.Controller/IO/StreamHelper.cs | |
| parent | 1f5e51b6338096ef6f119802ea595c2cc30daf8e (diff) | |
| parent | b54b7871e39e197d4af19a6c502938fa6178c4fa (diff) | |
Merge pull request #2685 from MediaBrowser/beta
Beta
Diffstat (limited to 'MediaBrowser.Controller/IO/StreamHelper.cs')
| -rw-r--r-- | MediaBrowser.Controller/IO/StreamHelper.cs | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/MediaBrowser.Controller/IO/StreamHelper.cs b/MediaBrowser.Controller/IO/StreamHelper.cs new file mode 100644 index 000000000..af97a0233 --- /dev/null +++ b/MediaBrowser.Controller/IO/StreamHelper.cs @@ -0,0 +1,32 @@ +using System.IO; +using System.Threading; +using System; + +namespace MediaBrowser.Controller.IO +{ + public static class StreamHelper + { + public static void CopyTo(Stream source, Stream destination, int bufferSize, CancellationToken cancellationToken) + { + CopyTo(source, destination, bufferSize, null, cancellationToken); + } + + public static void CopyTo(Stream source, Stream destination, int bufferSize, Action onStarted, CancellationToken cancellationToken) + { + byte[] buffer = new byte[bufferSize]; + int read; + while ((read = source.Read(buffer, 0, buffer.Length)) != 0) + { + cancellationToken.ThrowIfCancellationRequested(); + + destination.Write(buffer, 0, read); + + if (onStarted != null) + { + onStarted(); + onStarted = null; + } + } + } + } +} |
