rspec/rules/S2275/csharp/rule.adoc
2020-12-23 14:59:06 +01:00

43 lines
1.7 KiB
Plaintext
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

Because composite format strings are interpreted at runtime, rather than validated by the compiler, they can contain errors that lead to unexpected behaviors or runtime errors. This rule statically validates the good behavior of composite formats when calling the methods of ``String.Format``, ``StringBuilder.AppendFormat``, ``Console.Write``, ``Console.WriteLine``, ``TextWriter.Write``, ``TextWriter.WriteLine``, ``Debug.WriteLine(String,Object[])``, ``Trace.TraceError(String,Object[])``, ``Trace.TraceInformation(String,Object[])``, ``Trace.TraceWarning(String,Object[])`` and ``TraceSource.TraceInformation(String,Object[])``.
== Noncompliant Code Example
----
s = string.Format("[0}", arg0);
s = string.Format("{{0}", arg0);
s = string.Format("{0}}", arg0);
s = string.Format("{-1}", arg0);
s = string.Format("{0} {1}", arg0);
----
== Compliant Solution
----
s = string.Format("{0}", 42); // Compliant
s = string.Format("{0,10}", 42); // Compliant
s = string.Format("{0,-10}", 42); // Compliant
s = string.Format("{0:0000}", 42); // Compliant
s = string.Format("{2}-{0}-{1}", 1, 2, 3); // Compliant
s = string.Format("no format"); // Compliant
----
== Exceptions
* No issue is raised if the format string is not a ``const``.
----
var pattern = "{0} {1} {2}";
var res = string.Format(pattern, 1, 2); // Compliant, not const string are not recognized
----
* No issue is raised if the argument is not an inline creation array.
----
var array = new int[] {};
var res = string.Format("{0} {1}", array); // Compliant we don't know the size of the array
----
* This rule doesn't check whether the format specifier (defined after the ``:``) is actually valid.
include::../see.adoc[]