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