Redpoint.ProgressMonitor 2025.1226.163

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