rspec/rules/S1118/csharp/rule.adoc

45 lines
918 B
Plaintext
Raw Normal View History

Utility classes, which are collections of ``++static++`` members, are not meant to be instantiated.
2020-06-30 12:47:33 +02:00
2021-02-02 15:02:10 +01:00
C# adds an implicit public constructor to every class which does not explicitly define at least one constructor. Hence, at least one ``++protected++`` constructor should be defined if you wish to subclass this utility class. Or the ``++static++`` keyword should be added to the class declaration to prevent subclassing.
2020-06-30 12:47:33 +02:00
== Noncompliant Code Example
----
public class StringUtils // Noncompliant
{
public static string Concatenate(string s1, string s2)
{
return s1 + s2;
}
}
----
== Compliant Solution
----
public static class StringUtils
{
public static string Concatenate(string s1, string s2)
{
return s1 + s2;
}
}
----
or
2021-02-02 15:02:10 +01:00
2020-06-30 12:47:33 +02:00
----
public class StringUtils
{
protected StringUtils()
{
}
public static string Concatenate(string s1, string s2)
{
return s1 + s2;
}
}
----