Inspired by Phil Haack's attempt on null or empty coalescing, I'm trying to write a couple of extension methods for the string
object, as well as on the IEnumerable<T>
interface, to simplify null or emtpy ckecking. However, I'm running into problems: when I'm attempting to call the string
version of AsNullIsEmpty
, the compiler treats my string as an IEnumerable<char>
, and of course gives the wrong return type.
Is there any way to put an "anti-constraint" on the definition of the IEnumerable
version, so that I can tell the compiler to use that one whenever the type of T
is not string
? Something like
public static IEnumerable<T> AsNullIfEmpty(this IEnumerable<T> items)
where T !: string
I know that I could just change the name of one of them, but I want to have the same name for consistency.
Update: It turns out my problem with the extension methods was solved another way, by fixing a simple and stupid error (I was using str.IsNullOrEmpty()
, the extension method on IEnumerable<T>
, instead of string.IsNullOrEmpty(str)
...) but since the question of anti-constraints on generics is still an interesting one, I won't delete it.