|
|
Регистрация | << Правила форума >> | FAQ | Пользователи | Календарь | Поиск | Сообщения за сегодня | Все разделы прочитаны |
|
Опции темы | Поиск в этой теме | Опции просмотра |
#1
|
||||
|
||||
muParser 2.2.3, обёртка для Delphi
Итак, имеется подопытный парсер математических выражений. Хочу его приделать к Delphi. В Builder'е это у меня получилось, но ценой подключения родных исходников (подключение через lib не осилил).
Взять можно тут: Fast Mathematical Expressions Parser В приложенном архиве находится dll парсера следующей внутренней версии: Version 2.2.3 (20121222; SF; 32BIT; RELEASE; ASCII) (DLL) Я начал с нуля создавать обёртку для работы с dll. В принципе, простые вещи работают, т.е. можно задать выражение и его посчитать, но вот в комплексе, если я хочу задать несколько констант или переменных или делаю в ряд несколько операций, вызывая функции из библиотеки, вылетают ошибки и ничего не работает. Начну с простого вопроса. В архиве я всё закомментил, чтобы работало и было видно, что результат выражения считается. При запуске создаётся также лог файл muParserTest.log, в котором можно посмотреть сопутствующую информацию. Так вот, когда я включаю функцию Intro(), то почему-то после её выполнения теряется handle парсера, т.е. переменная hParser изменяет своё значение. Отладка в RS2007 выявила изменение регистра EBX, в котором сохраняется эта переменная. В коде подразумевается, что этот регистр не меняется внутри функции, но по факту он изменяется, что приводит к ошибке при вызове остальных функций. muParserDLL.h - это сишная обёртка, которая идёт в комплекте. Я с неё списывал, как нетрудно будет заметить. В общем, нужен спец, который шарит в теме на уровне соглашений вызова и работы с сишными библиотеками. Кое-что у меня работает, а кое-что нет. Вызов некоторых паскалевских функций из библиотеки работает, а вот обработку ошибок я не смог реализовать, функция не вызывается. Надо подправить мой черновой набросок и осчастливить народ хорошим парсером. Этот парсер действительно быстрый. После первого вычисления он переводит выражение во внутренний код и при последующих вычислениях работает уже с ним, что значительно ускоряет интерпретацию. Россия навсегда! |
#2
|
|||
|
|||
А откуда взялся stdcall ? В .h - файле везде стоит cdecl.
|
Этот пользователь сказал Спасибо icWasya за это полезное сообщение: | ||
uni (13.02.2013)
|
#3
|
||||
|
||||
Да, действительно, я не обратил внимание на определение API_EXPORT. Странно, что у меня вообще что-то работает, ведь я мог нарушить баланс стека. Уже точно не помню в какой части там отличие.
stdcall я по привычке использовал, от WinAPI осталось. Попробую изменить соглашение вызова и посмотреть что получится. П.С. Да, ошибка была в этом. Надо же, в таком простом месте ошибся. Достаточно заменить все stdcall на cdecl и у вас почти готовый интерфейс к библиотеке muParser 2.2.3. Глаз замылился у меня. Одну функцию попробовал - заработала, но на побочный эффект не обратил внимания, потом все описал по аналогии. Даже функция обратного вызова для обработки ошибок заработала. Россия навсегда! Последний раз редактировалось uni, 13.02.2013 в 23:55. |