Что меня особенно интересует, так это возможность определять грамматику в коде как обычный код без каких-либо ненужных усилий.
Я знаю, что могу использовать IronPython. Я не хочу.
UPDATE:
Для дальнейшего объяснения того, что я ищу, я включил пример кода для разбора. Это неполный парсер для преобразования сочетаний клавиш emacs в более обычные обозначения. Этот пример, конечно, достаточно мал, чтобы хватило строковых функций, но он просто показывает чистоту и краткость синтаксического анализа.
from pyparsing import Literal, OneOrMore, Optional, Word, printables, replaceWith
CTRL_MODIFIER = Literal('C').setParseAction(replaceWith('Ctrl'))
META_MODIFIER = Literal('M').setParseAction(replaceWith('Alt'))
MODIFIER = CTRL_MODIFIER | META_MODIFIER # Note operator overloading
SEPARATOR = Literal('-').setParseAction(replaceWith('+'))
MODIFIER_LIST = OneOrMore(MODIFIER + SEPARATOR)
KEY = Word(printables) # This is a "word" composed of any number of printable characters.
# The lambda functions here just join the tokens with the literal string
# on which .join is called.
STROKE = (Optional(MODIFIER_LIST) + KEY).setParseAction(
lambda tokens: ' '.join([str(token) for token in tokens]))
BINDING = OneOrMore(STROKE).setParseAction(
lambda tokens: ', '.join([str(token) for token in tokens]))
# Example usage:
# >>> BINDING.transformString('M-/')
# Alt + /
# >>> BINDING.transformString('C-x C-f')
# Ctrl + x, Ctrl + f
# >>> BINDING.transformString('C-x f')
# Ctrl + x, f
# >>> BINDING.transformString('C-x M-c M-butterfly')
# Ctrl + x, Alt + c, Alt + butterfly
Я бы хотел написать грамматику в .NET с такой легкостью, за несколько строк.