metaclass: (Default)
metaclass ([personal profile] metaclass) wrote2009-11-14 11:24 pm

На тему споров про хаскель и отладки программ

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

То есть, например, если я использую какую-то библиотеку - должно быть пофиг, как там она делает внутри себя, это должно быть черным ящиком, в том числе и в стеке вызовов. И если нужно отлаживать библиотеку - это нужно делать отдельно, когда кроме нее в стеке вызовов сверху только Main() сидит. А если мы отлаживаем конечную программу - то вызов библиотеки будет сидеть внизу стека, одной строкой.

[identity profile] metaclass.livejournal.com 2009-11-16 08:33 pm (UTC)(link)
Да по идее, через unsafePerformIO в лог писать в нужных местах.
Хотя я бы это дело на уровень компилятора засунул, в виде функции, эквивалентной id, но с записью в какой-нибудь внутренний лог, со стеком/графом вызовов.