mirror of
https://github.com/ChrisTitusTech/winutil.git
synced 2024-11-24 03:45:30 +00:00
Runspace Change to fix Tweaks
This commit is contained in:
parent
8e5fcceddb
commit
9d5e681aac
@ -20,31 +20,52 @@ function Invoke-WPFRunspace {
|
|||||||
|
|
||||||
[CmdletBinding()]
|
[CmdletBinding()]
|
||||||
Param (
|
Param (
|
||||||
$ScriptBlock,
|
[Parameter(Mandatory=$true)]
|
||||||
$ArgumentList,
|
[scriptblock]$ScriptBlock,
|
||||||
$DebugPreference
|
[Parameter(Mandatory=$false)]
|
||||||
|
[object[]]$ArgumentList,
|
||||||
|
[Parameter(Mandatory=$false)]
|
||||||
|
[System.Management.Automation.ActionPreference]$DebugPreference = 'SilentlyContinue'
|
||||||
)
|
)
|
||||||
|
|
||||||
# Create a PowerShell instance
|
try {
|
||||||
$script:powershell = [powershell]::Create()
|
# Create a PowerShell instance
|
||||||
|
$powershell = [powershell]::Create()
|
||||||
|
|
||||||
# Add Scriptblock and Arguments to runspace
|
# Add Scriptblock and Arguments to runspace
|
||||||
$script:powershell.AddScript($ScriptBlock)
|
$powershell.AddScript($ScriptBlock)
|
||||||
foreach ($Argument in $ArgumentList) {
|
if ($ArgumentList) {
|
||||||
$script:powershell.AddArgument($Argument)
|
foreach ($Argument in $ArgumentList) {
|
||||||
|
$powershell.AddArgument($Argument)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$powershell.AddArgument($DebugPreference)
|
||||||
|
|
||||||
|
# Ensure runspace pool is available
|
||||||
|
if (-not $sync.runspace -or $sync.runspace.IsDisposed) {
|
||||||
|
throw "Runspace pool is not initialized or has been disposed."
|
||||||
|
}
|
||||||
|
$powershell.RunspacePool = $sync.runspace
|
||||||
|
|
||||||
|
# Execute the RunspacePool asynchronously
|
||||||
|
$handle = $powershell.BeginInvoke()
|
||||||
|
|
||||||
|
# Set up an event to handle completion
|
||||||
|
$null = Register-ObjectEvent -InputObject $powershell -EventName InvocationStateChanged -Action {
|
||||||
|
if ($EventArgs.InvocationStateInfo.State -eq "Completed") {
|
||||||
|
$powershell.EndInvoke($handle)
|
||||||
|
$powershell.Dispose()
|
||||||
|
[System.GC]::Collect()
|
||||||
|
Unregister-Event -SourceIdentifier $EventSubscriber.SourceIdentifier
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
# Return the handle
|
||||||
|
return $handle
|
||||||
}
|
}
|
||||||
$script:powershell.AddArgument($DebugPreference) # Pass DebugPreference to the script block
|
catch {
|
||||||
$script:powershell.RunspacePool = $sync.runspace
|
Write-Error "Error in Invoke-WPFRunspace: $_"
|
||||||
|
if ($powershell) { $powershell.Dispose() }
|
||||||
# Execute the RunspacePool
|
throw
|
||||||
$script:handle = $script:powershell.BeginInvoke()
|
|
||||||
|
|
||||||
# Clean up the RunspacePool threads when they are complete, and invoke the garbage collector to clean up the memory
|
|
||||||
if ($script:handle.IsCompleted) {
|
|
||||||
$script:powershell.EndInvoke($script:handle)
|
|
||||||
$script:powershell.Dispose()
|
|
||||||
$sync.runspace.Dispose()
|
|
||||||
$sync.runspace.Close()
|
|
||||||
[System.GC]::Collect()
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -13,45 +13,66 @@ function Invoke-WPFtweaksbutton {
|
|||||||
}
|
}
|
||||||
|
|
||||||
$Tweaks = (Get-WinUtilCheckBoxes)["WPFTweaks"]
|
$Tweaks = (Get-WinUtilCheckBoxes)["WPFTweaks"]
|
||||||
|
$DNSChange = $sync["WPFchangedns"].text -ne "Default"
|
||||||
|
|
||||||
Set-WinUtilDNS -DNSProvider $sync["WPFchangedns"].text
|
if ($DNSChange) {
|
||||||
|
Set-WinUtilDNS -DNSProvider $sync["WPFchangedns"].text
|
||||||
|
}
|
||||||
|
|
||||||
if ($tweaks.count -eq 0 -and $sync["WPFchangedns"].text -eq "Default") {
|
if ($tweaks.count -eq 0 -and -not $DNSChange) {
|
||||||
$msg = "Please check the tweaks you wish to perform."
|
$msg = "Please check the tweaks you wish to perform or select a DNS provider."
|
||||||
[System.Windows.MessageBox]::Show($msg, "Winutil", [System.Windows.MessageBoxButton]::OK, [System.Windows.MessageBoxImage]::Warning)
|
[System.Windows.MessageBox]::Show($msg, "Winutil", [System.Windows.MessageBoxButton]::OK, [System.Windows.MessageBoxImage]::Warning)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
Write-Debug "Number of tweaks to process: $($Tweaks.Count)"
|
Write-Debug "Number of tweaks to process: $($Tweaks.Count)"
|
||||||
|
|
||||||
Invoke-WPFRunspace -ArgumentList $Tweaks -DebugPreference $DebugPreference -ScriptBlock {
|
try {
|
||||||
param($Tweaks, $DebugPreference)
|
$handle = Invoke-WPFRunspace -ArgumentList $Tweaks, $DNSChange -DebugPreference $DebugPreference -ScriptBlock {
|
||||||
Write-Debug "Inside Number of tweaks to process: $($Tweaks.Count)"
|
param($Tweaks, $DNSChange, $DebugPreference)
|
||||||
|
Write-Debug "Inside Number of tweaks to process: $($Tweaks.Count)"
|
||||||
|
|
||||||
$sync.ProcessRunning = $true
|
$sync.ProcessRunning = $true
|
||||||
|
|
||||||
if ($Tweaks.count -eq 1) {
|
if ($Tweaks.count -eq 0 -and $DNSChange) {
|
||||||
$sync.form.Dispatcher.Invoke([action]{ Set-WinUtilTaskbaritem -state "Indeterminate" -value 0.01 -overlay "logo" })
|
$sync.form.Dispatcher.Invoke([action]{ Set-WinUtilTaskbaritem -state "Indeterminate" -value 0.01 -overlay "logo" })
|
||||||
} else {
|
} elseif ($Tweaks.count -eq 1) {
|
||||||
$sync.form.Dispatcher.Invoke([action]{ Set-WinUtilTaskbaritem -state "Normal" -value 0.01 -overlay "logo" })
|
$sync.form.Dispatcher.Invoke([action]{ Set-WinUtilTaskbaritem -state "Indeterminate" -value 0.01 -overlay "logo" })
|
||||||
|
} else {
|
||||||
|
$sync.form.Dispatcher.Invoke([action]{ Set-WinUtilTaskbaritem -state "Normal" -value 0.01 -overlay "logo" })
|
||||||
|
}
|
||||||
|
|
||||||
|
# Execute selected tweaks
|
||||||
|
for ($i = 0; $i -lt $Tweaks.Count; $i++) {
|
||||||
|
$currentTweak = $Tweaks[$i]
|
||||||
|
Set-WinUtilProgressBar -Label "Applying $currentTweak" -Percent ($i / $Tweaks.Count * 100)
|
||||||
|
|
||||||
|
# Apply the current tweak
|
||||||
|
Invoke-WinUtilTweaks $currentTweak
|
||||||
|
|
||||||
|
# Update taskbar progress
|
||||||
|
$sync.form.Dispatcher.Invoke([action]{ Set-WinUtilTaskbaritem -value (($i + 1) / $Tweaks.Count) })
|
||||||
|
}
|
||||||
|
|
||||||
|
Set-WinUtilProgressBar -Label "Tweaks finished" -Percent 100
|
||||||
|
$sync.ProcessRunning = $false
|
||||||
|
$sync.form.Dispatcher.Invoke([action]{ Set-WinUtilTaskbaritem -state "None" -overlay "checkmark" })
|
||||||
|
Write-Host "================================="
|
||||||
|
Write-Host "-- Tweaks are Finished ---"
|
||||||
|
Write-Host "================================="
|
||||||
}
|
}
|
||||||
# Execute other selected tweaks
|
|
||||||
|
|
||||||
for ($i = 0; $i -lt $Tweaks.Count; $i++) {
|
# Optionally, you can add code here to update the UI or perform other tasks while the runspace is executing
|
||||||
Set-WinUtilProgressBar -Label "Applying $($tweaks[$i])" -Percent ($i / $Tweaks.Count * 100)
|
# For example, you might want to disable certain UI elements until the runspace completes
|
||||||
Invoke-WinUtilTweaks $tweaks[$i]$sync.form.Dispatcher.Invoke([action]{ Set-WinUtilTaskbaritem -value ($i/$Tweaks.Count) })
|
|
||||||
}
|
|
||||||
Set-WinUtilProgressBar -Label "Tweaks finished" -Percent 100
|
|
||||||
$sync.ProcessRunning = $false
|
|
||||||
$sync.form.Dispatcher.Invoke([action]{ Set-WinUtilTaskbaritem -state "None" -overlay "checkmark" })
|
|
||||||
Write-Host "================================="
|
|
||||||
Write-Host "-- Tweaks are Finished ---"
|
|
||||||
Write-Host "================================="
|
|
||||||
|
|
||||||
# $ButtonType = [System.Windows.MessageBoxButton]::OK
|
# If you need to wait for completion before proceeding, you can use:
|
||||||
# $MessageboxTitle = "Tweaks are Finished "
|
# $handle.AsyncWaitHandle.WaitOne()
|
||||||
# $Messageboxbody = ("Done")
|
# But be cautious about blocking the UI thread
|
||||||
# $MessageIcon = [System.Windows.MessageBoxImage]::Information
|
|
||||||
# [System.Windows.MessageBox]::Show($Messageboxbody, $MessageboxTitle, $ButtonType, $MessageIcon)
|
Write-Host "Tweaks execution started in background."
|
||||||
|
}
|
||||||
|
catch {
|
||||||
|
Write-Error "Failed to start tweaks execution: $_"
|
||||||
|
[System.Windows.MessageBox]::Show("An error occurred while starting tweaks execution. Please check the logs for more information.", "Error", [System.Windows.MessageBoxButton]::OK, [System.Windows.MessageBoxImage]::Error)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user