Директивы компилятора: различия между версиями
MZ (обсуждение | вклад) |
MZ (обсуждение | вклад) |
||
Строка 24: | Строка 24: | ||
== Пример программы с использованием директив компилятора == | == Пример программы с использованием директив компилятора == | ||
begin | |||
{$apptype console} | {$apptype console} | ||
{$reference library.dll} | {$reference library.dll} | ||
Строка 38: | Строка 38: | ||
{$include test.pas} | {$include test.pas} | ||
end. | |||
end. | end. |
Версия от 21:21, 20 мая 2009
Основные директивы, обрабатываемые препроцессором
{$include <имя файла>} - Включение в текст программы содержимого указанного файла.
{$define <идентификатор>} - Определение имени, используемого в директивах $ifdef, $ifndef.
{$undef <идентификатор>} - Исключение имени, используется для отмены действия директивы $define.
{$ifdef <name>} - Начало блока условной компиляции (проверяется условие: "идентификатор определен").
{$ifndef <name>} - Начало блока условной компиляции (проверяется условие: "идентификатор не определен").
{$else} - Директива "иначе" в блоке условной компиляции.
{$endif} - Завершение блока условной компиляции.
Директивы $ifdef, $ifndef совместно с директивами $else и $endif управлют условной компиляцией частей исходного файла. Каждой директиве $ifdef, $ifndef должна соответствовать завершающая ее директива $endif. Между директивами $ifdef, $ifndef и $endif допускается произвольное количество блоков условной компиляции (в том числе вложенных) и не более одной директивы $else.
{$apptype <тип приложения>} - Задание типа приложения.
{$reference <имя библиотеки>} - Подключение библиотеки.
Пример программы с использованием директив компилятора
begin {$apptype console} {$reference library.dll} {$define DEBUG} begin
{$ifdef DEBUG} {$ifndef DEBUG} write('Имя DEBUG не определено'); {$else} writeln('Имя DEBUG определено'); {$endif} {$endif} {$include test.pas}
end. end.