Mit einem Methodenaufruf ist es einfach, von einem Lambda zu einem Ausdruck zu wechseln ...
public void GimmeExpression(Expression<Func<T>> expression)
{
((MemberExpression)expression.Body).Member.Name; // "DoStuff"
}
public void SomewhereElse()
{
GimmeExpression(() => thing.DoStuff());
}
Aber ich möchte den Func nur in seltenen Fällen in einen Ausdruck verwandeln ...
public void ContainTheDanger(Func<T> dangerousCall)
{
try
{
dangerousCall();
}
catch (Exception e)
{
// This next line does not work...
Expression<Func<T>> DangerousExpression = dangerousCall;
var nameOfDanger =
((MemberExpression)dangerousCall.Body).Member.Name;
throw new DangerContainer(
"Danger manifested while " + nameOfDanger, e);
}
}
public void SomewhereElse()
{
ContainTheDanger(() => thing.CrossTheStreams());
}
Die Zeile, die nicht funktioniert, gibt mir den Fehler beim Kompilieren Cannot implicitly convert type 'System.Func<T>' to 'System.Linq.Expressions.Expression<System.Func<T>>'
. Eine explizite Besetzung löst die Situation nicht. Gibt es eine Möglichkeit, dies zu tun, die ich übersehen habe?
at lambda_method(Closure )
für den Aufruf des kompilierten Delegaten anzeigt.