KEMBAR78
PSAvoidTrailingWhitespace: Rule not applied when using formatter + single character lines with trailing whitespace are truncated by liamjpeters · Pull Request #1993 · PowerShell/PSScriptAnalyzer · GitHub
Skip to content

Conversation

@liamjpeters
Copy link
Contributor

@liamjpeters liamjpeters commented Apr 10, 2024

PR Summary

PR Checklist

…character, followed by multiple white-spaces were truncated when fixed/formatted
…ormatter with PSAvoidTrailingWhitespace and also checking that single-character lines that have trailing whitespace are not removed
@liamjpeters liamjpeters changed the title WIP: PSAvoidTrailingWhitespace: Rule not applied when using formatter + single character lines with trailing whitespace are truncated PSAvoidTrailingWhitespace: Rule not applied when using formatter + single character lines with trailing whitespace are truncated Apr 10, 2024
Copy link

@Ju-l1a Ju-l1a left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It works as expected now and all tests pass. Looks good to me!

@Ju-l1a
Copy link

Ju-l1a commented Jul 17, 2024

I don't know if this is to do with this issue specifically but I've found that with this branch the fix for PSAvoidTrailingWhitespace gets applied when using Invoke-ScriptAnalyzer -Fix ... but not when using Invoke-Formatter .... I don't seem to have this problem for any other rules I've tried.

Edit: actually I'm getting the same for PSPossibleIncorrectComparisonWithNull.

@liamjpeters
Copy link
Contributor Author

Hey @Ju-l1a 👋,

You need to tell the formatter to include that rule when carrying out the formatting.

$Settings = @{
    IncludeRules = @("PSAvoidTrailingWhitespace")
    Rules = @{
        "PSAvoidTrailingWhitespace" = @{}
    }
}

So the below code, with lots of trailing whitespace:

$ScriptDef = @"
    Function Get-Example {
        'Example'`t`t`t
    }`t`t`t
"@

Is not altered when running:

Invoke-Formatter -ScriptDefinition $ScriptDef

image

But is fixed when running:

Invoke-Formatter -ScriptDefinition $ScriptDef -Settings $Settings

image

Hope that helps!

Copy link
Member

@andyleejordan andyleejordan left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks! Sorry it took so long to get to these.

@andyleejordan andyleejordan merged commit d6eb35e into PowerShell:main Feb 25, 2025
4 checks passed
@liamjpeters liamjpeters deleted the #1992PSAvoidTrailingWhitespaceNotApplied branch February 25, 2025 09:16
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

The PSAvoidTrailingWhitespace rule is not applied when using Invoke-Formatter Fixing PSAvoidTrailingWhitespace is broken

4 participants