-
Notifications
You must be signed in to change notification settings - Fork 29
/
Optimize-Help.ps1
85 lines (80 loc) · 2.64 KB
/
Optimize-Help.ps1
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
<#
.SYNOPSIS
Cleans up comment-based help blocks by fully unindenting and capitalizing dot keywords.
.INPUTS
An object with a Path or FullName property.
.FUNCTIONALITY
Scripts
.EXAMPLE
Optimize-Help.ps1 Get-Thing.ps1
Unindents help and capitalizes dot keywords in Get-Thing.ps1
#>
#Requires -Version 7
[CmdletBinding()] Param(
# The script to process.
[Parameter(Position=0,Mandatory=$true,ValueFromPipelineByPropertyName=$true)][Alias('FullName')][string] $Path
)
Begin
{
$EOL = [Environment]::NewLine
function Get-ParameterDoc([Parameter(ValueFromPipeline=$true)][string]$script)
{
$params = [ordered]@{}
foreach($param in [regex]::Matches($script, '(?ms)^\.PARAMETER +(?<ParameterName>\w+)\r?\n(?<Description>.*?)(?=\s*^\.\w+|\s*^#>)'))
{
$params.Add($param.Groups['ParameterName'].Value, $param.Groups['Description'].Value)
}
return $params
}
}
Process
{
foreach($filename in Resolve-Path $Path)
{
Write-Verbose "Optimizing help in $filename"
$script = [regex]::Replace((Get-Content $filename -Raw).TrimEnd(), '(?s)<#\s*(\.\w+.*?)#>',
{[regex]::Replace(($args[0] -replace '(?m)^[\x09\x20]+',''), '(?m)^(\.\w+)\b', {"$($args[0])".ToUpper()} )})
$params = $script |Get-ParameterDoc
$script = $script -replace '(?ms)^\.PARAMETER +\w+\r?\n.*?\s*(?=^\.\w+|^#>)'
$script = [regex]::Replace($script, '(?ms)(?<=^\[CmdletBinding.*?\]\s*Param\(\r?\n)(?<ParameterDefs>.*?\r?\n)(?=^\))',
{
[string[]] $docparams = @()
foreach($p in $args[0] -split '(?<=\] *\$\w+\b(?: *= *.*?)?),\r?\n')
{
if($p -match '\] *\$(?<ParameterName>\w+)\b')
{
$name = $Matches.ParameterName
if($params.Contains($name))
{
$doc = $params[$name]
$params.Remove($name)
$docparams += $doc -match '\n' ? "<#$EOL$doc$EOL#>$EOL$p" : "# $doc$EOL$p";
}
else
{
"$(Get-Date -f s) Parameter $name documentation not found in $filename" |
Tee-Object optimize-help.log -Encoding utf8BOM -Append |
Write-Warning
$docparams += $p
}
}
else
{
"$(Get-Date -f s) Could not find parameter name in ${filename}:$EOL$p" |
Tee-Object optimize-help.log -Encoding utf8BOM -Append |
Write-Warning
$docparams += $p
}
}
foreach($k in $params.Keys)
{
"$(Get-Date -f s) Could not find parameter definition for $k in $filename$EOL$($params[$k])" |
Tee-Object optimize-help.log -Encoding utf8BOM -Append |
Write-Warning
}
$docparams -join ",$EOL"
})
$script |Out-File $filename utf8BOM
Write-Verbose "Optimized help in $filename"
}
}