From c30f95a0863bcf60a2ffb66e64cb4b23b5f9bf1f Mon Sep 17 00:00:00 2001 From: Vincent Marmin <3215889+vincent314@users.noreply.github.com> Date: Tue, 10 Dec 2024 15:56:33 +0100 Subject: [PATCH] feat: rename rule keys from ECXXX to GCIXXX --- .../EC83.ReplaceEnumToStringWithNameOf.cs | 28 ------ ...CI69.DontCallFunctionsInLoopConditions.cs} | 4 +- ...=> GCI72.DontExecuteSqlCommandsInLoops.cs} | 10 +- ...=> GCI75.DontConcatenateStringsInLoops.cs} | 62 ++++++------ ...Layout.cs => GCI81.SpecifyStructLayout.cs} | 6 +- ....cs => GCI82.VariableCanBeMadeConstant.cs} | 10 +- .../GCI83.ReplaceEnumToStringWithNameOf.cs | 28 ++++++ ...hods.cs => GCI84.AvoidAsyncVoidMethods.cs} | 4 +- ...eTypeSealed.cs => GCI85.MakeTypeSealed.cs} | 96 +++++++++---------- ...cs => GCI86.GCCollectShouldNotBeCalled.cs} | 12 +-- ...ListIndexer.cs => GCI87.UseListIndexer.cs} | 18 ++-- ... => GCI88.DisposeResourceAsynchronusly.cs} | 4 +- ...erBy.cs => GCI91.UseWhereBeforeOrderBy.cs} | 8 +- ...s => GCI92.UseLengthToTestEmptyStrings.cs} | 2 +- ...irectly.cs => GCI93.ReturnTaskDirectly.cs} | 6 +- 15 files changed, 149 insertions(+), 149 deletions(-) delete mode 100644 RuleTests/EcoCode/EC83.ReplaceEnumToStringWithNameOf.cs rename RuleTests/EcoCode/{EC69.DontCallFunctionsInLoopConditions.cs => GCI69.DontCallFunctionsInLoopConditions.cs} (88%) rename RuleTests/EcoCode/{EC72.DontExecuteSqlCommandsInLoops.cs => GCI72.DontExecuteSqlCommandsInLoops.cs} (62%) rename RuleTests/EcoCode/{EC75.DontConcatenateStringsInLoops.cs => GCI75.DontConcatenateStringsInLoops.cs} (77%) rename RuleTests/EcoCode/{EC81.SpecifyStructLayout.cs => GCI81.SpecifyStructLayout.cs} (70%) rename RuleTests/EcoCode/{EC82.VariableCanBeMadeConstant.cs => GCI82.VariableCanBeMadeConstant.cs} (69%) create mode 100644 RuleTests/EcoCode/GCI83.ReplaceEnumToStringWithNameOf.cs rename RuleTests/EcoCode/{EC84.AvoidAsyncVoidMethods.cs => GCI84.AvoidAsyncVoidMethods.cs} (73%) rename RuleTests/EcoCode/{EC85.MakeTypeSealed.cs => GCI85.MakeTypeSealed.cs} (77%) rename RuleTests/EcoCode/{EC86.GCCollectShouldNotBeCalled.cs => GCI86.GCCollectShouldNotBeCalled.cs} (74%) rename RuleTests/EcoCode/{EC87.UseListIndexer.cs => GCI87.UseListIndexer.cs} (79%) rename RuleTests/EcoCode/{EC88.DisposeResourceAsynchronusly.cs => GCI88.DisposeResourceAsynchronusly.cs} (89%) rename RuleTests/EcoCode/{EC91.UseWhereBeforeOrderBy.cs => GCI91.UseWhereBeforeOrderBy.cs} (82%) rename RuleTests/EcoCode/{EC92.UseLengthToTestEmptyStrings.cs => GCI92.UseLengthToTestEmptyStrings.cs} (86%) rename RuleTests/EcoCode/{EC93.ReturnTaskDirectly.cs => GCI93.ReturnTaskDirectly.cs} (94%) diff --git a/RuleTests/EcoCode/EC83.ReplaceEnumToStringWithNameOf.cs b/RuleTests/EcoCode/EC83.ReplaceEnumToStringWithNameOf.cs deleted file mode 100644 index 5123308..0000000 --- a/RuleTests/EcoCode/EC83.ReplaceEnumToStringWithNameOf.cs +++ /dev/null @@ -1,28 +0,0 @@ -namespace RuleTests.EcoCode; - -internal static class ReplaceEnumToStringWithNameOf -{ - private enum MyEnum { A, B, C, D } - - public static void Run() - { - Console.WriteLine(nameof(MyEnum.A)); - Console.WriteLine(nameof(MyEnum.B)); - Console.WriteLine(nameof(MyEnum.C)); - Console.WriteLine(nameof(MyEnum.D)); - - Console.WriteLine(MyEnum.A.ToString()); // EC83, code fix: nameof(MyEnum.A) - Console.WriteLine(MyEnum.B.ToString("")); // EC83, code fix: nameof(MyEnum.B) - Console.WriteLine(MyEnum.C.ToString(string.Empty)); // EC83, code fix: nameof(MyEnum.C) - Console.WriteLine(MyEnum.D.ToString(format: null)); // EC83, code fix: nameof(MyEnum.D) - - Console.WriteLine(MyEnum.A.ToString("G")); // EC83, code fix: nameof(MyEnum.A) - Console.WriteLine(MyEnum.B.ToString("F")); // EC83, code fix: nameof(MyEnum.B) - Console.WriteLine(MyEnum.C.ToString("N")); - - Console.WriteLine($"{MyEnum.A}"); // EC83, code fix: nameof(MyEnum.A) - Console.WriteLine($"{MyEnum.B:G}"); // EC83, code fix: nameof(MyEnum.B) - Console.WriteLine($"{MyEnum.C:F}"); // EC83, code fix: nameof(MyEnum.C) - Console.WriteLine($"{MyEnum.D:N}"); - } -} diff --git a/RuleTests/EcoCode/EC69.DontCallFunctionsInLoopConditions.cs b/RuleTests/EcoCode/GCI69.DontCallFunctionsInLoopConditions.cs similarity index 88% rename from RuleTests/EcoCode/EC69.DontCallFunctionsInLoopConditions.cs rename to RuleTests/EcoCode/GCI69.DontCallFunctionsInLoopConditions.cs index 6fa238c..12228ab 100644 --- a/RuleTests/EcoCode/EC69.DontCallFunctionsInLoopConditions.cs +++ b/RuleTests/EcoCode/GCI69.DontCallFunctionsInLoopConditions.cs @@ -13,7 +13,7 @@ public static void Run(int p) { int i, j = 0, k = 10; - // EC69 on V2(), V3(k), V3(p) and V3(C) + // GCI69 on V2(), V3(k), V3(p) and V3(C) for (i = 0; i < V1 && i < V2() && i < V3(i) && i < V3(j) && i < V3(k) && i < V3(p) && i < V3(C); i++) j += i; @@ -25,7 +25,7 @@ public static void Run(int p) while (i < V1 && i < V2() && i < V3(i) && i < V3(j) && i < V3(k) && i < V3(p) && i < V3(C)); string? d = Path.GetDirectoryName("toto"); - while (d != null && !d.Equals(@"S:\", StringComparison.OrdinalIgnoreCase)) // No EC69, d is reassigned in the loop + while (d != null && !d.Equals(@"S:\", StringComparison.OrdinalIgnoreCase)) // No GCI69, d is reassigned in the loop d = Path.GetDirectoryName(d); } } diff --git a/RuleTests/EcoCode/EC72.DontExecuteSqlCommandsInLoops.cs b/RuleTests/EcoCode/GCI72.DontExecuteSqlCommandsInLoops.cs similarity index 62% rename from RuleTests/EcoCode/EC72.DontExecuteSqlCommandsInLoops.cs rename to RuleTests/EcoCode/GCI72.DontExecuteSqlCommandsInLoops.cs index cea4fd6..cae2c49 100644 --- a/RuleTests/EcoCode/EC72.DontExecuteSqlCommandsInLoops.cs +++ b/RuleTests/EcoCode/GCI72.DontExecuteSqlCommandsInLoops.cs @@ -6,7 +6,7 @@ internal static class DontExecuteSqlCommandsInLoops { public static void Run() { - var command = default(IDbCommand)!; // EC82, code fix: const IDbCommand command = default!; + var command = default(IDbCommand)!; // GCI82, code fix: const IDbCommand command = default!; _ = command.ExecuteNonQuery(); _ = command.ExecuteScalar(); _ = command.ExecuteReader(); @@ -14,10 +14,10 @@ public static void Run() for (int i = 0; i < 10; i++) { - _ = command.ExecuteNonQuery(); // EC72 - _ = command.ExecuteScalar(); // EC72 - _ = command.ExecuteReader(); // EC72 - _ = command.ExecuteReader(CommandBehavior.Default); // EC72 + _ = command.ExecuteNonQuery(); // GCI72 + _ = command.ExecuteScalar(); // GCI72 + _ = command.ExecuteReader(); // GCI72 + _ = command.ExecuteReader(CommandBehavior.Default); // GCI72 } } } diff --git a/RuleTests/EcoCode/EC75.DontConcatenateStringsInLoops.cs b/RuleTests/EcoCode/GCI75.DontConcatenateStringsInLoops.cs similarity index 77% rename from RuleTests/EcoCode/EC75.DontConcatenateStringsInLoops.cs rename to RuleTests/EcoCode/GCI75.DontConcatenateStringsInLoops.cs index 83e0e1a..9a30367 100644 --- a/RuleTests/EcoCode/EC75.DontConcatenateStringsInLoops.cs +++ b/RuleTests/EcoCode/GCI75.DontConcatenateStringsInLoops.cs @@ -11,18 +11,18 @@ public static void DontConcatenateStringsWithParameterAllLoops(string sParam) for (int i = 0; i < 10; i++) { string si = $"{i}"; - sParam += si; // EC75 - sParam = sParam + si; // EC75 - sParam = si + sParam; // EC75 + sParam += si; // GCI75 + sParam = sParam + si; // GCI75 + sParam = si + sParam; // GCI75 sParam = si + si; } foreach (int i in Enumerable.Range(0, 10)) { string si = $"{i}"; - sParam += si; // EC75 - sParam = sParam + si; // EC75 - sParam = si + sParam; // EC75 + sParam += si; // GCI75 + sParam = sParam + si; // GCI75 + sParam = si + sParam; // GCI75 sParam = si + si; } @@ -30,9 +30,9 @@ public static void DontConcatenateStringsWithParameterAllLoops(string sParam) while (i2++ < 10) { string si = $"{i2}"; - sParam += si; // EC75 - sParam = sParam + si; // EC75 - sParam = si + sParam; // EC75 + sParam += si; // GCI75 + sParam = sParam + si; // GCI75 + sParam = si + sParam; // GCI75 sParam = si + si; } @@ -40,9 +40,9 @@ public static void DontConcatenateStringsWithParameterAllLoops(string sParam) do { string si = $"{i2}"; - sParam += si; // EC75 - sParam = sParam + si; // EC75 - sParam = si + sParam; // EC75 + sParam += si; // GCI75 + sParam = sParam + si; // GCI75 + sParam = si + sParam; // GCI75 sParam = si + si; } while (++i2 < 10); } @@ -54,9 +54,9 @@ public static void DontConcatenateStringsWithField() for (int i = 0; i < 10; i++) { string si = $"{i}"; - sField += si; // EC75 - sField = sField + si; // EC75 - sField = si + sField; // EC75 + sField += si; // GCI75 + sField = sField + si; // GCI75 + sField = si + sField; // GCI75 sField = si + si; } } @@ -67,9 +67,9 @@ public static void DontConcatenateStringsWithProperty() for (int i = 0; i < 10; i++) { string si = $"{i}"; - sProp += si; // EC75 - sProp = sProp + si; // EC75 - sProp = si + sProp; // EC75 + sProp += si; // GCI75 + sProp = sProp + si; // GCI75 + sProp = si + sProp; // GCI75 sProp = si + si; } } @@ -80,9 +80,9 @@ public static void DontConcatenateStringsWithLocal() for (int i = 0; i < 10; i++) { string si = $"{i}"; - sLocal += si; // EC75 - sLocal = sLocal + si; // EC75 - sLocal = si + sLocal; // EC75 + sLocal += si; // GCI75 + sLocal = sLocal + si; // GCI75 + sLocal = si + sLocal; // GCI75 sLocal = si + si; string sLocalInLoop = string.Empty; @@ -105,26 +105,26 @@ public static void DontConcatenateStringsWithForEach() Array.ForEach(arr, i => { string si = $"{i}"; - sLocal += si; // EC75 - sLocal = sLocal + si; // EC75 - sLocal = si + sLocal; // EC75 + sLocal += si; // GCI75 + sLocal = sLocal + si; // GCI75 + sLocal = si + sLocal; // GCI75 sLocal = si + si; }); - Array.ForEach(arr, i => sLocal += $"{i}"); // EC75 - Array.ForEach(arr, i => sLocal = sLocal + $"{i}"); // EC75 - Array.ForEach(arr, i => sLocal = $"{i}" + sLocal); // EC75 + Array.ForEach(arr, i => sLocal += $"{i}"); // GCI75 + Array.ForEach(arr, i => sLocal = sLocal + $"{i}"); // GCI75 + Array.ForEach(arr, i => sLocal = $"{i}" + sLocal); // GCI75 Array.ForEach(arr, i => sLocal = $"{i}" + $"{i}"); var list = new List(); list.ForEach(i => { string si = $"{i}"; - sLocal += si; // EC75 - sLocal = sLocal + si; // EC75 - sLocal = si + sLocal; // EC75 + sLocal += si; // GCI75 + sLocal = sLocal + si; // GCI75 + sLocal = si + sLocal; // GCI75 sLocal = si + si; }); - list.ForEach(i => sLocal += $"{i}"); // EC75 + list.ForEach(i => sLocal += $"{i}"); // GCI75 list.ForEach(i => sLocal = sLocal + $"{i}"); // EC75 list.ForEach(i => sLocal = $"{i}" + sLocal); // EC75 list.ForEach(i => sLocal = $"{i}" + $"{i}"); diff --git a/RuleTests/EcoCode/EC81.SpecifyStructLayout.cs b/RuleTests/EcoCode/GCI81.SpecifyStructLayout.cs similarity index 70% rename from RuleTests/EcoCode/EC81.SpecifyStructLayout.cs rename to RuleTests/EcoCode/GCI81.SpecifyStructLayout.cs index a03818c..e0a4419 100644 --- a/RuleTests/EcoCode/EC81.SpecifyStructLayout.cs +++ b/RuleTests/EcoCode/GCI81.SpecifyStructLayout.cs @@ -8,14 +8,14 @@ internal static class SpecifyStructLayout public readonly record struct TestStruct2(int A); - public readonly record struct TestStruct3(int A, double B); // EC81, code fix: Add StructLayout attribute (Auto or Sequential) + public readonly record struct TestStruct3(int A, double B); // GCI81, code fix: Add StructLayout attribute (Auto or Sequential) [StructLayout(LayoutKind.Auto)] public readonly record struct TestStruct4(int A, double B); public readonly record struct TestStruct5(int A, string B); - public readonly record struct TestStruct6(int A, double B, int C); // EC81, code fix: Add StructLayout attribute (Auto or Sequential) + public readonly record struct TestStruct6(int A, double B, int C); // GCI81, code fix: Add StructLayout attribute (Auto or Sequential) - public readonly record struct TestStruct7(bool A, int B, char C, ulong E, DateTime F); // EC81, code fix: Add StructLayout attribute (Auto or Sequential) + public readonly record struct TestStruct7(bool A, int B, char C, ulong E, DateTime F); // GCI81, code fix: Add StructLayout attribute (Auto or Sequential) } diff --git a/RuleTests/EcoCode/EC82.VariableCanBeMadeConstant.cs b/RuleTests/EcoCode/GCI82.VariableCanBeMadeConstant.cs similarity index 69% rename from RuleTests/EcoCode/EC82.VariableCanBeMadeConstant.cs rename to RuleTests/EcoCode/GCI82.VariableCanBeMadeConstant.cs index 462fb1a..bdc248f 100644 --- a/RuleTests/EcoCode/EC82.VariableCanBeMadeConstant.cs +++ b/RuleTests/EcoCode/GCI82.VariableCanBeMadeConstant.cs @@ -4,7 +4,7 @@ internal static class VariableCanBeMadeConstant { public static void Run() { - int i0 = 0; // EC82, code fix: const int i0 = 0; + int i0 = 0; // GCI82, code fix: const int i0 = 0; Console.WriteLine(i0); int i1 = 0; @@ -24,20 +24,20 @@ public static void Run() Console.WriteLine(i5); Console.WriteLine(i6); - int i7 = 0, i8 = 0; // EC82, code fix: const int i7 = 0, i8 = 0; + int i7 = 0, i8 = 0; // GCI82, code fix: const int i7 = 0, i8 = 0; Console.WriteLine(i7); Console.WriteLine(i8); object o = "abc"; Console.WriteLine(o); - string s = "abc"; // EC82, code fix: const string s = "abc"; + string s = "abc"; // GCI82, code fix: const string s = "abc"; Console.WriteLine(s); - var v0 = 4; // EC82, code fix: const int item = 4; + var v0 = 4; // GCI82, code fix: const int item = 4; Console.WriteLine(v0); - var v1 = "abc"; // EC82, code fix: const string item = "abc"; + var v1 = "abc"; // GCI82, code fix: const string item = "abc"; Console.WriteLine(v1); } } diff --git a/RuleTests/EcoCode/GCI83.ReplaceEnumToStringWithNameOf.cs b/RuleTests/EcoCode/GCI83.ReplaceEnumToStringWithNameOf.cs new file mode 100644 index 0000000..54b4ade --- /dev/null +++ b/RuleTests/EcoCode/GCI83.ReplaceEnumToStringWithNameOf.cs @@ -0,0 +1,28 @@ +namespace RuleTests.EcoCode; + +internal static class ReplaceEnumToStringWithNameOf +{ + private enum MyEnum { A, B, C, D } + + public static void Run() + { + Console.WriteLine(nameof(MyEnum.A)); + Console.WriteLine(nameof(MyEnum.B)); + Console.WriteLine(nameof(MyEnum.C)); + Console.WriteLine(nameof(MyEnum.D)); + + Console.WriteLine(MyEnum.A.ToString()); // GCI83, code fix: nameof(MyEnum.A) + Console.WriteLine(MyEnum.B.ToString("")); // GCI83, code fix: nameof(MyEnum.B) + Console.WriteLine(MyEnum.C.ToString(string.Empty)); // GCI83, code fix: nameof(MyEnum.C) + Console.WriteLine(MyEnum.D.ToString(format: null)); // GCI83, code fix: nameof(MyEnum.D) + + Console.WriteLine(MyEnum.A.ToString("G")); // GCI83, code fix: nameof(MyEnum.A) + Console.WriteLine(MyEnum.B.ToString("F")); // GCI83, code fix: nameof(MyEnum.B) + Console.WriteLine(MyEnum.C.ToString("N")); + + Console.WriteLine($"{MyEnum.A}"); // GCI83, code fix: nameof(MyEnum.A) + Console.WriteLine($"{MyEnum.B:G}"); // GCI83, code fix: nameof(MyEnum.B) + Console.WriteLine($"{MyEnum.C:F}"); // GCI83, code fix: nameof(MyEnum.C) + Console.WriteLine($"{MyEnum.D:N}"); + } +} diff --git a/RuleTests/EcoCode/EC84.AvoidAsyncVoidMethods.cs b/RuleTests/EcoCode/GCI84.AvoidAsyncVoidMethods.cs similarity index 73% rename from RuleTests/EcoCode/EC84.AvoidAsyncVoidMethods.cs rename to RuleTests/EcoCode/GCI84.AvoidAsyncVoidMethods.cs index e999d5d..85621ed 100644 --- a/RuleTests/EcoCode/EC84.AvoidAsyncVoidMethods.cs +++ b/RuleTests/EcoCode/GCI84.AvoidAsyncVoidMethods.cs @@ -4,7 +4,7 @@ namespace RuleTests.EcoCode; internal static class AvoidAsyncVoidMethods { - public static async void Method1() => // EC84, code fix: public static async Task Method1() + public static async void Method1() => // GCI84, code fix: public static async Task Method1() await Task.Delay(1000).ConfigureAwait(false); public static async Task Method2() => @@ -16,7 +16,7 @@ public static async Task Method3() return 1; } - public static async void Method4() // EC84, code fix: public static async Task Method4() + public static async void Method4() // GCI84, code fix: public static async Task Method4() { using var httpClient = new HttpClient(); _ = await httpClient.GetAsync(new Uri("URL")).ConfigureAwait(false); diff --git a/RuleTests/EcoCode/EC85.MakeTypeSealed.cs b/RuleTests/EcoCode/GCI85.MakeTypeSealed.cs similarity index 77% rename from RuleTests/EcoCode/EC85.MakeTypeSealed.cs rename to RuleTests/EcoCode/GCI85.MakeTypeSealed.cs index d864c91..c6088d9 100644 --- a/RuleTests/EcoCode/EC85.MakeTypeSealed.cs +++ b/RuleTests/EcoCode/GCI85.MakeTypeSealed.cs @@ -1,59 +1,59 @@ namespace RuleTests.EcoCode; -// Because EC85 is a compiler warning, it can't appear live in the editor. +// Because GCI85 is a compiler warning, it can't appear live in the editor. // It can appear in the Error List after a compilation or after using 'Run Code Analysis', // but only if the option 'all' is set in the .csproj file. internal static class MakeTypeSealed { - public class TestA; // EC85: make type sealed - internal class TestB; // EC85: make type sealed + public class TestA; // GCI85: make type sealed + internal class TestB; // GCI85: make type sealed public static class Test0 { - public class Test01; // EC85: make type sealed - internal class Test02; // EC85: make type sealed - private class Test03; // EC85: make type sealed + public class Test01; // GCI85: make type sealed + internal class Test02; // GCI85: make type sealed + private class Test03; // GCI85: make type sealed } internal static class Test1 { - public class Test11; // EC85: make type sealed - internal class Test12; // EC85: make type sealed - private class Test13; // EC85: make type sealed + public class Test11; // GCI85: make type sealed + internal class Test12; // GCI85: make type sealed + private class Test13; // GCI85: make type sealed } public static class SealableClasses { - public class TestA; // EC85: make type sealed - internal class TestB; // EC85: make type sealed + public class TestA; // GCI85: make type sealed + internal class TestB; // GCI85: make type sealed public static class Test0 { - public class Test01; // EC85: make type sealed - internal class Test02; // EC85: make type sealed - private class Test03; // EC85: make type sealed + public class Test01; // GCI85: make type sealed + internal class Test02; // GCI85: make type sealed + private class Test03; // GCI85: make type sealed } internal static class Test1 { - public class Test11; // EC85: make type sealed - internal class Test12; // EC85: make type sealed - private class Test13; // EC85: make type sealed + public class Test11; // GCI85: make type sealed + internal class Test12; // GCI85: make type sealed + private class Test13; // GCI85: make type sealed } } public static class SealableRecords { - public record TestA; // EC85: make type sealed - internal record TestB; // EC85: make type sealed + public record TestA; // GCI85: make type sealed + internal record TestB; // GCI85: make type sealed public static class Test0 { - public record Test01; // EC85: make type sealed - internal record Test02; // EC85: make type sealed - private record Test03; // EC85: make type sealed + public record Test01; // GCI85: make type sealed + internal record Test02; // GCI85: make type sealed + private record Test03; // GCI85: make type sealed } internal static class Test1 { - public record Test11; // EC85: make type sealed - internal record Test12; // EC85: make type sealed - private record Test13; // EC85: make type sealed + public record Test11; // GCI85: make type sealed + internal record Test12; // GCI85: make type sealed + private record Test13; // GCI85: make type sealed } } @@ -130,48 +130,48 @@ private sealed class Test13; public static class SealableClassesWithInterface { public interface ITest { void Method(); } - public class TestA : ITest { public void Method() { } } // EC85: make type sealed - internal class TestB : ITest { public void Method() { } } // EC85: make type sealed + public class TestA : ITest { public void Method() { } } // GCI85: make type sealed + internal class TestB : ITest { public void Method() { } } // GCI85: make type sealed public static class Test0 { - public class Test01 : ITest { public void Method() { } } // EC85: make type sealed - internal class Test02 : ITest { public void Method() { } } // EC85: make type sealed - private class Test03 : ITest { public void Method() { } } // EC85: make type sealed + public class Test01 : ITest { public void Method() { } } // GCI85: make type sealed + internal class Test02 : ITest { public void Method() { } } // GCI85: make type sealed + private class Test03 : ITest { public void Method() { } } // GCI85: make type sealed } internal static class Test1 { - public class Test11 : ITest { public void Method() { } } // EC85: make type sealed - internal class Test12 : ITest { public void Method() { } } // EC85: make type sealed - private class Test13 : ITest { public void Method() { } } // EC85: make type sealed + public class Test11 : ITest { public void Method() { } } // GCI85: make type sealed + internal class Test12 : ITest { public void Method() { } } // GCI85: make type sealed + private class Test13 : ITest { public void Method() { } } // GCI85: make type sealed } } public static class SealableClassesWithOverridable { public class TestA1 { public virtual void Method() { } } - public class TestA2 { internal virtual void Method() { } } // EC85: make type sealed + public class TestA2 { internal virtual void Method() { } } // GCI85: make type sealed public class TestA3 { protected virtual void Method() { } } - public class TestA4 { protected internal virtual void Method() { } } // EC85: make type sealed - public class TestA5 { private protected virtual void Method() { } } // EC85: make type sealed + public class TestA4 { protected internal virtual void Method() { } } // GCI85: make type sealed + public class TestA5 { private protected virtual void Method() { } } // GCI85: make type sealed - internal class TestB1 { public virtual void Method() { } } // EC85: make type sealed - internal class TestB2 { internal virtual void Method() { } } // EC85: make type sealed - internal class TestB3 { protected virtual void Method() { } } // EC85: make type sealed - internal class TestB4 { protected internal virtual void Method() { } } // EC85: make type sealed - internal class TestB5 { private protected virtual void Method() { } } // EC85: make type sealed + internal class TestB1 { public virtual void Method() { } } // GCI85: make type sealed + internal class TestB2 { internal virtual void Method() { } } // GCI85: make type sealed + internal class TestB3 { protected virtual void Method() { } } // GCI85: make type sealed + internal class TestB4 { protected internal virtual void Method() { } } // GCI85: make type sealed + internal class TestB5 { private protected virtual void Method() { } } // GCI85: make type sealed public static class Test0 { public class TestA1 { public virtual void Method() { } } - public class TestA2 { internal virtual void Method() { } } // EC85: make type sealed + public class TestA2 { internal virtual void Method() { } } // GCI85: make type sealed public class TestA3 { protected virtual void Method() { } } - public class TestA4 { protected internal virtual void Method() { } } // EC85: make type sealed - public class TestA5 { private protected virtual void Method() { } } // EC85: make type sealed + public class TestA4 { protected internal virtual void Method() { } } // GCI85: make type sealed + public class TestA5 { private protected virtual void Method() { } } // GCI85: make type sealed - internal class TestB1 { public virtual void Method() { } } // EC85: make type sealed - internal class TestB2 { internal virtual void Method() { } } // EC85: make type sealed - internal class TestB3 { protected virtual void Method() { } } // EC85: make type sealed - internal class TestB4 { protected internal virtual void Method() { } } // EC85: make type sealed + internal class TestB1 { public virtual void Method() { } } // GCI85: make type sealed + internal class TestB2 { internal virtual void Method() { } } // GCI85: make type sealed + internal class TestB3 { protected virtual void Method() { } } // GCI85: make type sealed + internal class TestB4 { protected internal virtual void Method() { } } // GCI85: make type sealed internal class TestB5 { private protected virtual void Method() { } } // EC85: make type sealed private class TestC1 { public virtual void Method() { } } // EC85: make type sealed diff --git a/RuleTests/EcoCode/EC86.GCCollectShouldNotBeCalled.cs b/RuleTests/EcoCode/GCI86.GCCollectShouldNotBeCalled.cs similarity index 74% rename from RuleTests/EcoCode/EC86.GCCollectShouldNotBeCalled.cs rename to RuleTests/EcoCode/GCI86.GCCollectShouldNotBeCalled.cs index 1d79f26..a92b9e0 100644 --- a/RuleTests/EcoCode/EC86.GCCollectShouldNotBeCalled.cs +++ b/RuleTests/EcoCode/GCI86.GCCollectShouldNotBeCalled.cs @@ -6,24 +6,24 @@ public static void Run() { // GC.Collect(); - GC.Collect(); // EC86 + GC.Collect(); // GCI86 - GC.Collect(); // EC86 + GC.Collect(); // GCI86 GC.Collect(0); - GC.Collect(2); // EC86 + GC.Collect(2); // GCI86 GC.Collect(0, GCCollectionMode.Optimized); - GC.Collect(2, GCCollectionMode.Forced); // EC86 + GC.Collect(2, GCCollectionMode.Forced); // GCI86 GC.Collect(generation: 0, GCCollectionMode.Optimized); - GC.Collect(generation: 2, GCCollectionMode.Optimized); // EC86 + GC.Collect(generation: 2, GCCollectionMode.Optimized); // GCI86 GC.Collect(mode: GCCollectionMode.Optimized, generation: 0); - GC.Collect(mode: GCCollectionMode.Optimized, generation: 2); // EC86 + GC.Collect(mode: GCCollectionMode.Optimized, generation: 2); // GCI86 } } diff --git a/RuleTests/EcoCode/EC87.UseListIndexer.cs b/RuleTests/EcoCode/GCI87.UseListIndexer.cs similarity index 79% rename from RuleTests/EcoCode/EC87.UseListIndexer.cs rename to RuleTests/EcoCode/GCI87.UseListIndexer.cs index 401e127..3a7f096 100644 --- a/RuleTests/EcoCode/EC87.UseListIndexer.cs +++ b/RuleTests/EcoCode/GCI87.UseListIndexer.cs @@ -20,23 +20,23 @@ private sealed class MyCollection2 : List public static void Run() { - Console.WriteLine(Arr.First()); // EC87 + Console.WriteLine(Arr.First()); // GCI87 Console.WriteLine(Arr.First(x => x != 1)); - Console.WriteLine(Arr.Last()); // EC87 + Console.WriteLine(Arr.Last()); // GCI87 Console.WriteLine(Arr.Last(x => x != 1)); - Console.WriteLine(Arr.ElementAt(2)); // EC87 + Console.WriteLine(Arr.ElementAt(2)); // GCI87 - Console.WriteLine(List.First()); // EC87 + Console.WriteLine(List.First()); // GCI87 Console.WriteLine(List.First(x => x != 1)); - Console.WriteLine(List.Last()); // EC87 + Console.WriteLine(List.Last()); // GCI87 Console.WriteLine(List.Last(x => x != 1)); - Console.WriteLine(List.ElementAt(2)); // EC87 + Console.WriteLine(List.ElementAt(2)); // GCI87 - Console.WriteLine(Coll1.First()); // EC87 + Console.WriteLine(Coll1.First()); // GCI87 Console.WriteLine(Coll1.First(x => x != 1)); - Console.WriteLine(Coll1.Last()); // EC87 + Console.WriteLine(Coll1.Last()); // GCI87 Console.WriteLine(Coll1.Last(x => x != 1)); - Console.WriteLine(Coll1.ElementAt(2)); // EC87 + Console.WriteLine(Coll1.ElementAt(2)); // GCI87 Console.WriteLine(Coll2.First()); Console.WriteLine(Coll2.First(x => x != 1)); diff --git a/RuleTests/EcoCode/EC88.DisposeResourceAsynchronusly.cs b/RuleTests/EcoCode/GCI88.DisposeResourceAsynchronusly.cs similarity index 89% rename from RuleTests/EcoCode/EC88.DisposeResourceAsynchronusly.cs rename to RuleTests/EcoCode/GCI88.DisposeResourceAsynchronusly.cs index 0667c2f..e855407 100644 --- a/RuleTests/EcoCode/EC88.DisposeResourceAsynchronusly.cs +++ b/RuleTests/EcoCode/GCI88.DisposeResourceAsynchronusly.cs @@ -31,10 +31,10 @@ public static async Task RunAsync() Console.WriteLine(d12); // Warn on asyncable usings - using (var d21 = new AsyncDisposableClass()) // EC88 : Dispose resource asynchronously + using (var d21 = new AsyncDisposableClass()) // GCI88 : Dispose resource asynchronously Console.WriteLine(d21); - using var d22 = new AsyncDisposableClass(); // EC88 : Dispose resource asynchronously + using var d22 = new AsyncDisposableClass(); // GCI88 : Dispose resource asynchronously Console.WriteLine(d22); await Task.CompletedTask.ConfigureAwait(false); diff --git a/RuleTests/EcoCode/EC91.UseWhereBeforeOrderBy.cs b/RuleTests/EcoCode/GCI91.UseWhereBeforeOrderBy.cs similarity index 82% rename from RuleTests/EcoCode/EC91.UseWhereBeforeOrderBy.cs rename to RuleTests/EcoCode/GCI91.UseWhereBeforeOrderBy.cs index 0f08142..74dded3 100644 --- a/RuleTests/EcoCode/EC91.UseWhereBeforeOrderBy.cs +++ b/RuleTests/EcoCode/GCI91.UseWhereBeforeOrderBy.cs @@ -7,7 +7,7 @@ public static void Test1() var items = new List(); var query = items .OrderBy(x => x) - .Where(x => x > 10) // EC91 + .Where(x => x > 10) // GCI91 .Select(x => x); } @@ -16,7 +16,7 @@ public static void Test2() var items = new List(); var query = items .OrderByDescending(x => x) - .Where(x => x > 10) // EC91 + .Where(x => x > 10) // GCI91 .Select(x => x); } @@ -25,7 +25,7 @@ public static void Test3() var items = new List(); var query = from item in items orderby item - where item > 10 // EC91 + where item > 10 // GCI91 select item; } @@ -34,7 +34,7 @@ public static void Test4() var items = new List(); var query = from item in items orderby item descending - where item > 10 // EC91 + where item > 10 // GCI91 select item; } } diff --git a/RuleTests/EcoCode/EC92.UseLengthToTestEmptyStrings.cs b/RuleTests/EcoCode/GCI92.UseLengthToTestEmptyStrings.cs similarity index 86% rename from RuleTests/EcoCode/EC92.UseLengthToTestEmptyStrings.cs rename to RuleTests/EcoCode/GCI92.UseLengthToTestEmptyStrings.cs index 73e3826..b250853 100644 --- a/RuleTests/EcoCode/EC92.UseLengthToTestEmptyStrings.cs +++ b/RuleTests/EcoCode/GCI92.UseLengthToTestEmptyStrings.cs @@ -4,7 +4,7 @@ internal static class UseLengthToTestEmpyString { public static void Test(string s) { - if (s == "") // EC92 + if (s == "") // GCI92 { Console.WriteLine("Empty"); } diff --git a/RuleTests/EcoCode/EC93.ReturnTaskDirectly.cs b/RuleTests/EcoCode/GCI93.ReturnTaskDirectly.cs similarity index 94% rename from RuleTests/EcoCode/EC93.ReturnTaskDirectly.cs rename to RuleTests/EcoCode/GCI93.ReturnTaskDirectly.cs index a6a0e0d..0780efe 100644 --- a/RuleTests/EcoCode/EC93.ReturnTaskDirectly.cs +++ b/RuleTests/EcoCode/GCI93.ReturnTaskDirectly.cs @@ -24,18 +24,18 @@ public static async Task DontWarnWithMultipleStatements2Async() await Task.Delay(0).ConfigureAwait(false); } - public static async Task WarnOnSingleAwaitExpressionAsync() => // EC93 + public static async Task WarnOnSingleAwaitExpressionAsync() => // GCI93 // Comment await Task.Delay(0).ConfigureAwait(false); - public static async Task WarnOnSingleAwaitBody1Async() // EC93 + public static async Task WarnOnSingleAwaitBody1Async() // GCI93 { // Comment 0 await Task.Delay(0).ConfigureAwait(false); // Comment 1 // Comment 2 } - public static async Task WarnOnSingleAwaitBody2Async() // EC93 + public static async Task WarnOnSingleAwaitBody2Async() // GCI93 { // Comment 0 return await Task.FromResult(0).ConfigureAwait(false); // Comment 1