Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Port few IDE analyzers/fixers to shared layer to be enabled in CodeStyle NuGet package #41363

Closed
Closed
Show file tree
Hide file tree
Changes from 6 commits
Commits
Show all changes
39 commits
Select commit Hold shift + click to select a range
f18cea7
Analyzer and code fixes refactoring
mavasani Jan 29, 2020
c3ecec5
Port CSharpMakeStructFieldsWritableDiagnosticAnalyzer and fixer
mavasani Jan 31, 2020
2e32204
Port ConvertSwitchStatementToExpression to CodeStyle layer
mavasani Feb 1, 2020
df116e9
Port C# type style analyzers (UseImplicitOrExplicitType) to code styl…
mavasani Feb 2, 2020
a6579cc
Port RemoveUnnecessaryImports analyzer/fixer to code style layer
mavasani Feb 2, 2020
2750a86
Merge remote-tracking branch 'upstream/master' into RefactorAnalyzerA…
mavasani Feb 3, 2020
09e77dc
Merge remote-tracking branch 'upstream/master' into RefactorAnalyzerA…
mavasani Feb 4, 2020
493b727
Merge remote-tracking branch 'upstream/master' into RefactorAnalyzerA…
mavasani Feb 4, 2020
2046dbb
Merge remote-tracking branch 'upstream/master' into RefactorAnalyzerA…
mavasani Feb 6, 2020
9297c51
Merge remote-tracking branch 'upstream/master' into RefactorAnalyzerA…
mavasani Feb 6, 2020
c4ebb30
Refactor remove unncessary imports service
mavasani Feb 7, 2020
46ef3bb
Disable some nullable related unit tests for CodeStyle layer as they …
mavasani Feb 7, 2020
53fdfe0
Add clarification comment
mavasani Feb 7, 2020
68c74bf
Merge remote-tracking branch 'upstream/master' into RefactorAnalyzerA…
mavasani Feb 7, 2020
cc3910c
Remove the last remaining extern alias.
mavasani Feb 7, 2020
677d292
Remove stale xlf files.
mavasani Feb 7, 2020
3e69af5
Revert changes to DocumentBasedFixAllProvider and AbstractFormattingC…
mavasani Feb 7, 2020
1e8b5d0
Remove CodeStyle layer from Compiler.sln due to dependencies on proje…
mavasani Feb 7, 2020
f1c5abe
Revert unnecessary code changes
mavasani Feb 7, 2020
26540d4
Project changes to avoid C# and VB CodeStyle unit test projects depen…
mavasani Feb 7, 2020
3050f34
Mark CodeStyle test projects as non-Shipping.
mavasani Feb 7, 2020
868886a
Test code refactoring to avoid C# and VB EditorFeatures UnitTests pro…
mavasani Feb 7, 2020
23dc0c0
Add direct project references in UnitTest projects to please BuildBoss
mavasani Feb 7, 2020
f70503d
Fix some more test project references
mavasani Feb 7, 2020
216ab58
Change signature for IncludeDiagnosticDuringFixAll
mavasani Feb 7, 2020
fb1940f
Merge remote-tracking branch 'upstream/master' into RefactorAnalyzerA…
mavasani Feb 8, 2020
c7a3026
Merge remote-tracking branch 'upstream/master' into RefactorAnalyzerA…
mavasani Feb 10, 2020
86304ff
Merge remote-tracking branch 'upstream/master' into RefactorAnalyzerA…
mavasani Feb 10, 2020
7d7bfc8
Merge remote-tracking branch 'upstream/master' into RefactorAnalyzerA…
mavasani Feb 10, 2020
f1b4a01
Delete duplicate file added by automatic merge conflict resolution
mavasani Feb 10, 2020
f0ed15e
Merge remote-tracking branch 'upstream/master' into RefactorAnalyzerA…
mavasani Feb 10, 2020
6f9b2ce
Merge remote-tracking branch 'upstream/master' into RefactorAnalyzerA…
mavasani Feb 11, 2020
f2f18c0
Fixes from conflicts
mavasani Feb 12, 2020
8e0fe0d
Revert unwanted changes and remove usage of extern aliases
mavasani Feb 12, 2020
7f9d9e1
Use shared resource files in shared projects.
mavasani Feb 12, 2020
1e1b9a7
Revert some unrelated changes
mavasani Feb 12, 2020
fee840f
Make analyzer diagnostics in CodeStyle layer be warnings by default.
mavasani Feb 12, 2020
d22e50c
Add comment
mavasani Feb 12, 2020
870fa85
Merge remote-tracking branch 'upstream/master' into RefactorAnalyzerA…
mavasani Feb 12, 2020
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
The table of contents is too big for display.
Diff view
Diff view
  •  
  •  
  •  
102 changes: 102 additions & 0 deletions Roslyn.sln

Large diffs are not rendered by default.

22 changes: 22 additions & 0 deletions src/Analyzers/CSharp/Analyzers/CSharpAnalyzers.projitems
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
<?xml version="1.0" encoding="utf-8"?>
<Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<PropertyGroup>
<MSBuildAllProjects>$(MSBuildAllProjects);$(MSBuildThisFileFullPath)</MSBuildAllProjects>
<HasSharedItems>true</HasSharedItems>
<SharedGUID>ec946164-1e17-410b-b7d9-7de7e6268d63</SharedGUID>
</PropertyGroup>
<PropertyGroup Label="Configuration">
<Import_RootNamespace>Microsoft.CodeAnalysis.CSharp.Analyzers</Import_RootNamespace>
</PropertyGroup>
<ItemGroup>
<Compile Include="$(MSBuildThisFileDirectory)ConvertSwitchStatementToExpression\ConvertSwitchStatementToExpressionConstants.cs" />
<Compile Include="$(MSBuildThisFileDirectory)ConvertSwitchStatementToExpression\ConvertSwitchStatementToExpressionDiagnosticAnalyzer.Analyzer.cs" />
<Compile Include="$(MSBuildThisFileDirectory)ConvertSwitchStatementToExpression\ConvertSwitchStatementToExpressionDiagnosticAnalyzer.cs" />
<Compile Include="$(MSBuildThisFileDirectory)RemoveUnnecessaryImports\CSharpRemoveUnnecessaryImportsDiagnosticAnalyzer.cs" />
<Compile Include="$(MSBuildThisFileDirectory)UseImplicitOrExplicitType\CSharpTypeStyleDiagnosticAnalyzerBase.cs" />
<Compile Include="$(MSBuildThisFileDirectory)UseImplicitOrExplicitType\CSharpUseExplicitTypeDiagnosticAnalyzer.cs" />
<Compile Include="$(MSBuildThisFileDirectory)UseImplicitOrExplicitType\CSharpUseImplicitTypeDiagnosticAnalyzer.cs" />
<Compile Include="$(MSBuildThisFileDirectory)MakeStructFieldsWritable\CSharpMakeStructFieldsWritableDiagnosticAnalyzer.cs" />
<Compile Include="$(MSBuildThisFileDirectory)RemoveUnusedMembers\CSharpRemoveUnusedMembersDiagnosticAnalyzer.cs" />
</ItemGroup>
</Project>
13 changes: 13 additions & 0 deletions src/Analyzers/CSharp/Analyzers/CSharpAnalyzers.shproj
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
<?xml version="1.0" encoding="utf-8"?>
<Project ToolsVersion="15.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<PropertyGroup Label="Globals">
<ProjectGuid>{EAFFCA55-335B-4860-BB99-EFCEAD123199}</ProjectGuid>
<MinimumVisualStudioVersion>14.0</MinimumVisualStudioVersion>
</PropertyGroup>
<Import Project="$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props" Condition="Exists('$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props')" />
<Import Project="$(MSBuildExtensionsPath32)\Microsoft\VisualStudio\v$(VisualStudioVersion)\CodeSharing\Microsoft.CodeSharing.Common.Default.props" />
<Import Project="$(MSBuildExtensionsPath32)\Microsoft\VisualStudio\v$(VisualStudioVersion)\CodeSharing\Microsoft.CodeSharing.Common.props" />
<PropertyGroup />
<Import Project="CSharpAnalyzers.projitems" Label="Shared" />
<Import Project="$(MSBuildExtensionsPath32)\Microsoft\VisualStudio\v$(VisualStudioVersion)\CodeSharing\Microsoft.CodeSharing.CSharp.targets" />
</Project>
Original file line number Diff line number Diff line change
Expand Up @@ -6,12 +6,19 @@
using System.Globalization;
using System.Linq;
using Microsoft.CodeAnalysis.CodeStyle;
using Microsoft.CodeAnalysis.CSharp.CodeStyle;
using Microsoft.CodeAnalysis.CSharp.Syntax;
using Microsoft.CodeAnalysis.Diagnostics;
using Microsoft.CodeAnalysis.Options;
using Microsoft.CodeAnalysis.PooledObjects;

#if CODE_STYLE
using Microsoft.CodeAnalysis.CSharp.Internal.CodeStyle;
using Resources = Microsoft.CodeAnalysis.CSharp.CSharpCodeStyleResources;
#else
using Microsoft.CodeAnalysis.CSharp.CodeStyle;
using Microsoft.CodeAnalysis.Options;
using Resources = Microsoft.CodeAnalysis.CSharp.CSharpFeaturesResources;
#endif

namespace Microsoft.CodeAnalysis.CSharp.ConvertSwitchStatementToExpression
{
using Constants = ConvertSwitchStatementToExpressionConstants;
Expand All @@ -23,8 +30,8 @@ public ConvertSwitchStatementToExpressionDiagnosticAnalyzer()
: base(IDEDiagnosticIds.ConvertSwitchStatementToExpressionDiagnosticId,
CSharpCodeStyleOptions.PreferSwitchExpression,
LanguageNames.CSharp,
new LocalizableResourceString(nameof(CSharpFeaturesResources.Convert_switch_statement_to_expression), CSharpFeaturesResources.ResourceManager, typeof(CSharpFeaturesResources)),
new LocalizableResourceString(nameof(CSharpFeaturesResources.Use_switch_expression), CSharpFeaturesResources.ResourceManager, typeof(CSharpFeaturesResources)))
new LocalizableResourceString(nameof(Resources.Convert_switch_statement_to_expression), Resources.ResourceManager, typeof(Resources)),
new LocalizableResourceString(nameof(Resources.Use_switch_expression), Resources.ResourceManager, typeof(Resources)))
{
}

Expand All @@ -48,7 +55,7 @@ private void AnalyzeSyntax(SyntaxNodeAnalysisContext context)

var options = context.Options;
var cancellationToken = context.CancellationToken;
var optionSet = options.GetDocumentOptionSetAsync(syntaxTree, cancellationToken).GetAwaiter().GetResult();
var optionSet = options.GetOptions(syntaxTree, cancellationToken);
mavasani marked this conversation as resolved.
Show resolved Hide resolved
if (optionSet == null)
{
return;
Expand Down Expand Up @@ -90,9 +97,6 @@ private void AnalyzeSyntax(SyntaxNodeAnalysisContext context)
.Add(Constants.ShouldRemoveNextStatementKey, shouldRemoveNextStatement.ToString(CultureInfo.InvariantCulture))));
}

public override bool OpenFileOnly(OptionSet options)
=> false;
mavasani marked this conversation as resolved.
Show resolved Hide resolved

public override DiagnosticAnalyzerCategory GetAnalyzerCategory()
=> DiagnosticAnalyzerCategory.SemanticSpanAnalysis;
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,13 +10,19 @@

namespace Microsoft.CodeAnalysis.CSharp.MakeStructFieldsWritable
{
#if CODE_STYLE
using Resources = CSharpCodeStyleResources;
#else
using Resources = FeaturesResources;
#endif

[DiagnosticAnalyzer(LanguageNames.CSharp)]
internal sealed class CSharpMakeStructFieldsWritableDiagnosticAnalyzer : AbstractCodeQualityDiagnosticAnalyzer
{
private static readonly DiagnosticDescriptor s_diagnosticDescriptor = CreateDescriptor(
IDEDiagnosticIds.MakeStructFieldsWritable,
new LocalizableResourceString(nameof(FeaturesResources.Make_readonly_fields_writable), FeaturesResources.ResourceManager, typeof(FeaturesResources)),
new LocalizableResourceString(nameof(FeaturesResources.Make_readonly_fields_writable), FeaturesResources.ResourceManager, typeof(FeaturesResources)),
new LocalizableResourceString(nameof(Resources.Make_readonly_fields_writable), Resources.ResourceManager, typeof(Resources)),
new LocalizableResourceString(nameof(Resources.Make_readonly_fields_writable), Resources.ResourceManager, typeof(Resources)),
isUnneccessary: false);

public CSharpMakeStructFieldsWritableDiagnosticAnalyzer()
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,8 @@
using System.Collections.Immutable;
using System.Linq;
using System.Threading;
using Microsoft.CodeAnalysis;
using Microsoft.CodeAnalysis.CSharp.Extensions;
using Microsoft.CodeAnalysis.CSharp.Syntax;
using Microsoft.CodeAnalysis.Diagnostics;
using Microsoft.CodeAnalysis.RemoveUnnecessaryImports;
Expand All @@ -15,22 +17,34 @@

namespace Microsoft.CodeAnalysis.CSharp.RemoveUnnecessaryImports
{
#if CODE_STYLE
using Resources = CSharpCodeStyleResources;
#else
using Resources = CSharpFeaturesResources;
#endif

[DiagnosticAnalyzer(LanguageNames.CSharp)]
internal sealed class CSharpRemoveUnnecessaryImportsDiagnosticAnalyzer :
AbstractRemoveUnnecessaryImportsDiagnosticAnalyzer
{
private static readonly LocalizableString s_TitleAndMessageFormat =
new LocalizableResourceString(nameof(CSharpFeaturesResources.Using_directive_is_unnecessary), CSharpFeaturesResources.ResourceManager, typeof(CSharpFeaturesResources));
private static readonly LocalizableString s_titleAndMessageFormat =
new LocalizableResourceString(nameof(Resources.Using_directive_is_unnecessary), Resources.ResourceManager, typeof(Resources));

protected override LocalizableString GetTitleAndMessageFormatForClassificationIdDescriptor()
=> s_TitleAndMessageFormat;
=> s_titleAndMessageFormat;

// C# has no need to do any merging of using statements. Only VB needs to
// merge import clauses to an import statement if it all the import clauses
// are unnecessary.
protected override ImmutableArray<SyntaxNode> MergeImports(ImmutableArray<SyntaxNode> unnecessaryImports)
=> unnecessaryImports;

protected override IUnnecessaryImportsProvider UnnecessaryImportsProvider
=> CSharpUnnecessaryImportsProvider.Instance;

protected override bool IsRegularCommentOrDocComment(SyntaxTrivia trivia)
=> trivia.IsRegularComment() || trivia.IsDocComment();
mavasani marked this conversation as resolved.
Show resolved Hide resolved

protected override IEnumerable<TextSpan> GetFixableDiagnosticSpans(
IEnumerable<SyntaxNode> nodes, SyntaxTree tree, CancellationToken cancellationToken)
{
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,13 +4,20 @@

using System.Collections.Immutable;
using Microsoft.CodeAnalysis.CodeStyle;
using Microsoft.CodeAnalysis.CSharp.CodeStyle;
using Microsoft.CodeAnalysis.CSharp.Extensions;
using Microsoft.CodeAnalysis.CSharp.Utilities;
using Microsoft.CodeAnalysis.Diagnostics;
using Microsoft.CodeAnalysis.Options;
using Microsoft.CodeAnalysis.Text;

#if CODE_STYLE
using Microsoft.CodeAnalysis.CSharp.Internal.CodeStyle;
using Microsoft.CodeAnalysis.Internal.Options;
using OptionSet = Microsoft.CodeAnalysis.Diagnostics.AnalyzerConfigOptions;
#else
using Microsoft.CodeAnalysis.CSharp.CodeStyle;
using Microsoft.CodeAnalysis.Options;
#endif

namespace Microsoft.CodeAnalysis.CSharp.Diagnostics.TypeStyle
{
internal abstract partial class CSharpTypeStyleDiagnosticAnalyzerBase :
Expand Down Expand Up @@ -50,7 +57,7 @@ private void HandleVariableDeclaration(SyntaxNodeAnalysisContext context)
var options = context.Options;
var syntaxTree = context.Node.SyntaxTree;
var cancellationToken = context.CancellationToken;
var optionSet = options.GetDocumentOptionSetAsync(syntaxTree, cancellationToken).GetAwaiter().GetResult();
var optionSet = options.GetOptions(syntaxTree, cancellationToken);
mavasani marked this conversation as resolved.
Show resolved Hide resolved
if (optionSet == null)
{
return;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,14 +7,20 @@

namespace Microsoft.CodeAnalysis.CSharp.Diagnostics.TypeStyle
{
#if CODE_STYLE
Copy link
Contributor Author

Choose a reason for hiding this comment

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

These #if statements should go away once @tmat's change #34003 goes in and we can use shared resource files for all analyzer and code fix resources that are shared between Workspaces, Features and CodeStyle layer.

using Resources = CSharpCodeStyleResources;
#else
using Resources = CSharpFeaturesResources;
#endif

[DiagnosticAnalyzer(LanguageNames.CSharp)]
internal sealed class CSharpUseExplicitTypeDiagnosticAnalyzer : CSharpTypeStyleDiagnosticAnalyzerBase
{
private static readonly LocalizableString s_Title =
new LocalizableResourceString(nameof(CSharpFeaturesResources.Use_explicit_type), CSharpFeaturesResources.ResourceManager, typeof(CSharpFeaturesResources));
new LocalizableResourceString(nameof(Resources.Use_explicit_type), Resources.ResourceManager, typeof(Resources));

private static readonly LocalizableString s_Message =
new LocalizableResourceString(nameof(CSharpFeaturesResources.Use_explicit_type_instead_of_var), CSharpFeaturesResources.ResourceManager, typeof(CSharpFeaturesResources));
new LocalizableResourceString(nameof(Resources.Use_explicit_type_instead_of_var), Resources.ResourceManager, typeof(Resources));

protected override CSharpTypeStyleHelper Helper => CSharpUseExplicitTypeHelper.Instance;

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,14 +7,20 @@

namespace Microsoft.CodeAnalysis.CSharp.Diagnostics.TypeStyle
{
#if CODE_STYLE
using Resources = CSharpCodeStyleResources;
#else
using Resources = CSharpFeaturesResources;
#endif

[DiagnosticAnalyzer(LanguageNames.CSharp)]
internal sealed class CSharpUseImplicitTypeDiagnosticAnalyzer : CSharpTypeStyleDiagnosticAnalyzerBase
{
private static readonly LocalizableString s_Title =
new LocalizableResourceString(nameof(CSharpFeaturesResources.Use_implicit_type), CSharpFeaturesResources.ResourceManager, typeof(CSharpFeaturesResources));
new LocalizableResourceString(nameof(Resources.Use_implicit_type), Resources.ResourceManager, typeof(Resources));

private static readonly LocalizableString s_Message =
new LocalizableResourceString(nameof(CSharpFeaturesResources.use_var_instead_of_explicit_type), CSharpFeaturesResources.ResourceManager, typeof(CSharpFeaturesResources));
new LocalizableResourceString(nameof(Resources.use_var_instead_of_explicit_type), Resources.ResourceManager, typeof(Resources));

protected override CSharpTypeStyleHelper Helper => CSharpUseImplicitTypeHelper.Instance;

Expand Down
20 changes: 20 additions & 0 deletions src/Analyzers/CSharp/CodeFixes/CSharpCodeFixes.projitems
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
<?xml version="1.0" encoding="utf-8"?>
<Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<PropertyGroup>
<MSBuildAllProjects>$(MSBuildAllProjects);$(MSBuildThisFileFullPath)</MSBuildAllProjects>
<HasSharedItems>true</HasSharedItems>
<SharedGUID>ec946164-1e17-410b-b7d9-7de7e6268d63</SharedGUID>
</PropertyGroup>
<PropertyGroup Label="Configuration">
<Import_RootNamespace>Microsoft.CodeAnalysis.CSharp.CodeFixes</Import_RootNamespace>
</PropertyGroup>
<ItemGroup>
<Compile Include="$(MSBuildThisFileDirectory)ConvertSwitchStatementToExpression\ConvertSwitchStatementToExpressionCodeFixProvider.cs" />
<Compile Include="$(MSBuildThisFileDirectory)ConvertSwitchStatementToExpression\ConvertSwitchStatementToExpressionCodeFixProvider.Rewriter.cs" />
<Compile Include="$(MSBuildThisFileDirectory)MakeStructFieldsWritable\CSharpMakeStructFieldsWritableCodeFixProvider.cs" />
<Compile Include="$(MSBuildThisFileDirectory)RemoveUnnecessaryImports\CSharpRemoveUnnecessaryImportsCodeFixProvider.cs" />
<Compile Include="$(MSBuildThisFileDirectory)RemoveUnusedMembers\CSharpRemoveUnusedMembersCodeFixProvider.cs" />
<Compile Include="$(MSBuildThisFileDirectory)UseImplicitOrExplicitType\UseExplicitTypeCodeFixProvider.cs" />
<Compile Include="$(MSBuildThisFileDirectory)UseImplicitOrExplicitType\UseImplicitTypeCodeFixProvider.cs" />
</ItemGroup>
</Project>
13 changes: 13 additions & 0 deletions src/Analyzers/CSharp/CodeFixes/CSharpCodeFixes.shproj
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
<?xml version="1.0" encoding="utf-8"?>
<Project ToolsVersion="15.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<PropertyGroup Label="Globals">
<ProjectGuid>{DA973826-C985-4128-9948-0B445E638BDB}</ProjectGuid>
<MinimumVisualStudioVersion>14.0</MinimumVisualStudioVersion>
</PropertyGroup>
<Import Project="$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props" Condition="Exists('$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props')" />
<Import Project="$(MSBuildExtensionsPath32)\Microsoft\VisualStudio\v$(VisualStudioVersion)\CodeSharing\Microsoft.CodeSharing.Common.Default.props" />
<Import Project="$(MSBuildExtensionsPath32)\Microsoft\VisualStudio\v$(VisualStudioVersion)\CodeSharing\Microsoft.CodeSharing.Common.props" />
<PropertyGroup />
<Import Project="CSharpCodeFixes.projitems" Label="Shared" />
<Import Project="$(MSBuildExtensionsPath32)\Microsoft\VisualStudio\v$(VisualStudioVersion)\CodeSharing\Microsoft.CodeSharing.CSharp.targets" />
</Project>
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,11 @@
namespace Microsoft.CodeAnalysis.CSharp.ConvertSwitchStatementToExpression
{
using Constants = ConvertSwitchStatementToExpressionConstants;
#if CODE_STYLE
using Resources = CSharpCodeStyleFixesResources;
#else
using Resources = CSharpFeaturesResources;
#endif

[ExportCodeFixProvider(LanguageNames.CSharp), Shared]
internal sealed partial class ConvertSwitchStatementToExpressionCodeFixProvider : SyntaxEditorBasedCodeFixProvider
Expand Down Expand Up @@ -94,10 +99,10 @@ protected override async Task FixAllAsync(Document document, ImmutableArray<Diag
}
}

private sealed class MyCodeAction : CodeAction.DocumentChangeAction
private sealed class MyCodeAction : CustomCodeActions.DocumentChangeAction
mavasani marked this conversation as resolved.
Show resolved Hide resolved
{
public MyCodeAction(Func<CancellationToken, Task<Document>> createChangedDocument)
: base(CSharpFeaturesResources.Convert_switch_statement_to_expression, createChangedDocument)
: base(Resources.Convert_switch_statement_to_expression, createChangedDocument)
{
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,12 @@

namespace Microsoft.CodeAnalysis.CSharp.MakeStructFieldsWritable
{
#if CODE_STYLE
using Resources = CSharpCodeStyleResources;
#else
using Resources = FeaturesResources;
#endif

[ExportCodeFixProvider(LanguageNames.CSharp, Name = PredefinedCodeFixProviderNames.MakeStructFieldsWritable), Shared]
internal class CSharpMakeStructFieldsWritableCodeFixProvider : SyntaxEditorBasedCodeFixProvider
{
Expand Down Expand Up @@ -72,10 +78,10 @@ protected override Task FixAllAsync(
return Task.CompletedTask;
}

private class MyCodeAction : CodeAction.DocumentChangeAction
private class MyCodeAction : CustomCodeActions.DocumentChangeAction
{
public MyCodeAction(Func<CancellationToken, Task<Document>> createChangedDocument)
: base(FeaturesResources.Make_readonly_fields_writable, createChangedDocument)
: base(Resources.Make_readonly_fields_writable, createChangedDocument)
{
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,12 @@

namespace Microsoft.CodeAnalysis.CSharp.RemoveUnnecessaryImports
{
#if CODE_STYLE
using Resources = CSharpCodeStyleFixesResources;
#else
using Resources = CSharpFeaturesResources;
#endif

[ExportCodeFixProvider(LanguageNames.CSharp, Name = PredefinedCodeFixProviderNames.RemoveUnnecessaryImports), Shared]
[ExtensionOrder(After = PredefinedCodeFixProviderNames.AddMissingReference)]
internal class CSharpRemoveUnnecessaryImportsCodeFixProvider : AbstractRemoveUnnecessaryImportsCodeFixProvider
Expand All @@ -18,6 +24,6 @@ public CSharpRemoveUnnecessaryImportsCodeFixProvider()
}

protected override string GetTitle()
=> CSharpFeaturesResources.Remove_Unnecessary_Usings;
=> Resources.Remove_Unnecessary_Usings;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,12 @@

namespace Microsoft.CodeAnalysis.CSharp.TypeStyle
{
#if CODE_STYLE
using Resources = CSharpCodeStyleResources;
#else
using Resources = CSharpFeaturesResources;
#endif

[ExportCodeFixProvider(LanguageNames.CSharp, Name = PredefinedCodeFixProviderNames.UseExplicitType), Shared]
internal class UseExplicitTypeCodeFixProvider : SyntaxEditorBasedCodeFixProvider
{
Expand Down Expand Up @@ -158,12 +164,12 @@ private static ExpressionSyntax GenerateTupleDeclaration(ITypeSymbol typeSymbol,
.WithTrailingTrivia(parensDesignation.GetTrailingTrivia());
}

private class MyCodeAction : CodeAction.DocumentChangeAction
private class MyCodeAction : CustomCodeActions.DocumentChangeAction
{
public MyCodeAction(Func<CancellationToken, Task<Document>> createChangedDocument)
: base(CSharpFeaturesResources.Use_explicit_type_instead_of_var,
: base(Resources.Use_explicit_type_instead_of_var,
createChangedDocument,
CSharpFeaturesResources.Use_explicit_type_instead_of_var)
Resources.Use_explicit_type_instead_of_var)
{
}
}
Expand Down
Loading