-D
)Замените макросы в предварительно обработанном коде
Замените макросы на их определения в предварительно обработанном коде.
Пользовательский интерфейс (только десктопные решения): В вашей настройке проекта опция находится на узле Macros.
Командная строка и файл опций: Используйте опцию -D
. Смотрите информацию о командной строке.
Используйте эту опцию, чтобы эмулировать ваше поведение компилятора. Например, если ваш компилятор рассматривает макро-_WIN32
как задано, когда вы создаете свой код, он выполняет код в #ifdef _WIN32
оператор. Если Polyspace® не полагает, что макрос, как задано, необходимо использовать эту опцию, чтобы заменить макрос на 1.
В зависимости от ваших настроек для Compiler (-compiler)
, некоторые макросы заданы по умолчанию. Используйте эту опцию, чтобы задать макросы, которые неявно не заданы.
Как правило, вы распознаете от ошибок компиляции, что определенный макрос не задан. Например, следующий код не компилирует если макро-_WIN32
не задан.
#ifdef _WIN32 int env_var; #endif void set() { env_var=1; }
env_var
isundefined. Однако определение env_var
находится в #ifdef _WIN32
оператор. Первопричина для ошибки состоит в том что макро-_WIN32
не задан. Необходимо задать _WIN32
.Никакое значение по умолчанию
Используя кнопку, добавьте строку для макроса, который вы хотите задать. Определение должно быть в формате
. Если вы хотите, чтобы Polyspace проигнорировал макрос, оставил Macro
=Value
пробел.Value
Например:
name1=name2
замены все экземпляры name1
name2
.
name=
дает программному обеспечению команду игнорировать name
.
name
без равняется знаку, или значение заменяет все экземпляры name
1. Задавать макрос, чтобы выполнить код в #ifdef
оператор, используйте этот синтаксис.macro_name
Если Polyspace не поддерживает не-ANSI® ключевое слово и показывает ошибку компиляции, используйте эту опцию, чтобы заменить все случаи ключевого слова с пустой строкой в предварительно обработанном коде. Замена происходит только в целях анализа. Ваш код первоисточника остается неповрежденным.
Например, если ваш компилятор поддерживает __far
ключевое слово, чтобы избежать ошибок компиляции:
В пользовательском интерфейсе (только десктопные решения), введите __far=
.
На командной строке используйте флаг -D __far=
.
Программное обеспечение заменяет __far
ключевое слово с пустой строкой во время предварительной обработки. Например:
int __far* pValue;
int * pValue;
Polyspace распознает ключевые слова, такие как restrict
и не позволяет их использование в качестве идентификаторов. Если вы используете те ключевые слова в качестве идентификаторов (потому что ваш компилятор не распознает их ключевыми словами), замените запрещенное имя на другое имя с помощью этой опции. Замена происходит только в целях анализа. Ваш код первоисточника остается неповрежденным.
Например, чтобы позволить использование restrict
как идентификатор:
В пользовательском интерфейсе введите restrict=my_restrict
.
На командной строке используйте флаг -D restrict=my_restrict
.
Ваша спецификация компилятора определяет значения многих специфичные для компилятора макросы. В случае, если вы хотите знать, как Polyspace задает определенный макрос, используйте опцию -dump-preprocessing-info
.
Чтобы заменить макроопределение, прибывающее из спецификации компилятора, используйте эту опцию.
Чтобы не задать макрос, используйте опцию Disabled preprocessor definitions (-U)
.
Можно задать только один флаг с каждым -D
опция. Однако можно задать опцию многократно.
Параметр: -D |
Никакое значение по умолчанию |
Значение:
|
Пример (Bug Finder):
polyspace-bug-finder -D HAVE_MYLIB -D int32_t=int |
Пример (Code Prover): polyspace-code-prover -D HAVE_MYLIB -D int32_t=int |
Пример (сервер Bug Finder): polyspace-bug-finder-server -D HAVE_MYLIB -D int32_t=int |
Пример (сервер Code Prover):
polyspace-code-prover-server -D HAVE_MYLIB -D int32_t=int |