I am creating some dynamic linq and am having problems with the following exception:
The binary operator GreaterThanOrEqual
is not defined for the types
‘System.Nullable`1[System.DateTime]’
and ‘System.DateTime’
I get why, because my field type is nullable and Im passing in DateTime.Now essentially.
So in trying to resolve this issue I’ve tried
System.Nullable<DateTime> now;
now = DateTime.Now;
But the resulting type is a non-nullable object and hence still giving me the above exception.
Any suggestions?!
Update: For more clarification the now variable becomes a non-nullable type when it is set rather than staying as a nullable DateTime so the match throws an exception
Update: The actual code can be seen in the CodePlex project:
http://webquarters.codeplex.com/SourceControl/changeset/view/36529#574700
The offending line is ~145
fExp = Expression.GreaterThanOrEqual(fExpLeft, fExpRight);
The problem here is that the expression library is throwing an exception when given two arguments of mismatched nullability. Here’s a simple repro:
It is not clear to me whether this is a bug or not; the rules of C# require that in this scenario, the non-nullable operand is converted to nullable, and the lifted-to-nullable form of the comparison is used. However, the expression tree library is not required to follow the rules of C# because of course the expression tree library can be used to represent C# expressions, Python expressions, JScript expressions, VB expressions and so on; it cannot possibly follow all the rules of every possible language.
But regardless, this looks like it might be a bug, so I’ll submit it to the expression tree team and see what they say. In the meanwhile, you can easily work around it by defining your own helper method that fixes the operands up. A quick sketch would be:
However, notice that this does not check that e1 and e2’s type differ only in nullability; if you pass in a nullable int and a non-nullable double expression, bad things happen. I leave it as an exercise to implement the better logic that checks whether the two expressions are of type that only differs by nullability.