Когда вы задаёте характеристики подпрограммы машинного кода, аргумент 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, FreeBSD
Синтаксис:
include dll.e
a1 = define_c_var(a2, s)
Описание:
Выдаёт адрес переменной Си, загруженной в память. Аргумент a2 является адресом общей библиотеки .so Linux, FreeBSD или .dll Windows, выданным функцией open_dll(). Ряд s задает имя глобальной переменной Си, определенной внутри системной библиотеки. В переменной a1 будет содержаться значение адреса переменной s в памяти.
Комментарии:
Как только вы получили адрес переменной Си, и если вы знаете её тип, вы можете далее использовать подпрограммы peek() и poke(), чтобы считывать или записывать в памяти величину этой переменной.
Пример программы:
euphoria/demo/linux/mylib.exu
См. также:
c_proc, define_c_func, c_func, open_dll, platform_r.htm
dir
Синтаксис:
include file.e
x = dir(st)
Описание:
Выдаёт информацию о каталоге или о файле с именем st. Если такой каталог или файл не существует, выдаёт -1. Под Windows и DOS st может содержать символы догадок * и ?, что позволяет получать данные о нескольких файлах с похожими именами.
Выдаваемая информация похожа на ту, которую вы получаете по команде DIR под DOS. Ряд, формируемый функцией, содержит вложенные ряды (записи), каждый из которых описывает один файл или подкаталог.
Если в st задано имя каталога (директории, папки, фолдера), вы можете получить записи для "." и "..", точно так же, как и по команде DIR под DOS. Если же в st задано имя файла, тогда x будет иметь только одну запись, т.е. length(x) будет равна 1. Если в st содержатся символы догадок (шаблоны), вы можете получить многочисленные записи.
Каждая запись содержит имя, атрибуты файла и его размер, а также год, месяц, день, час, минуту и секунду последнего изменения. Вы можете обращаться к элементам записи с помощью следующих констант, определенных в библиотеке file.e:
global constant D_NAME = 1, -- имя
D_ATTRIBUTES = 2, -- атрибуты
D_SIZE = 3, -- размер
D_YEAR = 4, -- год
D_MONTH = 5, -- месяц
D_DAY = 6, -- день
D_HOUR = 7, -- час
D_MINUTE = 8, -- минута
D_SECOND = 9 -- секунда
Элемент атрибутов является строковым рядом, содержащим символы, выбранные из следующего перечня:
'd' -- каталог
'r' -- файл только для чтения
'h' -- скрытый файл
's' -- системный файл
'v' -- метка тома
'a' -- файл, подлежащий архивированию
Для обычного файла, без специальных атрибутов, в этом поле будет выдана пустая строка, "".
Комментарии:
Каталог высшего уровня, корневой, т.е. c:\, не содержит записей "." или "..".
Данная функция часто используется просто для проверки, существует ли заданный файл или каталог.
На платформе WIN32 в st могут содержаться длинные имена файлов или каталогов в любом месте полного пути.
На платформах Linux/FreeBSD в настоящее время доступен только атрибут 'd'.
DOS32: Имя файла, выдаваемое в элементе D_NAME, будет стандартным DOS-именем формата 8.3 (посетите Web-страницу Архива файлов, если вас интересует лучшее решение).
WIN32: Имя файла, выдаваемое в элементе D_NAME, будет длинным именем.
Пример:
d = dir(current_dir())
-- ряд d мог бы быть, например, равным:
{
{".", "d", 0 1994, 1, 18, 9, 30, 02},
{"..", "d", 0 1994, 1, 18, 9, 20, 14},
{"fred", "ra", 2350, 1994, 1, 22, 17, 22, 40},
{"sub", "d", 0, 1993, 9, 20, 8, 50, 12}
}
-- тогда d[3][D_NAME] было бы "fred"
Пример программы:
bin\search.ex
См. также:
wildcard_file, current_dir, open
display_image
Платформа:
DOS32
Синтаксис:
include image.e
display_image(s1, s2)
Описание:
Выводит в точке s1 на пиксельном экране 2-мерный ряд пикселов, описание которых содержится в s2. Аргумент s1 - двухэлементный ряд вида {x, y}. Аргумент s2 содержит ряды, каждый из которых представляет горизонтальную строчку значений цветов пикселов, которые необходимо включить на экране. Первый пиксел первого ряда расположен в точке s1. Это верхний левый пиксел. Все остальные пикселы расположены правее или ниже этого первого.