Я ищу способ синтаксического анализа условного выражения в строку.
Лучший пример, который я могу придумать, это LINQ-to-SQL. Он использует ExpressionVisitors для форматирования предложений «Где». Пример:
from a in b where a.x == 5 && a.y < 3 select a
Это будет переводиться в следующую строку (примерно, MSSQL для меня не актуален):
"SELECT * FROM b WHERE x = 5 AND y < 3"
Из того, что я читал, это было сделано с помощью класса ExpressionVisitor, как описано в этой статье: http://blogs.msdn.com/b/mattwar/archive/2007/07/31/linq-build-an-queryable-provider-part-ii.aspx
Теперь проблема в том, что я не использую LINQ, но мне нужен именно этот функционал. Есть ли способ разобрать такое состояние? Я готов делать что угодно с отражением, делегатами, лямбдой и т.д.
Честно говоря, я не думаю, что это возможно, но мои мозги немного поджарены (читай: будьте любезны, если вопрос смешной), так что я решил, что с тем же успехом мог бы попробовать S/O .
EDIT: окончательный пример использования:
// Usage:
foo.Bar(foo => foo.X == 5 && foo.Y < 3)
// Ideal string output (variable name (foo) is not needed):
"foo.X == 5 && foo.Y < 3"
РЕДАКТИРОВАТЬ 2: Да, число может быть меньше 3 и равно 5. Говорил же вам, что мой мозг поджарился.