-- все стандартные подпрограммы .dll в системе WIN32 API.
-- Чтобы задать правила cdecl, мы бы использовали "+LoadIconA".
if LoadIcon = -1 then
puts(1, "LoadIconA не найдена!\n")
end if
См. также:
euphoria\demo\callmach.ex, c_func, define_c_proc, c_proc, open_dll, platform_r.htm
define_c_proc
Синтаксис:
include dll.e
i1 = define_c_proc(x1, x2, s1)
Описание:
Выдаёт номер(идентификатор) подпрограммы для заданной Си-функции или же подпрограммы машинного кода, которые подлежат вызову в качестве процедур Euphoria. Аргументами служат характеристики заданной функции (подпрограммы). Выданный номерi1 используется далее в качестве первого аргумента при вызове подпрограммы c_proc(), которая и запускает заданную внешнюю подпрограмму на исполнение из Euphoria как процедуру.
Когда вы задаёте характеристики Си-функции, аргумент x1 должен представлять собой адрес системной библиотеки, содержащей эту Си-функцию. Адрес библиотеки вы должны получить, заранее вызвав функцию open_dll(). Аргумент x2 задаёт имя Си-функции, которая вас интересует. Если define_c_proc() не находит заданную Си-функцию, в качестве номера она выдаёт -1. На платформе Windows вы можете перед именем функции добавить символ '+'. Он показывает Euphoria, что для вызова Си-функции предусмотрены правила соглашения cdecl. По умолчанию Euphoria считает, что подпрограммы Си вызываются по правилам соглашения stdcall.
Когда вы задаёте характеристики подпрограммы машинного кода, аргумент x1 должен быть пустым рядом, "" или {}, а x2 - содержать адрес подпрограммы машинного кода. Байты машинного кода должны быть заранее размещены в участке памяти, выделенном функцией allocate(), которая и выдаёт адрес, используемый далее для размещения подпрограммы машинного кода и задания её характеристик. На платформе Windows подпрограммы машинного кода обычно следуют правилам соглашения stdcall, но если вам вместо этого необходимо использование правил cdecl, вы можете записать x2 как ряд {'+', адрес}вместо подачи значения адресакак атома.
Аргумент s1 представляет собой список типов аргументов функции (подпрограммы). Полный список типов Си, содержащий их определения, находится в библиотеке dll.eи показан выше. Эти же типы могут быть использованы при назначении типов аргументов для подпрограммы машинного кода.
Си-функция, характеристики которой вы задаёте с использованием define_c_proc(), может быть создана с помощью транслятора с Euphoria на Си. В этом случае вы сможете подавать в неё данные типов Euphoria. Полный список типов Euphoria с их определениями находится в библиотеке dll.eи показан выше.
Комментарии:
Аргументы Си-функций могут быть любого целочисленного типа Си и типа указателя (пойнтера) Си. Если аргументы Си-функции имеют тип двойной точности или с плавающей точкой, то в их качестве могут использоваться атомы Euphoria.
Аргументы с типами, для представления которых достаточно 4-х или меньше байтов, все подаются одним и тем же порядком, поэтому нет необходимости быть слишком пунктуальным, выбирая тот или иной тип для обозначения 4-х байтового аргумента.
В настоящее время не существует метода подачи в Си-функцию структуры Си по величине. Вы можете подать как аргумент лишь указатель на структуру
Заданная вами Си-функция может выдавать величину, но эта величина будет игнорироваться. Если вы заинтересованы в получении и использовании величины, выдаваемой Си-функцией, вам следует обратиться к паре подпрограмм define_c_func() и c_func().
Пример:
atom user32
integer ShowWindow
-- Открываем системную библиотеку user32.dll - в ней находится Си-функция ShowWindow.
user32 = open_dll("user32.dll")
-- Си-функция требует 2-х аргументов, оба типа C int.
ShowWindow = define_c_proc(user32, "ShowWindow", {C_INT, C_INT})
-- Если бы ShowWindow работала по правилам cdecl,
-- мы записали бы здесь "+ShowWindow"
if ShowWindow = -1 then
puts(1, "ShowWindow не найдена!\n")
end if
См. также:
c_proc, define_c_func, c_func, open_dll, platform_r.htm
define_c_var
Платформа:
WIN32, Linux, FreeBS D
Синтаксис:
include dll.e
a1 = define_c_var(a2, s)
Описание:
Выдаёт адрес переменной Си, загруженной в память. Аргумент a2 является адресом общей библиотеки .so Linux, FreeBSD или .dll Windows, выданным функцией open_dll(). Ряд s задает имя глобальной переменной Си, определенной внутри системной библиотеки. В переменной a1 будет содержаться значение адреса переменной s в памяти.
Комментарии:
Как только вы получили адрес переменной Си, и если вы знаете её тип, вы можете далее использовать подпрограммы peek() и poke(), чтобы считывать или записывать в памяти величину этой переменной.
Читать дальше