Given my research, I don't believe the following is easily accomplished, if at all. As a last resort, however, I figured I'd check here.
In Powershell 2.0, I'd like a way to reduce the (annoyingly) long names of parameters to various cmdlets. I would like absolute control over what the shorthand version looks like. (As opposed to being a slave to whatever parameter abbreviation scheme PS uses.)
So, for example, I'd like to be able to do something like this:
# Command goes on this first line to alias "-ForegroundColor" to "-fg"
# Command goes on this second line to alias "-BackgroundColor" to "-bg"
Wr-te-Host -fg yellow -bg black "Parameter aliases now work just like I want."
What's the closest I can get to this functionality, and how? I was not able to find anything regarding parameter abbreviation using 'get-help about_parameters'.
Thanks!
You can create parameter aliases for your own functions like so:
function ParamAlias {
param(
[Alias('fg','fColor')]
$ForegroundColor
)
Write-Host "$ForegroundColor" -ForegroundColor $ForegroundColor
}
ParamAlias -fg Green
ParamAlias -fColor Green
You could then use this technique with Proxy CmdLets to add your own aliases to existing CmdLets. However, I find it sufficient to use existing parameter aliases/shortened parameter names in the console, and you shouldn't use aliases in scripts, so I'm not sure this would be worth the effort. I would go with @Shay's answer
Check this script: Get-Parameter.ps1
dot-source it and execute the following, it gives a wealth of information about a command parameters. Take a look at the aliases column, it will show all built-in parameter aliases as well as calculates the shortest name you can use for a parameter:
PS > Get-Parameter Write-Host
Command: Microsoft.PowerShell.Utility/Write-Host
Set: Default
Name Aliases Position Mandatory Pipeline ByName Provider Type
---- ------- -------- --------- -------- ------ -------- ----
BackgroundColor {b} Named False False False All ConsoleColor
ForegroundColor {f} Named False False False All ConsoleColor
NoNewline {n} Named False False False All SwitchParameter
Object {obj} 0 False True False All Object
Separator {s} Named False False False All Object
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With