реклама на сайте
подробности

 
 
> Использование несуществующих дефайнов
esaulenka
сообщение Sep 4 2012, 15:08
Сообщение #1


Профессионал
*****

Группа: Свой
Сообщений: 1 032
Регистрация: 13-03-08
Из: Маськва
Пользователь №: 35 877



Столкнулся с такой... проблемой:

Для контроля за выполнением программы в коде широко использую конструкции
Код
#if DEBUG_MODE
printf ("10 секунд, полёт нормальный!\n");
#endif

при этом дефайн DEBUG_MODE объявлен в глобальном файле-хидере.

Сегодня потратил пол-дня, выясняя, почему один из модулей не шлёт отладочную информацию (грешил на то, что не вызываю его в нужном месте). Выяснилось, что из того модуля банально не видно дефайн DEBUG_MODE, и компилятор повыкидывал все printf'ы.

Собственно, вопрос: каким образом оформить условие, чтобы компилятор сообщал об ошибке "не знаю такого символа" ?
Можно завернуть в обычный if(), но вдруг компилятору не хватит мозгов выкинуть его в релизной ветке?


--------------------
Тут обсуждается творческий порыв, а не соответствие каким-либо стандартам ©
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов (1 - 10)
aaarrr
сообщение Sep 4 2012, 15:20
Сообщение #2


Гуру
******

Группа: Свой
Сообщений: 10 713
Регистрация: 11-12-04
Пользователь №: 1 448



Цитата(esaulenka @ Sep 4 2012, 19:08) *
Собственно, вопрос: каким образом оформить условие, чтобы компилятор сообщал об ошибке "не знаю такого символа" ?

Переименуйте сам printf, тогда точно выругается.

Код
Где-то в global.h:
#ifdef DEBUG
    #define    printf_dbg(...)    printf(__VA_ARGS__)
#else
    #define    printf_dbg(...)
#endif

В модуле:
#include "global.h"

printf_dbg("bla-bla");
Go to the top of the page
 
+Quote Post
Idle
сообщение Sep 4 2012, 17:20
Сообщение #3


Местный
***

Группа: Участник
Сообщений: 351
Регистрация: 5-04-05
Пользователь №: 3 874



Код
#ifndef DEBUG_MODE
#error DEBUG_MODE undefined
#endif
Go to the top of the page
 
+Quote Post
_Артём_
сообщение Sep 4 2012, 18:20
Сообщение #4


Гуру
******

Группа: Свой
Сообщений: 2 128
Регистрация: 21-05-06
Пользователь №: 17 322



Цитата(Idle @ Sep 4 2012, 20:20) *
Код
#ifndef DEBUG_MODE
#error DEBUG_MODE undefined
#endif

Тогда дебаг неотключаемый будет.


Код
#if (DEBUG_MODE==0) // отладка отключена

#elif  (DEBUG_MODE==1) //отладка включена
else
#error DEBUG_MODE undefined
#endif
Go to the top of the page
 
+Quote Post
SSerge
сообщение Sep 4 2012, 19:16
Сообщение #5


Профессионал
*****

Группа: Свой
Сообщений: 1 719
Регистрация: 13-09-05
Из: Novosibirsk
Пользователь №: 8 528



Цитата(_Артём_ @ Sep 5 2012, 01:20) *
Тогда дебаг неотключаемый будет.

Тогда надо два символа определять:
Код
// определение
#ifndef NDEBUG
  #define DEBUG_MODE
#endif

//проверка
#if !defined( NDEBUG ) && !defined( DEBUG_MODE )
  #error Achtung! DEBUG_MODE and NDEBUG both undefined
#endif



--------------------
Russia est omnis divisa in partes octo.
Go to the top of the page
 
+Quote Post
Idle
сообщение Sep 4 2012, 19:31
Сообщение #6


Местный
***

Группа: Участник
Сообщений: 351
Регистрация: 5-04-05
Пользователь №: 3 874



Код
#ifndef DEBUG_MODE
#error DEBUG_MODE undefined
#endif

#if (DEBUG_MODE == 1)
printf ("10 секунд, полёт нормальный!\n");
#endif

полёт нормальный?
Go to the top of the page
 
+Quote Post
_Артём_
сообщение Sep 4 2012, 19:54
Сообщение #7


Гуру
******

Группа: Свой
Сообщений: 2 128
Регистрация: 21-05-06
Пользователь №: 17 322



Цитата(SSerge @ Sep 4 2012, 22:16) *
Тогда надо два символа определять:
Код
// определение
#ifndef NDEBUG
  #define DEBUG_MODE
#endif

//проверка
#if !defined( NDEBUG ) && !defined( DEBUG_MODE )
  #error Achtung! DEBUG_MODE and NDEBUG both undefined
#endif


Не, неправильно -так Achtung! никогда не случится:
так как вот это
Код
#ifndef NDEBUG
  #define DEBUG_MODE
#endif


определит DEBUG_MODE, если NDEBUG !defined.

Цитата(Idle @ Sep 4 2012, 22:31) *
Код
#ifndef DEBUG_MODE
#error DEBUG_MODE undefined
#endif

#if (DEBUG_MODE == 1)
printf ("10 секунд, полёт нормальный!\n");
#endif

полёт нормальный?


Пожалуй, что так полетит.
Go to the top of the page
 
+Quote Post
SSerge
сообщение Sep 4 2012, 20:17
Сообщение #8


Профессионал
*****

Группа: Свой
Сообщений: 1 719
Регистрация: 13-09-05
Из: Novosibirsk
Пользователь №: 8 528



Цитата(_Артём_ @ Sep 5 2012, 02:54) *
Не, неправильно -так Achtung! никогда не случится:

Это решает проблему из первого сообщения:
Цитата
из того модуля банально не видно дефайн DEBUG_MODE

если напутано в инклюдах, то это будет обнаружено.

А вообще лучше определения таких символов, управляющих отладкой, включать не в текст программы, а определять в командной строке компилятора (в опциях используемой IDE или в make-файле). Это позволяет скомпилировать Debug и Release варианты без изменений в тексте программы, просто выбирая нужный вариант.
На NDEBUG, кстати, ещё завязаны ассерты (см. assert.h), поэтому есть смысл начинать плясать от него, примерно как в моём примере было сделано.

update: впрочем, тогда эта проблема просто не возникнет, поскольку наличие/отсутствие NDEBUG всегда однозначно определяет Debug или Release компилируется.


--------------------
Russia est omnis divisa in partes octo.
Go to the top of the page
 
+Quote Post
редактор
сообщение Sep 5 2012, 06:00
Сообщение #9


Местный
***

Группа: Участник
Сообщений: 356
Регистрация: 9-06-07
Пользователь №: 28 315



Цитата
Цитата(Idle @ Sep 4 2012, 20:20) *
Код
#ifndef DEBUG_MODE
#error DEBUG_MODE undefined
#endif

Тогда дебаг неотключаемый будет.


Если "#Error " заменить на "#Warning" то код скомпиится и выдаст предупреждение
Но добавлять все таки лучше в командную строку или MAKE


--------------------
Хорошую систему делают из стандартных блоков нестандартно мыслящие инженеры.
Go to the top of the page
 
+Quote Post
halfdoom
сообщение Sep 5 2012, 08:00
Сообщение #10


Профессионал
*****

Группа: Свой
Сообщений: 1 003
Регистрация: 20-01-05
Пользователь №: 2 072



Цитата(esaulenka @ Sep 4 2012, 18:08) *
Собственно, вопрос: каким образом оформить условие, чтобы компилятор сообщал об ошибке "не знаю такого символа" ?


Для gcc это реализуется ключиком -Wundef.
Go to the top of the page
 
+Quote Post
esaulenka
сообщение Sep 5 2012, 09:13
Сообщение #11


Профессионал
*****

Группа: Свой
Сообщений: 1 032
Регистрация: 13-03-08
Из: Маськва
Пользователь №: 35 877



Итого, моё имхо.
Методика aaarrr самая правильная. Заодно и код не загаживается постоянными #if #endif. Почему я про неё забыл, непонятно :-)

Добавлять в каждый файл #ifndef .. #error лениво. Если я забыл сделать #include "global.h", то и эту проверку вставить забуду.

И надо будет ещё раз полистать руководство от кейла на предмет аналога ключа -Wundef. В каких-то ранних версиях это было поведением по умолчанию, было удобно.

Ну или подумать над выносом глобальных дефайнов в настройки среды.
Правда, в одном из проектов у меня уже три таргета, различающиеся парой констант. Если туда же добавить отладку, получится шесть...


--------------------
Тут обсуждается творческий порыв, а не соответствие каким-либо стандартам ©
Go to the top of the page
 
+Quote Post

Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 19th July 2025 - 14:17
Рейтинг@Mail.ru


Страница сгенерированна за 0.01436 секунд с 7
ELECTRONIX ©2004-2016