Handling lots of parameters

The Scripting Games practice event for this season evokes scripts that have a lot of switch parameters.

I saw lots of stacks of IF statements among the entries dealing with those switches.

When I see stacks of IF statements I have to wonder if might not be better to have a Switch instead.

After tinkering at it a while, with the intent of producing something that was relatively easy to maintain (after you put it into production, somebody is going to want stuff added to it, trust me on this) I have this:

function Get-Inventory

param (

End {

foreach ($ComputerName in $ComputerNames)
$PropHash = [ordered]@{}

Switch -Regex ($PSBoundParameters.GetEnumerator().
Where({$_.Value -eq $true}).Key)
{ 'Manufacturer','Model','CPU','RAM','Disks' | Get-ReportProp }

{ 'LastPatch','LastReboot' | Get-ReportProp }

{ 'ServerRoles'| Get-ReportProp }

{ 'Components' | Get-ReportProp }

} #End Switch


} #End ForEach

} #End End Block


[Array]$ComputerNames = $ComputerName

function Get-Manufacturer {}
function Get-Model {}
function Get-CPU {}
function Get-Disks {}
function Get-LastPatch {}
function Get-LastReboot {}
function Get-ServerRoles {}
function Get-Components {}

filter Get-ReportProp { $PropHash[$_] = Invoke-Expression "Get-$_ $ComputerName" }

} #End Begin block

Process { $ComputerNames += $_ } #Process Block

}#End Get-Inventory Function

2 responses to “Handling lots of parameters

  1. Jeffrey Snover [MSFT]

    Cool approach!

    Jeffrey Snover[MSFT]
    Distinguished Engineer and Lead Architect for Windows Server and System Center

  2. Nice work! learned something today šŸ™‚

Leave a Reply

Fill in your details below or click an icon to log in:

WordPress.com Logo

You are commenting using your WordPress.com account. Log Out /  Change )

Twitter picture

You are commenting using your Twitter account. Log Out /  Change )

Facebook photo

You are commenting using your Facebook account. Log Out /  Change )

Connecting to %s