internal/Export-HelpToMd.ps1
function Export-HelpToMd { [CmdletBinding()] param ( [Parameter(Mandatory, Position = 0, ValueFromPipeline)] [PSCustomObject] $HelpInfo ) begin { function GetText { param ([string]$text, [string]$default) $text = $text.Trim().Trim('.') if ([string]::IsNullOrEmpty($text)) { if ([string]::IsNullOrEmpty($default)) { $default = 'No description' } return $default } return $text } function GetName ([PSCustomObject]$help) { $lines = @() $lines += '# {0}' -f $help.Name $lines += [System.Environment]::NewLine return $lines } function GetDescription { param ($description, [string]$noDesc) $description = $description.Description.Text | Out-String $line = '{0}' -f (GetText $description $noDesc) return $line } function GetParameterSet ([PSCustomObject]$help) { $lines = @() $setNum = 1 $lines += '## Parameters' foreach ($set in $help.syntax.syntaxItem) { $lines += [System.Environment]::NewLine $lines += '### Parameter Set {0}' -f $setNum $lines += [System.Environment]::NewLine foreach ($param in $set.Parameter) { $paramStringParts = @() $paramStringParts += '- `[{0}]`' -f (GetText $param.parameterValue 'switch') $paramStringParts += '**{0}**' -f $param.Name $paramStringParts += '_{0}_. ' -f (GetDescription -description $param -noDesc 'Parameter help description') $attributes = @() if ($param.required -eq 'true') { $attributes += 'Mandatory' } if ($param.pipelineInput -like '*ByValue*') { $attributes += 'ValueFromPipeline' } $paramStringParts += $attributes -join ', ' $lines += $paramStringParts -join ' ' } $setNum++ } return $lines } function GetExample ([PSCustomObject]$help) { $lines = @() $exNum = 1 $lines += [System.Environment]::NewLine $lines += '## Examples' foreach ($exampleList in $help.examples.example) { foreach ($example in $exampleList) { $lines += [System.Environment]::NewLine $lines += '### Example {0}' -f $exNum $lines += [System.Environment]::NewLine $lines += $example.remarks.Text.Where({ ![string]::IsNullOrEmpty($_) }) $lines += [System.Environment]::NewLine $lines += '```powershell' $lines += $example.code.Trim("`t") $lines += '```' } $exNum++ } return $lines } function GetLink ([PSCustomObject]$help, $Commands) { if ($help.relatedLinks.count -gt 0) { $lines = @() $lines += [System.Environment]::NewLine $lines += '## Links' $lines += [System.Environment]::NewLine foreach ($link in $help.relatedLinks) { foreach ($text in $link.navigationLink.linkText) { if ($text -match '\w{3,}-\w{3,}') { $uri = $text $lines += '- [{0}]({0}.md)' -f $uri } } foreach ($uri in $link.navigationLink.uri) { if (![string]::IsNullOrEmpty($uri)) { $lines += '- [{0}]({0})' -f $uri } } } return $lines } } } process { GetName $HelpInfo GetDescription $HelpInfo $HelpInfo.Synopsis GetParameterSet $HelpInfo GetExample $HelpInfo GetLink $HelpInfo } end { } } |