diff --git a/src/Spectre.Console.Analyzer/Fixes/CodeActions/SwitchToAnsiConsoleAction.cs b/src/Spectre.Console.Analyzer/Fixes/CodeActions/SwitchToAnsiConsoleAction.cs index d6802bcb..6a0833d1 100644 --- a/src/Spectre.Console.Analyzer/Fixes/CodeActions/SwitchToAnsiConsoleAction.cs +++ b/src/Spectre.Console.Analyzer/Fixes/CodeActions/SwitchToAnsiConsoleAction.cs @@ -75,7 +75,9 @@ public class SwitchToAnsiConsoleAction : CodeAction // int local = 0; // static void LocalFunction() => local; <-- local is invalid here but LookupSymbols suggests it // } - if (symbol.Kind is SymbolKind.Local) + // + // Parameters from the ancestor methods or local functions are also returned even if the operation is in a static local function. + if (symbol.Kind is SymbolKind.Local or SymbolKind.Parameter) { var localPosition = symbol.DeclaringSyntaxReferences.FirstOrDefault()?.GetSyntax(cancellationToken).GetLocation().SourceSpan.Start; @@ -167,6 +169,24 @@ public class SwitchToAnsiConsoleAction : CodeAction return true; } } + else if (member is LambdaExpressionSyntax lambdaExpression) + { + var symbol = operation.SemanticModel!.GetSymbolInfo(lambdaExpression, cancellationToken).Symbol; + if (symbol != null && symbol.IsStatic) + { + parentStaticMemberStartPosition = lambdaExpression.GetLocation().SourceSpan.Start; + return true; + } + } + else if (member is AnonymousMethodExpressionSyntax anonymousMethod) + { + var symbol = operation.SemanticModel!.GetSymbolInfo(anonymousMethod, cancellationToken).Symbol; + if (symbol != null && symbol.IsStatic) + { + parentStaticMemberStartPosition = anonymousMethod.GetLocation().SourceSpan.Start; + return true; + } + } else if (member is MethodDeclarationSyntax methodDeclaration) { parentStaticMemberStartPosition = methodDeclaration.GetLocation().SourceSpan.Start;