Skip to content

Commit

Permalink
(maint) Update documentation generation script
Browse files Browse the repository at this point in the history
When working on this, some irregularities were noted with the generation
of the documentation, so these changes avoid the issues that arose.
  • Loading branch information
vexx32 committed Oct 15, 2024
1 parent 24497f4 commit 8297eb1
Showing 1 changed file with 12 additions and 8 deletions.
20 changes: 12 additions & 8 deletions update-cmdlet-documentation.ps1
Original file line number Diff line number Diff line change
@@ -1,4 +1,6 @@
<#
# PowerShell Core generates additional documentation that may not be correct for running under Windows PowerShell.
#Requires -PSEdition Desktop
<#
.SYNOPSIS
Generates Markdown documentation for the Chocolatey.PowerShell portion of Chocolatey's installer module commands.
Expand Down Expand Up @@ -85,12 +87,12 @@ if (-not (Get-Module Chocolatey.PowerShell)) {
throw "The Chocolatey.PowerShell module was not able to be loaded, exiting documentation generation."
}

$newOrUpdatedFiles = [System.Collections.Generic.HashSet[System.IO.FileSystemInfo]] @(
$newOrUpdatedFiles = @(
if ($NewCommand) {
New-MarkdownHelp -Command $NewCommand -OutputFolder "$PSScriptRoot\docs" -ExcludeDontShow
New-MarkdownHelp -Command $NewCommand -OutputFolder $documentationPath -ExcludeDontShow
}

Update-MarkdownHelp -Path $documentationPath -ExcludeDontShow
Update-MarkdownHelp -Path $documentationPath -ExcludeDontShow | Where-Object BaseName -ne $NewCommand
)

$incompleteFiles = $newOrUpdatedFiles | Select-String '\{\{[^}]+}}' | Select-Object -ExpandProperty Path
Expand All @@ -116,7 +118,7 @@ $newOrUpdatedFiles = $newOrUpdatedFiles |

$frontMatterBounds = 0
$content = $content | ForEach-Object {
if ($_ -match '\[(?<name>[^\]]+)\]\(xref:(?<xref>[^#,]+)(#(?<anchor>[^,]+))?,(?<classes>[^)]+)\)') {
if ($_ -match '\[(?<name>[^\]]+)\]\(xref:(?<xref>[^#,]+)(#(?<anchor>[^,]+))?(?:,(?<classes>[^)]+))?\)') {
# replace any lines that are an xref link with the html/xml format that astro uses <Xref ... />
$xml = [xml]::new()
$node = $xml.CreateElement('Xref')
Expand All @@ -134,9 +136,11 @@ $newOrUpdatedFiles = $newOrUpdatedFiles |
$null = $node.Attributes.Append($anchor)
}

$classes = $xml.CreateAttribute('classes')
$classes.Value = $matches['classes']
$null = $node.Attributes.Append($classes)
if ($matches['classes']) {
$classes = $xml.CreateAttribute('classes')
$classes.Value = $matches['classes']
$null = $node.Attributes.Append($classes)
}

$node.OuterXml
}
Expand Down

0 comments on commit 8297eb1

Please sign in to comment.