Redpoint.ProgressMonitor 2025.1236.697

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.1236.697
                    
NuGet\Install-Package Redpoint.ProgressMonitor -Version 2025.1236.697
                    
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.1236.697" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Redpoint.ProgressMonitor" Version="2025.1236.697" />
                    
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.1236.697
                    
#r "nuget: Redpoint.ProgressMonitor, 2025.1236.697"
                    
#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.1236.697
                    
#: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.1236.697
                    
Install as a Cake Addin
#tool nuget:?package=Redpoint.ProgressMonitor&version=2025.1236.697
                    
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.1239.82 0 8/27/2025
2025.1236.697 20 8/24/2025
2025.1235.897 20 8/23/2025
2025.1234.740 50 8/22/2025
2025.1234.625 56 8/22/2025
2025.1234.484 62 8/22/2025
2025.1234.426 65 8/22/2025
2025.1234.329 70 8/22/2025
2025.1234.304 73 8/22/2025
2025.1234.279 74 8/22/2025
2025.1234.210 80 8/22/2025
2025.1234.185 82 8/22/2025
2025.1234.108 84 8/22/2025
2025.1234.70 83 8/22/2025
2025.1233.957 93 8/21/2025
2025.1233.933 90 8/21/2025
2025.1233.915 87 8/21/2025
2025.1233.885 87 8/21/2025
2025.1233.764 91 8/21/2025
2025.1233.694 90 8/21/2025
2025.1233.677 90 8/21/2025
2025.1233.212 90 8/21/2025
2025.1233.74 85 8/21/2025
2025.1233.72 86 8/21/2025
2025.1233.28 86 8/21/2025
2025.1232.155 90 8/20/2025
2025.1232.154 87 8/20/2025
2025.1232.104 89 8/20/2025
2025.1232.102 88 8/20/2025
2025.1231.1026 90 8/19/2025
2025.1231.941 91 8/19/2025
2025.1231.499 87 8/19/2025
2025.1231.484 88 8/19/2025
2025.1231.297 88 8/19/2025
2025.1230.859 116 8/18/2025
2025.1228.220 48 8/16/2025
2025.1227.934 75 8/15/2025
2025.1227.904 74 8/15/2025
2025.1227.852 73 8/15/2025
2025.1227.816 75 8/15/2025
2025.1227.77 116 8/15/2025
2025.1226.857 122 8/14/2025
2025.1226.472 124 8/14/2025
2025.1226.163 124 8/14/2025
2025.1222.583 131 8/10/2025
2025.1222.562 128 8/10/2025
2025.1222.437 131 8/10/2025
2025.1222.425 127 8/10/2025
2025.1220.271 193 8/8/2025
2025.1220.225 193 8/8/2025
2025.1220.80 201 8/8/2025
2025.1219.568 204 8/7/2025
2025.1219.546 208 8/7/2025
2025.1219.514 206 8/7/2025
2025.1219.513 203 8/7/2025
2025.1219.511 202 8/7/2025
2025.1219.421 205 8/7/2025
2025.1219.377 206 8/7/2025
2025.1219.362 208 8/7/2025
2025.1219.361 204 8/7/2025
2025.1218.1281 209 8/6/2025
2025.1218.1266 205 8/6/2025
2025.1218.1264 208 8/6/2025
2025.1218.1255 208 8/6/2025
2025.1218.1223 207 8/6/2025
2025.1218.1180 208 8/6/2025
2025.1218.1166 202 8/6/2025
2025.1218.1154 205 8/6/2025
2025.1218.1088 209 8/6/2025
2025.1218.595 207 8/6/2025
2025.1218.554 206 8/6/2025
2025.1218.544 208 8/6/2025
2025.1218.523 204 8/6/2025
2025.1218.499 208 8/6/2025
2025.1218.427 211 8/6/2025
2025.1218.415 206 8/6/2025
2025.1218.187 220 8/6/2025
2025.1218.174 217 8/6/2025
2025.1218.148 216 8/6/2025
2025.1218.123 213 8/6/2025
2025.1217.886 221 8/5/2025
2025.1217.560 220 8/5/2025
2025.1217.516 222 8/5/2025
2025.1217.512 222 8/5/2025
2025.1217.503 224 8/5/2025
2025.1216.1103 185 8/4/2025
2025.1216.1025 183 8/4/2025
2025.1216.978 165 8/4/2025
2025.1216.897 162 8/4/2025
2025.1216.893 164 8/4/2025
2025.1216.884 166 8/4/2025
2025.1216.873 162 8/4/2025
2025.1216.824 164 8/4/2025
2025.1216.767 163 8/4/2025
2025.1216.745 168 8/4/2025
2025.1216.411 142 8/4/2025
2025.1216.396 140 8/4/2025
2025.1216.386 140 8/4/2025
2025.1216.357 140 8/4/2025
2025.1216.347 138 8/4/2025
2025.1216.334 141 8/4/2025
2025.1216.319 136 8/4/2025
2025.1215.930 105 8/3/2025
2025.1215.928 108 8/3/2025
2025.1215.911 109 8/3/2025
2025.1215.892 108 8/3/2025
2025.1215.842 108 8/3/2025
2025.1209.1064 98 7/28/2025
2025.1209.1061 92 7/28/2025
2025.1209.1047 91 7/28/2025
2025.1209.1038 94 7/28/2025
2025.1209.1034 92 7/28/2025
2025.1209.948 92 7/28/2025
2025.1209.881 95 7/28/2025
2025.1209.773 100 7/28/2025
2025.1209.765 91 7/28/2025
2025.1209.758 95 7/28/2025
2025.1209.727 96 7/28/2025
2025.1209.658 92 7/28/2025
2025.1209.300 91 7/28/2025
2025.1209.284 94 7/28/2025
2025.1209.264 93 7/28/2025
2025.1209.227 92 7/28/2025
2025.1209.198 93 7/28/2025
2025.1209.179 94 7/28/2025
2025.1208.826 103 7/27/2025
2025.1208.627 67 7/27/2025
2025.1208.617 63 7/27/2025
2025.1208.570 63 7/27/2025
2025.1208.568 63 7/27/2025
2025.1208.566 64 7/27/2025
2025.1206.491 394 7/25/2025
2025.1206.247 422 7/25/2025
2025.1205.230 445 7/24/2025
2025.1203.826 494 7/22/2025
2025.1202.906 443 7/21/2025
2025.1202.904 438 7/21/2025
2025.1202.283 363 7/21/2025
2025.1201.470 187 7/20/2025
2025.1199.287 99 7/18/2025
2025.1198.1048 115 7/17/2025
2025.1198.682 113 7/17/2025
2025.1198.638 115 7/17/2025
2025.1198.574 117 7/17/2025
2025.1198.187 120 7/17/2025
2025.1191.922 147 7/10/2025
2025.1191.235 150 7/10/2025
2025.1190.175 149 7/9/2025
2025.1189.851 150 7/8/2025
2025.1189.841 153 7/8/2025
2025.1187.587 151 7/6/2025
2025.1183.853 146 7/2/2025
2025.1181.644 139 6/30/2025
2025.1175.340 150 6/24/2025
2025.1174.62 148 6/23/2025
2025.1171.352 138 6/20/2025
2025.1169.413 149 6/18/2025
2025.1166.1191 147 6/15/2025
2025.1166.1178 149 6/15/2025
2025.1166.1177 149 6/15/2025
2025.1159.445 131 6/8/2025
2025.1159.364 127 6/8/2025
2025.1159.324 130 6/8/2025
2025.1155.438 152 6/4/2025
2025.1141.1424 157 5/21/2025
2025.1140.383 158 5/20/2025
2025.1140.377 157 5/20/2025
2025.1139.983 159 5/19/2025
2025.1139.952 154 5/19/2025
2025.1139.941 158 5/19/2025
2025.1139.855 158 5/19/2025
2025.1139.850 152 5/19/2025
2025.1139.837 151 5/19/2025
2025.1139.811 153 5/19/2025
2025.1139.806 154 5/19/2025
2025.1139.796 156 5/19/2025
2025.1139.729 155 5/19/2025
2025.1139.719 156 5/19/2025
2025.1139.706 156 5/19/2025
2025.1139.694 153 5/19/2025
2025.1139.679 157 5/19/2025
2025.1139.662 153 5/19/2025
2025.1139.638 148 5/19/2025
2025.1139.628 149 5/19/2025
2025.1139.626 156 5/19/2025
2025.1139.619 154 5/19/2025
2025.1139.605 152 5/19/2025
2025.1139.600 153 5/19/2025
2025.1139.583 154 5/19/2025
2025.1139.573 156 5/19/2025
2025.1139.564 152 5/19/2025
2025.1139.552 154 5/19/2025
2025.1139.543 151 5/19/2025
2025.1138.909 155 5/18/2025
2025.1136.150 225 5/16/2025
2025.1135.267 228 5/15/2025
2025.1135.143 236 5/15/2025
2025.1133.453 236 5/13/2025
2025.1133.351 242 5/13/2025
2025.1133.349 247 5/13/2025
2025.1133.347 239 5/13/2025
2025.1130.236 89 5/10/2025
2025.1129.831 117 5/9/2025
2025.1129.346 159 5/9/2025
2023.1176.407 221 6/25/2023
2023.1176.396 183 6/25/2023
2023.1176.363 195 6/25/2023
2023.1176.360 229 6/25/2023
2023.1175.638 189 6/24/2023
2023.1170.907 185 6/19/2023
2023.1170.900 187 6/19/2023
2023.1167.562 188 6/16/2023
2023.1167.556 194 6/16/2023
2023.1167.496 207 6/16/2023
2023.1166.1008 210 6/15/2023
2023.1166.938 182 6/15/2023
2023.1166.713 202 6/15/2023
2023.1166.699 190 6/15/2023
2023.1165.1065 199 6/14/2023
2023.1165.888 196 6/14/2023
2023.1165.878 195 6/14/2023
2023.1165.861 186 6/14/2023
2023.1165.828 197 6/14/2023
2023.1165.686 208 6/14/2023
2023.1165.653 191 6/14/2023
2023.377.1003 282 5/31/2023
2023.377.909 214 5/31/2023
2023.377.558 211 5/31/2023
2023.365.1417 259 5/30/2023
2023.365.1350 199 5/30/2023
2023.365.1327 194 5/30/2023
2023.365.1306 212 5/30/2023
2023.365.1198 223 5/30/2023
2023.365.1046 200 5/30/2023
2023.365.710 200 5/30/2023
2023.365.703 211 5/30/2023
2023.365.336 201 5/30/2023
2023.174.636 199 6/14/2023
2023.174.616 182 6/14/2023
2023.174.442 198 6/14/2023
2023.162.1243 191 6/13/2023
2023.162.1225 198 6/13/2023
2023.162.1023 184 6/13/2023
2023.162.948 190 6/13/2023
2023.162.865 195 6/13/2023
2023.162.770 218 6/13/2023
2023.162.734 208 6/13/2023
2023.162.701 199 6/13/2023
2023.162.470 210 6/13/2023
2023.162.418 193 6/13/2023
2023.150.1142 193 6/12/2023
2023.150.1121 196 6/12/2023
2023.150.1095 198 6/12/2023
2023.150.1081 183 6/12/2023
2023.150.1066 192 6/12/2023
2023.150.999 184 6/12/2023
2023.150.916 211 6/12/2023
2023.150.865 195 6/12/2023
2023.150.831 195 6/12/2023
2023.150.774 193 6/12/2023
2023.150.613 191 6/12/2023
2023.150.558 205 6/12/2023
2023.150.456 217 6/12/2023
2023.150.450 219 6/12/2023
2023.150.220 216 6/12/2023
2023.150.179 221 6/12/2023
2023.150.167 223 6/12/2023
2023.138.864 206 6/11/2023
2023.138.837 202 6/11/2023
2023.138.363 211 6/11/2023
2023.138.224 241 6/11/2023
2023.138.213 185 6/11/2023
2023.126.1167 214 6/11/2023
2023.126.1148 207 6/10/2023
2023.126.838 219 6/10/2023
2023.126.794 214 6/10/2023
2023.126.745 214 6/10/2023
2023.126.714 225 6/10/2023
2023.126.662 221 6/10/2023
2023.114.544 198 6/9/2023
2023.114.351 207 6/9/2023
2023.90.1030 211 6/7/2023
2023.90.1009 195 6/7/2023
2023.54.1152 196 6/4/2023
2023.54.419 217 6/4/2023
2023.54.198 198 6/4/2023
2023.54.60 181 6/4/2023
2023.54.48 211 6/4/2023
2023.42.745 198 6/3/2023
2023.30.1191 198 6/2/2023
2023.30.1172 210 6/2/2023
2023.30.1163 203 6/2/2023
2023.30.1147 208 6/2/2023
2023.30.1136 226 6/2/2023
2023.30.765 219 6/2/2023
2023.30.761 207 6/2/2023
2023.30.747 220 6/2/2023
2023.30.734 207 6/2/2023