Andy Melnikov (nponeccop) wrote,
Andy Melnikov
nponeccop

Системы типов без функций высших порядков

Меня давно не покидает мысль, что ТруЪ-язык должен быть без ФВП. Что-то вроде

data Type = DataType Data | FunctionType Data Data

Это запрещает, помимо map (для которого нужен FunctionType перед стрелкой), также и каррирование (которому нужен FunctionType после стрелки).

В связи с этим вопрос залу: известны ли вам такие системы типов?

Зарестриктить Хиндли-Милнера так можно, и если добавить в этот обрезанный ХМ-язык присваивание и цикл (что тоже можно с т.з. системы типов) - то будет вполне себе полноценный императивный язычок.

При этом красоты можно будет переместить на уровень метапрограммирования и метаязык может быть нетипизированным без риска рантайм-ошибок.

Можно и if добавить, чтобы покрасивше было, но в первом приближении if можно метагенерировать из while и присваивания.
Tags: fp
Subscribe

  • Post a new comment

    Error

    default userpic

    Your reply will be screened

    Your IP address will be recorded 

    When you submit the form an invisible reCAPTCHA check will be performed.
    You must follow the Privacy Policy and Google Terms of use.
  • 34 comments