From fe90f417dc3a963d69da90d2f884b025eea02be5 Mon Sep 17 00:00:00 2001 From: fam007e Date: Wed, 21 Aug 2024 21:05:52 +0600 Subject: [PATCH] Edited 'Update-Progress' Script Utility --- tools/Update-Progress.ps1 | 32 ++++++++++++++++++++++---------- 1 file changed, 22 insertions(+), 10 deletions(-) diff --git a/tools/Update-Progress.ps1 b/tools/Update-Progress.ps1 index 2749f7e0..45ebb88b 100644 --- a/tools/Update-Progress.ps1 +++ b/tools/Update-Progress.ps1 @@ -1,27 +1,42 @@ # Update-Progress.ps1 function Update-Progress { + <# + .SYNOPSIS + A wrapper for PowerShell 'Write-Progress' Cmdlet. + + .PARAMETER StatusMessage + A mandatory parameter which’ll be used when displaying progress bar using 'Write-Progress' Cmdlet. + + .PARAMETER Percent + An integer value (0-100) representing the completion percentage. + + .PARAMETER Activity + The activity name to be displayed in the progress bar. Defaults to "Processing" if not provided. + + .PARAMETER LogProgress + A switch that indicates whether the progress should be logged to a file. + + .EXAMPLE + Update-Progress "Processing files..." 50 "File Processing" -LogProgress + #> + param ( [Parameter(Mandatory, Position = 0)] [ValidateNotNullOrEmpty()] [string]$StatusMessage, - [Parameter(Mandatory, Position = 1)] + [Parameter(Position = 1)] [ValidateRange(0, 100)] [int]$Percent, [Parameter(Position = 2)] - [string]$Activity, + [string]$Activity = "Processing", # Default activity to "Processing" if not provided [Parameter(Position = 3)] [switch]$LogProgress ) - # Default activity to "Processing" if not provided - if (-not $Activity) { - $Activity = "Processing" - } - # Write the progress to the console Write-Progress -Activity $Activity -Status $StatusMessage -PercentComplete $Percent @@ -31,6 +46,3 @@ function Update-Progress { $logMessage | Out-File -FilePath "$PSScriptRoot\progress.log" -Append -Encoding utf8 } } - -# Example Usage: -# Update-Progress "Processing files..." 50 "File Processing" -LogProgress