Redpoint.ProgressMonitor 2025.1216.884

Prefix Reserved
There is a newer version of this package available.
See the version list below for details.
dotnet add package Redpoint.ProgressMonitor --version 2025.1216.884
                    
NuGet\Install-Package Redpoint.ProgressMonitor -Version 2025.1216.884
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Redpoint.ProgressMonitor" Version="2025.1216.884" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Redpoint.ProgressMonitor" Version="2025.1216.884" />
                    
Directory.Packages.props
<PackageReference Include="Redpoint.ProgressMonitor" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add Redpoint.ProgressMonitor --version 2025.1216.884
                    
#r "nuget: Redpoint.ProgressMonitor, 2025.1216.884"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package Redpoint.ProgressMonitor@2025.1216.884
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=Redpoint.ProgressMonitor&version=2025.1216.884
                    
Install as a Cake Addin
#tool nuget:?package=Redpoint.ProgressMonitor&version=2025.1216.884
                    
Install as a Cake Tool

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, or HttpClient 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 support Position or Length, 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 Compatible and additional computed target framework versions.
.NET net9.0 is compatible.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed.  net10.0 was computed.  net10.0-android was computed.  net10.0-browser was computed.  net10.0-ios was computed.  net10.0-maccatalyst was computed.  net10.0-macos was computed.  net10.0-tvos was computed.  net10.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (1)

Showing the top 1 NuGet packages that depend on Redpoint.ProgressMonitor:

Package Downloads
Redpoint.PackageManagement

Provides APIs for installing, upgrading and uninstalling packages with WinGet and Homebrew.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last Updated
2025.1218.595 0 8/6/2025
2025.1218.554 0 8/6/2025
2025.1218.544 0 8/6/2025
2025.1218.523 0 8/6/2025
2025.1218.499 0 8/6/2025
2025.1218.427 0 8/6/2025
2025.1218.415 0 8/6/2025
2025.1218.187 0 8/6/2025
2025.1218.174 0 8/6/2025
2025.1218.148 0 8/6/2025
2025.1218.123 0 8/6/2025
2025.1217.886 7 8/5/2025
2025.1217.560 10 8/5/2025
2025.1217.516 13 8/5/2025
2025.1217.512 13 8/5/2025
2025.1217.503 16 8/5/2025
2025.1216.1103 14 8/4/2025
2025.1216.1025 12 8/4/2025
2025.1216.978 10 8/4/2025
2025.1216.897 11 8/4/2025
2025.1216.893 12 8/4/2025
2025.1216.884 15 8/4/2025
2025.1216.873 11 8/4/2025
2025.1216.824 12 8/4/2025
2025.1216.767 11 8/4/2025
2025.1216.745 15 8/4/2025
2025.1216.411 13 8/4/2025
2025.1216.396 12 8/4/2025
2025.1216.386 12 8/4/2025
2025.1216.357 12 8/4/2025
2025.1216.347 11 8/4/2025
2025.1216.334 13 8/4/2025
2025.1216.319 9 8/4/2025
2025.1215.930 12 8/3/2025
2025.1215.928 15 8/3/2025
2025.1215.911 16 8/3/2025
2025.1215.892 14 8/3/2025
2025.1215.842 15 8/3/2025
2025.1209.1064 90 7/28/2025
2025.1209.1061 84 7/28/2025
2025.1209.1047 83 7/28/2025
2025.1209.1038 85 7/28/2025
2025.1209.1034 84 7/28/2025
2025.1209.948 84 7/28/2025
2025.1209.881 87 7/28/2025
2025.1209.773 92 7/28/2025
2025.1209.765 83 7/28/2025
2025.1209.758 87 7/28/2025
2025.1209.727 87 7/28/2025
2025.1209.658 84 7/28/2025
2025.1209.300 83 7/28/2025
2025.1209.284 86 7/28/2025
2025.1209.264 85 7/28/2025
2025.1209.227 83 7/28/2025
2025.1209.198 85 7/28/2025
2025.1209.179 86 7/28/2025
2025.1208.826 96 7/27/2025
2025.1208.627 59 7/27/2025
2025.1208.617 55 7/27/2025
2025.1208.570 56 7/27/2025
2025.1208.568 56 7/27/2025
2025.1208.566 56 7/27/2025
2025.1206.491 388 7/25/2025
2025.1206.247 416 7/25/2025
2025.1205.230 439 7/24/2025
2025.1203.826 487 7/22/2025
2025.1202.906 434 7/21/2025
2025.1202.904 431 7/21/2025
2025.1202.283 357 7/21/2025
2025.1201.470 180 7/20/2025
2025.1199.287 93 7/18/2025
2025.1198.1048 108 7/17/2025
2025.1198.682 107 7/17/2025
2025.1198.638 108 7/17/2025
2025.1198.574 110 7/17/2025
2025.1198.187 113 7/17/2025
2025.1191.922 139 7/10/2025
2025.1191.235 142 7/10/2025
2025.1190.175 141 7/9/2025
2025.1189.851 141 7/8/2025
2025.1189.841 145 7/8/2025
2025.1187.587 142 7/6/2025
2025.1183.853 137 7/2/2025
2025.1181.644 131 6/30/2025
2025.1175.340 141 6/24/2025
2025.1174.62 138 6/23/2025
2025.1171.352 129 6/20/2025
2025.1169.413 141 6/18/2025
2025.1166.1191 138 6/15/2025
2025.1166.1178 141 6/15/2025
2025.1166.1177 142 6/15/2025
2025.1159.445 124 6/8/2025
2025.1159.364 120 6/8/2025
2025.1159.324 122 6/8/2025
2025.1155.438 146 6/4/2025
2025.1141.1424 150 5/21/2025
2025.1140.383 151 5/20/2025
2025.1140.377 151 5/20/2025
2025.1139.983 151 5/19/2025
2025.1139.952 147 5/19/2025
2025.1139.941 151 5/19/2025
2025.1139.855 152 5/19/2025
2025.1139.850 145 5/19/2025
2025.1139.837 145 5/19/2025
2025.1139.811 147 5/19/2025
2025.1139.806 148 5/19/2025
2025.1139.796 149 5/19/2025
2025.1139.729 148 5/19/2025
2025.1139.719 148 5/19/2025
2025.1139.706 149 5/19/2025
2025.1139.694 145 5/19/2025
2025.1139.679 149 5/19/2025
2025.1139.662 146 5/19/2025
2025.1139.638 141 5/19/2025
2025.1139.628 142 5/19/2025
2025.1139.626 149 5/19/2025
2025.1139.619 146 5/19/2025
2025.1139.605 144 5/19/2025
2025.1139.600 146 5/19/2025
2025.1139.583 146 5/19/2025
2025.1139.573 149 5/19/2025
2025.1139.564 144 5/19/2025
2025.1139.552 146 5/19/2025
2025.1139.543 144 5/19/2025
2025.1138.909 147 5/18/2025
2025.1136.150 217 5/16/2025
2025.1135.267 221 5/15/2025
2025.1135.143 227 5/15/2025
2025.1133.453 230 5/13/2025
2025.1133.351 234 5/13/2025
2025.1133.349 240 5/13/2025
2025.1133.347 231 5/13/2025
2025.1130.236 81 5/10/2025
2025.1129.831 111 5/9/2025
2025.1129.346 152 5/9/2025
2023.1176.407 214 6/25/2023
2023.1176.396 176 6/25/2023
2023.1176.363 186 6/25/2023
2023.1176.360 222 6/25/2023
2023.1175.638 181 6/24/2023
2023.1170.907 177 6/19/2023
2023.1170.900 179 6/19/2023
2023.1167.562 180 6/16/2023
2023.1167.556 184 6/16/2023
2023.1167.496 197 6/16/2023
2023.1166.1008 200 6/15/2023
2023.1166.938 173 6/15/2023
2023.1166.713 191 6/15/2023
2023.1166.699 181 6/15/2023
2023.1165.1065 191 6/14/2023
2023.1165.888 187 6/14/2023
2023.1165.878 187 6/14/2023
2023.1165.861 177 6/14/2023
2023.1165.828 188 6/14/2023
2023.1165.686 201 6/14/2023
2023.1165.653 183 6/14/2023
2023.377.1003 273 5/31/2023
2023.377.909 204 5/31/2023
2023.377.558 201 5/31/2023
2023.365.1417 250 5/30/2023
2023.365.1350 189 5/30/2023
2023.365.1327 185 5/30/2023
2023.365.1306 203 5/30/2023
2023.365.1198 214 5/30/2023
2023.365.1046 192 5/30/2023
2023.365.710 191 5/30/2023
2023.365.703 203 5/30/2023
2023.365.336 192 5/30/2023
2023.174.636 189 6/14/2023
2023.174.616 172 6/14/2023
2023.174.442 187 6/14/2023
2023.162.1243 183 6/13/2023
2023.162.1225 190 6/13/2023
2023.162.1023 176 6/13/2023
2023.162.948 181 6/13/2023
2023.162.865 186 6/13/2023
2023.162.770 210 6/13/2023
2023.162.734 200 6/13/2023
2023.162.701 191 6/13/2023
2023.162.470 201 6/13/2023
2023.162.418 184 6/13/2023
2023.150.1142 185 6/12/2023
2023.150.1121 188 6/12/2023
2023.150.1095 188 6/12/2023
2023.150.1081 175 6/12/2023
2023.150.1066 184 6/12/2023
2023.150.999 175 6/12/2023
2023.150.916 202 6/12/2023
2023.150.865 187 6/12/2023
2023.150.831 187 6/12/2023
2023.150.774 184 6/12/2023
2023.150.613 182 6/12/2023
2023.150.558 197 6/12/2023
2023.150.456 208 6/12/2023
2023.150.450 209 6/12/2023
2023.150.220 207 6/12/2023
2023.150.179 212 6/12/2023
2023.150.167 214 6/12/2023
2023.138.864 198 6/11/2023
2023.138.837 193 6/11/2023
2023.138.363 203 6/11/2023
2023.138.224 232 6/11/2023
2023.138.213 177 6/11/2023
2023.126.1167 205 6/11/2023
2023.126.1148 199 6/10/2023
2023.126.838 211 6/10/2023
2023.126.794 204 6/10/2023
2023.126.745 205 6/10/2023
2023.126.714 217 6/10/2023
2023.126.662 213 6/10/2023
2023.114.544 189 6/9/2023
2023.114.351 198 6/9/2023
2023.90.1030 203 6/7/2023
2023.90.1009 186 6/7/2023
2023.54.1152 188 6/4/2023
2023.54.419 209 6/4/2023
2023.54.198 189 6/4/2023
2023.54.60 170 6/4/2023
2023.54.48 203 6/4/2023
2023.42.745 189 6/3/2023
2023.30.1191 189 6/2/2023
2023.30.1172 203 6/2/2023
2023.30.1163 193 6/2/2023
2023.30.1147 199 6/2/2023
2023.30.1136 216 6/2/2023
2023.30.765 211 6/2/2023
2023.30.761 198 6/2/2023
2023.30.747 211 6/2/2023
2023.30.734 199 6/2/2023