Redpoint.ProgressMonitor
2023.1176.407
Prefix Reserved
dotnet add package Redpoint.ProgressMonitor --version 2023.1176.407
NuGet\Install-Package Redpoint.ProgressMonitor -Version 2023.1176.407
<PackageReference Include="Redpoint.ProgressMonitor" Version="2023.1176.407" />
paket add Redpoint.ProgressMonitor --version 2023.1176.407
#r "nuget: Redpoint.ProgressMonitor, 2023.1176.407"
// Install Redpoint.ProgressMonitor as a Cake Addin #addin nuget:?package=Redpoint.ProgressMonitor&version=2023.1176.407 // Install Redpoint.ProgressMonitor as a Cake Tool #tool nuget:?package=Redpoint.ProgressMonitor&version=2023.1176.407
Redpoint.ProgressMonitor
This library provides APIs for monitoring and reporting the progress of arbitrary operations in console applications.
Read on for the following examples:
Example for a generic stream
You can monitor an operation that uses a stream like so:
// Inject these services.
IProgressFactory _progressFactory;
IMonitorFactory _monitorFactory;
using (var stream = new FileStream(...))
{
// Start monitoring.
var cts = new CancellationTokenSource();
var progress = _progressFactory.CreateProgressForStream(stream);
var monitorTask = Task.Run(async () =>
{
var monitor = _monitorFactory.CreateByteBasedMonitor();
await monitor.MonitorAsync(
progress,
SystemConsole.ConsoleInformation,
SystemConsole.WriteProgressToConsole,
cts.Token);
});
// e.g. hash the stream.
byte[] hashBytes;
using (var hasher = SHA256.Create())
{
hashBytes = await hasher.ComputeHashAsync(stream);
}
// Stop monitoring.
await SystemConsole.CancelAndWaitForConsoleMonitoringTaskAsync(monitorTask, cts);
}
Example for a HTTP download
If you're reporting progress on a HTTP stream, there's a few extra things to keep in mind:
- You need to pass
HttpCompletionOption.ResponseHeadersRead
as the completion option, orHttpClient
will buffer the entire response by default. - You need to wrap the stream you read from in
PositionAwareStream
, which is a class provided by this library. Since the underlying HTTP stream does not supportPosition
orLength
, this wrapping stream tracks the position as the stream is read from and allows the length to be passed in as a constructor parameter (which you should set based on the Content-Length header).
Below is a concise example of how to show the progress of downloading a file:
using (var client = new HttpClient())
{
using (var target = new FileStream(targetPath, FileMode.Create, FileAccess.Write, FileShare.None))
{
var response = await client.GetAsync(downloadUrl, HttpCompletionOption.ResponseHeadersRead);
using (var stream = new PositionAwareStream(
await response.Content.ReadAsStreamAsync(),
response.Content.Headers.ContentLength!.Value))
{
var cts = new CancellationTokenSource();
var progress = _progressFactory.CreateProgressForStream(stream);
var monitorTask = Task.Run(async () =>
{
var monitor = _monitorFactory.CreateByteBasedMonitor();
await monitor.MonitorAsync(
progress,
SystemConsole.ConsoleInformation,
SystemConsole.WriteProgressToConsole,
cts.Token);
});
await stream.CopyToAsync(target);
await SystemConsole.CancelAndWaitForConsoleMonitoringTaskAsync(monitorTask, cts);
}
}
}
The SystemConsole static class
The SystemConsole
type provides common values for monitoring parameters, such as the current console information and rendering progress information to the console. You should replace the static values in the examples above with your own callbacks and values if you're not rendering progress to the console.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net7.0 is compatible. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
.NET Framework | net48 is compatible. net481 was computed. |
-
.NETFramework 4.8
-
net7.0
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
2023.1176.407 | 168 | 6/25/2023 |
2023.1176.396 | 139 | 6/25/2023 |
2023.1176.363 | 151 | 6/25/2023 |
2023.1176.360 | 184 | 6/25/2023 |
2023.1175.638 | 145 | 6/24/2023 |
2023.1170.907 | 139 | 6/19/2023 |
2023.1170.900 | 145 | 6/19/2023 |
2023.1167.562 | 140 | 6/16/2023 |
2023.1167.556 | 142 | 6/16/2023 |
2023.1167.496 | 151 | 6/16/2023 |
2023.1166.1008 | 158 | 6/15/2023 |
2023.1166.938 | 131 | 6/15/2023 |
2023.1166.713 | 152 | 6/15/2023 |
2023.1166.699 | 139 | 6/15/2023 |
2023.1165.1065 | 147 | 6/14/2023 |
2023.1165.888 | 146 | 6/14/2023 |
2023.1165.878 | 148 | 6/14/2023 |
2023.1165.861 | 135 | 6/14/2023 |
2023.1165.828 | 149 | 6/14/2023 |
2023.1165.686 | 162 | 6/14/2023 |
2023.1165.653 | 142 | 6/14/2023 |
2023.377.1003 | 224 | 5/31/2023 |
2023.377.909 | 161 | 5/31/2023 |
2023.377.558 | 161 | 5/31/2023 |
2023.365.1417 | 209 | 5/30/2023 |
2023.365.1350 | 146 | 5/30/2023 |
2023.365.1327 | 143 | 5/30/2023 |
2023.365.1306 | 159 | 5/30/2023 |
2023.365.1198 | 171 | 5/30/2023 |
2023.365.1046 | 148 | 5/30/2023 |
2023.365.710 | 147 | 5/30/2023 |
2023.365.703 | 159 | 5/30/2023 |
2023.365.336 | 149 | 5/30/2023 |
2023.174.636 | 149 | 6/14/2023 |
2023.174.616 | 131 | 6/14/2023 |
2023.174.442 | 141 | 6/14/2023 |
2023.162.1243 | 135 | 6/13/2023 |
2023.162.1225 | 142 | 6/13/2023 |
2023.162.1023 | 131 | 6/13/2023 |
2023.162.948 | 134 | 6/13/2023 |
2023.162.865 | 143 | 6/13/2023 |
2023.162.770 | 164 | 6/13/2023 |
2023.162.734 | 159 | 6/13/2023 |
2023.162.701 | 148 | 6/13/2023 |
2023.162.470 | 161 | 6/13/2023 |
2023.162.418 | 143 | 6/13/2023 |
2023.150.1142 | 144 | 6/12/2023 |
2023.150.1121 | 146 | 6/12/2023 |
2023.150.1095 | 142 | 6/12/2023 |
2023.150.1081 | 131 | 6/12/2023 |
2023.150.1066 | 142 | 6/12/2023 |
2023.150.999 | 131 | 6/12/2023 |
2023.150.916 | 160 | 6/12/2023 |
2023.150.865 | 144 | 6/12/2023 |
2023.150.831 | 144 | 6/12/2023 |
2023.150.774 | 140 | 6/12/2023 |
2023.150.613 | 137 | 6/12/2023 |
2023.150.558 | 153 | 6/12/2023 |
2023.150.456 | 167 | 6/12/2023 |
2023.150.450 | 168 | 6/12/2023 |
2023.150.220 | 164 | 6/12/2023 |
2023.150.179 | 171 | 6/12/2023 |
2023.150.167 | 164 | 6/12/2023 |
2023.138.864 | 157 | 6/11/2023 |
2023.138.837 | 152 | 6/11/2023 |
2023.138.363 | 162 | 6/11/2023 |
2023.138.224 | 187 | 6/11/2023 |
2023.138.213 | 136 | 6/11/2023 |
2023.126.1167 | 165 | 6/11/2023 |
2023.126.1148 | 157 | 6/10/2023 |
2023.126.838 | 168 | 6/10/2023 |
2023.126.794 | 163 | 6/10/2023 |
2023.126.745 | 165 | 6/10/2023 |
2023.126.714 | 173 | 6/10/2023 |
2023.126.662 | 172 | 6/10/2023 |
2023.114.544 | 146 | 6/9/2023 |
2023.114.351 | 158 | 6/9/2023 |
2023.90.1030 | 163 | 6/7/2023 |
2023.90.1009 | 146 | 6/7/2023 |
2023.54.1152 | 145 | 6/4/2023 |
2023.54.419 | 161 | 6/4/2023 |
2023.54.198 | 146 | 6/4/2023 |
2023.54.60 | 126 | 6/4/2023 |
2023.54.48 | 155 | 6/4/2023 |
2023.42.745 | 147 | 6/3/2023 |
2023.30.1191 | 141 | 6/2/2023 |
2023.30.1172 | 161 | 6/2/2023 |
2023.30.1163 | 148 | 6/2/2023 |
2023.30.1147 | 157 | 6/2/2023 |
2023.30.1136 | 167 | 6/2/2023 |
2023.30.765 | 166 | 6/2/2023 |
2023.30.761 | 154 | 6/2/2023 |
2023.30.747 | 171 | 6/2/2023 |
2023.30.734 | 142 | 6/2/2023 |