From a70843385f748fec088f6f843ac684e84c3a3110 Mon Sep 17 00:00:00 2001 From: onyx-and-iris <75868496+onyx-and-iris@users.noreply.github.com> Date: Thu, 6 Jan 2022 15:28:28 +0000 Subject: [PATCH] Update vban.ps1 vban is now a custom class of subclasses for each vban stream type. --- lib/vban.ps1 | 48 ++++++++++++++++++++++++++++++++++-------------- 1 file changed, 34 insertions(+), 14 deletions(-) diff --git a/lib/vban.ps1 b/lib/vban.ps1 index a79d43a..aa32731 100644 --- a/lib/vban.ps1 +++ b/lib/vban.ps1 @@ -4,10 +4,8 @@ class Vban { [Array]$stringparams # Constructor - Vban ([Int]$id, [String]$direction) + Vban() { - $this.id = $id - $this.direction = $direction $this.stringparams = @('name', 'ip') } @@ -169,18 +167,40 @@ class Vban { ) } -Function Vban_In { - [System.Collections.ArrayList]$vban_in = @() - 0..$($layout.vban_in-1) | ForEach-Object { - [void]$vban_in.Add([Vban]::new($_, "in")) + +class VbanInstream : Vban { + # Constructor + VbanInstream ($id) + { + $this.id = $id + $this.direction = "in" } - $vban_in } -Function Vban_Out { - [System.Collections.ArrayList]$vban_out = @() - 0..$($layout.vban_out-1) | ForEach-Object { - [void]$vban_out.Add([Vban]::new($_, "out")) + +class VbanOutstream : Vban { + # Constructor + VbanOutstream ($id) + { + $this.id = $id + $this.direction = "out" } - $vban_out -} \ No newline at end of file +} + +Function Vban { + [System.Collections.ArrayList]$instream = @() + [System.Collections.ArrayList]$outstream = @() + + 0..$($layout.vban_in-1) | ForEach-Object { + [void]$instream.Add([VbanInstream]::new($_)) + } + 0..$($layout.vban_out-1) | ForEach-Object { + [void]$outstream.Add([VbanOutstream]::new($_)) + } + + $obj = [PSCustomObject]@{ + instream = $instream + outstream = $outstream + } + return $obj +}