Board logo

标题: [转载代码] [PowerShell每日技巧]确保代码的向后兼容性(20140212) [打印本页]

作者: DAIC    时间: 2014-2-19 14:42     标题: [PowerShell每日技巧]确保代码的向后兼容性(20140212)

Let's assume you have created this function:
  1. function Test-Function
  2. {
  3.   param
  4.   (
  5.     [Parameter(Mandatory=$true)]
  6.     $ServerPath
  7.   )
  8.   "You selected $ServerPath"
  9. }
复制代码
It works fine, but half a year later in a code review, your boss wants you to use standard parameter names, and rename "ServerPath" to "ComputerName". So you change your function appropriately:
  1. function Test-Function
  2. {
  3.   param
  4.   (
  5.     [Parameter(Mandatory=$true)]
  6.     $ComputerName
  7.   )
  8.   "You selected $ComputerName"
  9. }
复制代码
What you cannot easily control, though, is who else calls your function, and may still use the old parameter. So to ensure backward compatibility, make sure your function can still work with the old parameter name, too:
  1. function Test-Function
  2. {
  3.   param
  4.   (
  5.     [Parameter(Mandatory=$true)]
  6.     [Alias("ServerPath")]
  7.     $ComputerName
  8.   )
  9.   "You selected $ComputerName"
  10. }
复制代码
Old code can now still run, and new code (and code completion) will use the new name:
PS> Test-Function -ComputerName server1
You selected server1

PS> Test-Function -ServerPath server1
You selected server1


http://powershell.com/cs/blogs/tips/archive/2014/02/12/ensuring-backward-compatibility.aspx
作者: DAIC    时间: 2014-2-19 14:43

如果需要定义两个参数的别名:
  1. [Alias("ServerPath","CN")]
复制代码





欢迎光临 批处理之家 (http://bbs.bathome.net/) Powered by Discuz! 7.2