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[]).
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);
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
const.
var pattern = "{0} {1} {2}";
var res = string.Format(pattern, 1, 2); // Compliant, not const string are not recognized
var array = new int[] {};
var res = string.Format("{0} {1}", array); // Compliant we don't know the size of the array
:) is actually valid.