Я пытаюсь реализовать функцию, которая возвращает рекурсивное закрытие. Хотя я не уверен, как выразить это в сигнатуре функции. Вот пример кода рабочей реализации в Python
def counter(state):
def handler(msg):
if msg == 'inc':
print state
return counter(state + 1)
if msg == 'dec':
print state
return counter(state - 1)
return handler
c = counter(1)
for x in range(1000000):
c = c('inc')
и псевдокод для Rust.
enum Msg {
Inc,
Dec
}
fn counter(state: Int) -> ? {
move |msg| match msg {
Msg::Inc => counter(state + 1),
Msg::Dec => counter(state - 1),
}
}