mirror of
https://github.com/onyx-and-iris/voicemeeter-api-powershell.git
synced 2026-03-20 08:59:10 +00:00
more IODevice.driver tweaks
use temp file instead of persistent manual and pester tests pass
This commit is contained in:
parent
6b2031de99
commit
4ea371af2f
@ -20,15 +20,11 @@ class Remote {
|
||||
[String]$vmpath
|
||||
[Hashtable]$kind
|
||||
[Object]$profiles
|
||||
[String]$userpath
|
||||
[String]$workingconfig
|
||||
|
||||
Remote ([String]$kindId) {
|
||||
$this.vmpath = Setup_DLL
|
||||
$this.kind = GetKind($kindId)
|
||||
$this.profiles = Get_Profiles($this.kind.name)
|
||||
$this.userpath = Join-Path ([Environment]::GetFolderPath('MyDocuments')) 'Voicemeeter'
|
||||
$this.workingconfig = Join-Path $this.userpath ('vm' + $this.kind.name + '_working.xml')
|
||||
}
|
||||
|
||||
[string] ToString() {
|
||||
|
||||
23
lib/io.ps1
23
lib/io.ps1
@ -122,32 +122,33 @@ class IODevice : IRemote {
|
||||
{
|
||||
if ([string]::IsNullOrEmpty($this.name)) { return '' }
|
||||
|
||||
$path = $this.remote.workingconfig
|
||||
$oldTime = if (Test-Path $path) { (Get-Item $path).LastWriteTime } else { [DateTime]::MinValue }
|
||||
|
||||
$this.remote.Setter('Command.Save', $path)
|
||||
$type = $null
|
||||
try {
|
||||
$tmp = [System.IO.Path]::Combine([System.IO.Path]::GetTempPath(), "vmrtmp-$(New-Guid).xml")
|
||||
$this.remote.Setter('Command.Save', $tmp)
|
||||
|
||||
$timeout = New-TimeSpan -Seconds 2
|
||||
$sw = [Diagnostics.Stopwatch]::StartNew()
|
||||
$line = $null
|
||||
do {
|
||||
if (Test-Path $path) {
|
||||
$newTime = (Get-Item $path).LastWriteTime
|
||||
if ($newTime -gt $oldTime) {
|
||||
if (Test-Path $tmp) {
|
||||
try {
|
||||
$line = Get-Content $path | Select-String -Pattern "<$($this.kindOfDevice)Dev index='$($this.index + 1)'" -List
|
||||
$line = Get-Content $tmp | Select-String -Pattern "<$($this.kindOfDevice)Dev index='$($this.index + 1)'" -List
|
||||
if ($line) { break }
|
||||
}
|
||||
catch {}
|
||||
}
|
||||
}
|
||||
Start-Sleep -Milliseconds 20
|
||||
} while ($sw.elapsed -lt $timeout)
|
||||
|
||||
$type = $null
|
||||
if ($line -and $line.ToString() -match "type='(?<type>\d+)'") {
|
||||
$type = $matches['type']
|
||||
}
|
||||
}
|
||||
finally {
|
||||
if (Test-Path $tmp) {
|
||||
Remove-Item $tmp -Force
|
||||
}
|
||||
}
|
||||
|
||||
if ($type -notin $this.drivers.Keys) { return 'unknown' }
|
||||
return $this.drivers[$type]
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user