metaclass: (Default)
metaclass ([personal profile] metaclass) wrote2009-04-10 09:50 pm

Белорусский налоговый учет

и бухгалтерия выкушают мой моск.

Кто-нибудь знает:
1) Что и в каком порядке изучать, чтобы написать интерпретатор Хаскеля?
2) Где взять готовый встраиваемый интерпретатор?

:)

[identity profile] thesz.livejournal.com 2009-04-10 07:11 pm (UTC)(link)
1) Хаскельный код вызывается через FFI.
2) http://haskell.org/haskellwiki/Ghc_as_a_library

Вот. ;)

[identity profile] metaclass.livejournal.com 2009-04-10 07:29 pm (UTC)(link)
Ужосъ :)
На самом деле, я как раз хочу избежать FFI и реализовать взаимодействие с БД и еще кой-какими внутренностями внешней программы так, как будто это родной модуль хаскеля, в крайнем случае, завернув его в монаду, аналогичную IO.

Тут в натуре министерство по налогам и сборам вместе с бухгалтерами сошло с ума и требует ведомости, для которых есть три варианта реализации:
1) написать вручную алгоритм, который будет грузить первичные данные из БД, их обрабатывать совершенно необъяснимым образом и потом вручную собирать выходную печатную форму. тысячи строк несамоочевидного кода
2) факторизовать код на выполняемый частично в SQL, частично в обычном языке, частично в скриптах печатной формы. Это сейчас оно реализовано так. Объяснить нормальному человеку, как ЭТО работает, будет очень сложно.
3) Прикрутить к этому Haskell-based DSL, который бы все, от загрузки из БД до генерации печатной формы делал сам. Очень сложно сначала, зато было бы гораздо проще потом и на веки вечные.

[identity profile] mibori.livejournal.com 2009-04-10 07:58 pm (UTC)(link)
FFI -- нормальная практика. Загляните в исходники стандартных win32-библиотек поставляемых с GHC.

[identity profile] thesz.livejournal.com 2009-04-10 07:58 pm (UTC)(link)
Так Хаскельные DLL можно делать.

Ты опиши поточней, что тебе надо, попробуем.

[identity profile] metaclass.livejournal.com 2009-04-10 08:17 pm (UTC)(link)
Тут именно проблема класса: "алгоритм на хаскеле - 10 строк, загрузка данных из БД через FFI или там HDBC - 1000 строк". Если делать вручную описание структур данных и загрузку их из БД, смысл хаскеля очень сильно теряется, в то время, как моя шиза мне подсказывает, что автоматический вывод структур данных исходя из структуры БД сразу решит множество проблем.

Вкратце, идея такая: неким образом при компиляции подгружается схема БД(и, возможно, предопределенный набор запросов к ней) и из нее генерируется модуль, экспортирующий содержимое этой БД в совместимом с хаскелем виде. Т.е. таблица представляется в виде списка, а поскольку списки у нас ленивые - мы получаем обычную итерационную обработку таблицы. Запросы представляются в виде функций от параметров запроса тоже к спискам.
Сейчас из похожего я видел только HaskellDB, который для работы генерирует такой модуль своей какой-то утилитой, и вроде работает только через ODBC.

Затем мы это дело обрабатываем как нам в голову взбредет, обычным хаскелевым кодом, получаем некие выходные данные.

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

Такое реализовать, насколько я себе представляю, достаточно сложно, поэтому я уже давно над этим думаю, но к реализации приступить не хватает мозга и времени.

[identity profile] tonal.myopenid.com (from livejournal.com) 2009-04-12 10:55 am (UTC)(link)
HaskellDB вроде может работать поверх HDBC.
Хотя мне кажется, было бы круто иметь EDSL с синтаксисом SQL поверх HDBC.
Т.е. пишешь обычный SQL запрос, который возвращает ленивый список кртежей...

[identity profile] metaclass.livejournal.com 2009-04-12 05:04 pm (UTC)(link)
Вот вроде HaskellDB так и работает. У него утилита генерит файл, оборачивающий базу данных в модуль, и затем поверх этого выполняются SQL-подобные запросы.

[identity profile] tonal.myopenid.com (from livejournal.com) 2009-04-13 02:50 pm (UTC)(link)
Всегда хочется лучшего. :)
HaskellDB так же как и SQL основан на реляционной алгебре, но таки не sql.
Поэтому, какими-нибудь расширениями SQL для конкретного сервера не воспользуешься, а в случае SQL-EDSL всегда можно сделать бакенд максимально близким к конкретному диалекту.

Ну и планка входа в случае SQL-я существенно ниже - документации горы, в отличии от...