Add TreatWarningsAsErrors to README for CLI
This commit is contained in:
@@ -24,37 +24,29 @@ public class TreatWarningsAsErrorsCommand : Command<TreatWarningsAsErrorsCommand
|
||||
var solutionFile = SolutionProjectParity.ParseSolutionFileFromPath(pathToSolutionFile);
|
||||
if (solutionFile == null)
|
||||
{
|
||||
Console.WriteLine(
|
||||
"Failed to parse solution file. The file was either not found or malformed."
|
||||
);
|
||||
Console.WriteLine("Failed to parse solution file. The file was either not found or malformed.");
|
||||
return 1;
|
||||
}
|
||||
var cSharpProjects = SolutionProjectParity.GetCSharpProjectObjectsFromSolutionFile(
|
||||
solutionFile
|
||||
);
|
||||
var cSharpProjects = SolutionProjectParity.GetCSharpProjectObjectsFromSolutionFile(solutionFile);
|
||||
Console.WriteLine($"Found {cSharpProjects.Count} C# Projects");
|
||||
Console.WriteLine("==================================================");
|
||||
|
||||
// Get the list of projects
|
||||
var projectsMissingImplicitUsings = WarningsAsErrors.FindCSharpProjectsMissingTreatWarningsAsErrors(
|
||||
var projectsMissingTreatWarningsAsErrors = WarningsAsErrors.FindCSharpProjectsMissingTreatWarningsAsErrors(
|
||||
cSharpProjects
|
||||
);
|
||||
|
||||
Console.WriteLine(
|
||||
$"{projectsMissingImplicitUsings.Count} C# Projects have missing Treat Warnings As Errors"
|
||||
$"{projectsMissingTreatWarningsAsErrors.Count} C# Projects have missing Treat Warnings As Errors"
|
||||
);
|
||||
|
||||
if (settings.AddMissing)
|
||||
{
|
||||
Console.WriteLine("==================================================");
|
||||
Console.WriteLine("Adding missing Warnings As Errors");
|
||||
WarningsAsErrors.AddMissingTreatWarningsAsErrors(projectsMissingImplicitUsings);
|
||||
var updatedProjects = SolutionProjectParity.GetCSharpProjectObjectsFromSolutionFile(
|
||||
solutionFile
|
||||
);
|
||||
var projectsWithMissing = WarningsAsErrors.FindCSharpProjectsMissingTreatWarningsAsErrors(
|
||||
updatedProjects
|
||||
);
|
||||
WarningsAsErrors.AddMissingTreatWarningsAsErrors(projectsMissingTreatWarningsAsErrors);
|
||||
var updatedProjects = SolutionProjectParity.GetCSharpProjectObjectsFromSolutionFile(solutionFile);
|
||||
var projectsWithMissing = WarningsAsErrors.FindCSharpProjectsMissingTreatWarningsAsErrors(updatedProjects);
|
||||
Console.WriteLine(
|
||||
$"There are now {projectsWithMissing.Count} C# Projects missing Treat Warnings As Errors"
|
||||
);
|
||||
|
||||
@@ -7,13 +7,9 @@ public static class WarningsAsErrors
|
||||
public static List<string> FindCSharpProjectsMissingTreatWarningsAsErrors(string solutionFilePath)
|
||||
{
|
||||
var solutionFile = SolutionFile.Parse(solutionFilePath);
|
||||
var csprojList = SolutionProjectParity.GetCSharpProjectObjectsFromSolutionFile(
|
||||
solutionFile
|
||||
);
|
||||
var csprojList = SolutionProjectParity.GetCSharpProjectObjectsFromSolutionFile(solutionFile);
|
||||
var projectsMissingImplicitUsings = FindCSharpProjectsMissingTreatWarningsAsErrors(csprojList);
|
||||
var projectsMissingImplicitUsingsStringList = projectsMissingImplicitUsings
|
||||
.Select(x => x.FullPath)
|
||||
.ToList();
|
||||
var projectsMissingImplicitUsingsStringList = projectsMissingImplicitUsings.Select(x => x.FullPath).ToList();
|
||||
|
||||
return projectsMissingImplicitUsingsStringList;
|
||||
}
|
||||
@@ -26,8 +22,8 @@ public static class WarningsAsErrors
|
||||
|
||||
foreach (var project in projectList)
|
||||
{
|
||||
var treatWarningsAsErrors = project.PropertyGroups
|
||||
.SelectMany(x => x.Properties)
|
||||
var treatWarningsAsErrors = project
|
||||
.PropertyGroups.SelectMany(x => x.Properties)
|
||||
.FirstOrDefault(x => x.Name == "TreatWarningsAsErrors");
|
||||
if (treatWarningsAsErrors is null || treatWarningsAsErrors.Value is not "true")
|
||||
{
|
||||
@@ -37,13 +33,11 @@ public static class WarningsAsErrors
|
||||
|
||||
return projectsMissingTreatWarningsAsErrors;
|
||||
}
|
||||
|
||||
|
||||
public static void AddMissingTreatWarningsAsErrorsToSolution(string solutionFilePath)
|
||||
{
|
||||
var solutionFile = SolutionFile.Parse(solutionFilePath);
|
||||
var csprojList = SolutionProjectParity.GetCSharpProjectObjectsFromSolutionFile(
|
||||
solutionFile
|
||||
);
|
||||
var csprojList = SolutionProjectParity.GetCSharpProjectObjectsFromSolutionFile(solutionFile);
|
||||
var projectsMissingImplicitUsings = FindCSharpProjectsMissingTreatWarningsAsErrors(csprojList);
|
||||
AddMissingTreatWarningsAsErrors(projectsMissingImplicitUsings);
|
||||
}
|
||||
@@ -51,36 +45,29 @@ public static class WarningsAsErrors
|
||||
public static void RemoveAllTreatWarningsAsErrorsInSolution(string solutionFilePath)
|
||||
{
|
||||
var solutionFile = SolutionFile.Parse(solutionFilePath);
|
||||
var csprojList = SolutionProjectParity.GetCSharpProjectObjectsFromSolutionFile(
|
||||
solutionFile
|
||||
);
|
||||
var csprojList = SolutionProjectParity.GetCSharpProjectObjectsFromSolutionFile(solutionFile);
|
||||
RemoveTreatWarningsAsErrors(csprojList);
|
||||
}
|
||||
|
||||
public static void AddMissingTreatWarningsAsErrors(
|
||||
List<ProjectRootElement> projectsMissingImplicitUsings
|
||||
)
|
||||
|
||||
public static void AddMissingTreatWarningsAsErrors(List<ProjectRootElement> projectsMissingImplicitUsings)
|
||||
{
|
||||
foreach (var project in projectsMissingImplicitUsings)
|
||||
{
|
||||
if (ProjectIsMissingTreatWarningsAsErrors(project))
|
||||
{
|
||||
|
||||
project.AddProperty("TreatWarningsAsErrors", "true");
|
||||
project.Save();
|
||||
FormatCsproj.FormatCsprojFile(project.FullPath);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public static void RemoveTreatWarningsAsErrors(
|
||||
List<ProjectRootElement> projectList
|
||||
)
|
||||
|
||||
public static void RemoveTreatWarningsAsErrors(List<ProjectRootElement> projectList)
|
||||
{
|
||||
foreach (var project in projectList)
|
||||
{
|
||||
var treatWarningsAsErrors = project.PropertyGroups
|
||||
.SelectMany(x => x.Properties)
|
||||
var treatWarningsAsErrors = project
|
||||
.PropertyGroups.SelectMany(x => x.Properties)
|
||||
.FirstOrDefault(x => x.Name == "TreatWarningsAsErrors");
|
||||
if (treatWarningsAsErrors is not null)
|
||||
{
|
||||
@@ -93,8 +80,8 @@ public static class WarningsAsErrors
|
||||
|
||||
private static bool ProjectIsMissingTreatWarningsAsErrors(ProjectRootElement project)
|
||||
{
|
||||
var implicitUsings = project.PropertyGroups
|
||||
.SelectMany(x => x.Properties)
|
||||
var implicitUsings = project
|
||||
.PropertyGroups.SelectMany(x => x.Properties)
|
||||
.FirstOrDefault(x => x.Name == "TreatWarningsAsErrors");
|
||||
if (implicitUsings is null)
|
||||
{
|
||||
@@ -107,7 +94,7 @@ public static class WarningsAsErrors
|
||||
private static bool ProjectBuildSuccessfully(ProjectRootElement project)
|
||||
{
|
||||
// build the project
|
||||
var buildProject = new Microsoft.Build.Evaluation.Project(project);
|
||||
var buildProject = new Microsoft.Build.Evaluation.Project(project);
|
||||
// retrieve warnings
|
||||
var buildResult = buildProject.Build();
|
||||
return buildResult;
|
||||
|
||||
@@ -25,11 +25,9 @@ _options_
|
||||
`-d|--enable-disabled` enables disabled implicit usings in all project files
|
||||
`-a|--enable-all` enables implicit usings in all project files
|
||||
|
||||
**warnings-as-errors** `<SolutionFilePath>` **NOT IMPLEMENTED IN CLI YET** Find projects in sln that don't have TreatWarningsAsErrors enabled. Optionally enables them.
|
||||
**warnings-as-errors** `<SolutionFilePath>` Find projects in sln that don't have TreatWarningsAsErrors enabled. Optionally enables them.
|
||||
_options_
|
||||
`-m|--add-missing` adds missing TreatWarningsAsErrors to all project files
|
||||
`-d|--enable-disabled` enables disabled TreatWarningsAsErrors in all project files
|
||||
`-a|--enable-all` enables TreatWarningsAsErrors in all project files
|
||||
`-m|--add-missing` adds missing TreatWarningsAsErrors to all project files
|
||||
|
||||
**clear-bin-obj** `<SolutionFolderPath>` **NOT IMPLEMENTED IN CLI YET** Deletes all bin and obj folders, and node_modules folders in the solution folder.
|
||||
|
||||
|
||||
Reference in New Issue
Block a user