Петля Powershell не ждет завершения команды - PullRequest
0 голосов
/ 10 июня 2019

Я создал небольшой скрипт для запуска и распечатки всякий раз, когда у меня установлен драйвер. Проблема, с которой я сталкиваюсь, заключается в том, что при вызове Compare-Object сценарий зависает и запускает этот код только при выходе.

Я уже пробовал | out-null и waitjob безрезультатно

$global:drivers = $null

function checkDrivers{
    $temp = Driverquery.exe /V

    # testing
    $temp += "newDriver     SMS Process Event Driv SMS Process Event Driv Kernel        Manual     Running    OK         TRUE        FALSE        8,192             8,192       0          03/08/2011 8:56:26 AM  C:\WINDOWS\system32\DRIVERS\prepdrv.sys          4,096"

    if($temp.Length -eq $global:drivers.Length){
        return
    }

    Write-Output "[---] Driver Installed"
    Compare-Object -ReferenceObject $global:drivers -DifferenceObject $temp
    $global:drivers = $temp
}

Write-Output "[+] Parsing initial drivers..."
$global:drivers = Driverquery.exe /V
Write-Output "[+] Parsing complete`n"
Write-Output "[+] Press 'q' to quit"
Write-Output "[+] Scanning for Driver Installs..."
while ($true){
    if ($Host.UI.RawUI.KeyAvailable -and ("q" -eq $Host.UI.RawUI.ReadKey("IncludeKeyUp,NoEcho").Character)) {
        Write-Host "Exiting now..." -Background DarkRed
        break;
    }

    checkDrivers
    start-sleep -seconds 5
}

Вот мой вывод, я ожидал, что строка сравнения объектов будет выполнена перед выходом в [---] Driver Installed

[+] Parsing initial drivers...
[+] Parsing complete

[+] Press 'q' to quit
[+] Scanning for Driver Installs...
[---] Driver Installed

Exiting now...
InputObject                                                                                                                                                                                                                                                SideIndicator
-----------                                                                                                                                                                                                                                                -------------
newDriver     SMS Process Event Driv SMS Process Event Driv Kernel        Manual     Running    OK         TRUE        FALSE        8,192             8,192       0          03/08/2011 8:56:26 AM  C:\WINDOWS\system32\DRIVERS\prepdrv.sys          4,096 =>

1 Ответ

0 голосов
/ 11 июня 2019

Строка «Exiting now ..» появляется над остальной частью вывода, потому что она использует Write-Host, которая записывает в консоль вместо Write-Output, которая записывает в конвейер. Но скрипт выполняется в ожидаемом порядке.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...