Question

string.Format has following method signature

string.Format(format, params, .., .. , ..);

I want to pass custom format each time like

string custFormat = "Hi {0} ... {n} ";   // I only care about numbers here, and want avoid  {abdb}
string name = "Foo";

string message = ProcessMessage(custFormat, name);

public string ProcessMessage(custFormat, name)
{
   return string.Format(custFormat, name);
}

I want to validate the value in custFormat before passing to ProcessMessage to avoid exception.

Was it helpful?

Solution

Let's think about this API, if it exists. The goal is to pre-validate a format string, to make sure String.Format won't throw.

Note that any string which doesn't contain a valid format slot is a valid format string - if you don't try to insert any replacements.

-> So we would need to pass in the number or args we expect to replace

Note that there are tons of different specialty formatting patterns, each with a specific meaning for specific types: http://msdn.microsoft.com/en-us/library/system.string.format.aspx

Although it seems that String.Format won't throw if you pass a format string which doesn't match your argument type, the formatter becomes meaningless in such cases. e.g. String.Format("{0:0000}", "foo")

-> So such an API would be truly useful only if you passed the types of the args, as well.

If we already need to pass in our format string and an array of types (at least), then we are basically at the signature of String.Format, so why not just use that and handle the exception? It would be nice if something like String.TryFormat existed, but to my knowledge it doesn't.

Also, pre-validating via some API, then re-validating in String.Format itself is not ideal perf-wise.

I think the cleanest solution might be to define a wrapper:

public static bool TryFormat(string format, out string result, params Object[] args)
{
   try
   {
      result = String.Format(format, args);
      return true;
   }
   catch(FormatException)
   {
      return false;
   }
}

OTHER TIPS

As long as you're only passing in 1 argument, you can look search custFormat for {0}. If you don't find it, it's invalid.

You can validate with try catch, if format throw exceptin you log information and stop treatment.

try 
{ 
   string.Format(custFormat, params, .., .. , ..);
}
catch(FormatException ex)  
{ 
  throw ex;
}

string message = ProcessMessage(custFormat, name);

You should use regular expressions for syntax checking and you may use some semantic checking as well.

Regular expression should be: (*{\d+}*)+

Licensed under: CC-BY-SA with attribution
Not affiliated with StackOverflow
scroll top