functions/public/New-CommentHelp.ps1
Function New-CommentHelp { [cmdletbinding(DefaultParameterSetName="ast")] [alias('nch')] [OutputType("System.String")] Param( [Parameter( Position = 0, Mandatory, ValueFromPipeline, HelpMessage = "Specify ParamBlockAST object.", ParameterSetName = "ast" )] [System.Management.Automation.Language.ParamBlockAst]$ParamBlock, [Parameter(HelpMessage = "Provide a short description. You can always edit this later.")] [string]$Synopsis = "<short description>", [Parameter(HelpMessage = "Provide a longer description. You can always edit this later.")] [string]$Description = "<long description>", [Parameter(HelpMessage = "Insert help template",ParameterSetName = "template")] [switch]$TemplateOnly ) Begin { Write-Verbose "Starting $($MyInvocation.MyCommand)" Write-Verbose "Defining help opening" $h = [System.Collections.Generic.List[string]]::new() $h.Add("<#") $h.Add(" .Synopsis") $h.Add(" $Synopsis") $h.Add(" .Description") $h.Add(" $Description") } Process { if ($PSCmdlet.ParameterSetName -eq 'ast') { Write-Verbose "Processing a ParamBlock AST object" foreach ($p in $ParamBlock.Parameters) { $ParamName = $p.name.VariablePath.UserPath Write-Verbose "Adding parameter help for $ParamName" $h.Add(" .Parameter $ParamName") $paramHelp = $p.Attributes.namedArguments.where({ $_.ArgumentName -eq 'helpmessage' }) if ($paramHelp) { $h.Add(" $($paramHelp.argument.value)") } else { $h.Add(" <enter a parameter description>") } } } #if ParamBlock } #process End { Write-Verbose "Adding closing help content" $h.Add(" .Example") $h.Add(" PS C:\> $Name") $h.Add(" <output and explanation>") $h.Add(" .Inputs") $h.Add(" <Inputs to this function (if any)>") $h.Add(" .Outputs") $h.Add(" <Output from this function (if any)>") $h.Add(" .Notes") $h.Add(" <General notes>") $h.Add(" .Link") $h.Add(" <enter a link reference>") $h.Add("#>") $h Write-Verbose "Ending $($MyInvocation.MyCommand)" } #end } |