Pull to refresh

Comments 42

Тихоходка из любви к искусству присутствует? :)
UFO landed and left these words here
UFO landed and left these words here
Сори за оффтоп, но не подскажите где взять видео с подобными существами?
UFO landed and left these words here
Не понял, без чего именно обходиться?
UFO landed and left these words here
Другой вариант — включить /Wall. Сообщения будут выданы, но это путь, как вы понимаете, только для отважных.

Без холивара, но в *nix код, собирающийся с -Wall без ругани, считается хорошим тоном. А ядро FreeBSD вообще собирается с -Werror (любое предупреждение = ошибка).
Если бы ещё ядро Линукса собиралось в таком же режиме :-)
Это и в некоторых коммерческих виндузовых приложениях так, если у команды есть время следить за чистотой кода, а не только бегать от релиза к релизу. Плюс, низкоуровневые вещи обычно пишут с -werror
Везде, где я работал (правда это 2 фирмы, но одна большая) все собиралась без варнингов.Это не сложно, если умеешь хорошо программировать
Хорошо или нет — это другой вопрос, но отсутствие варнингов говорит о некоторой культуре, от архитектурных багов и «шедевров» никакие статические анализаторы не спасут, а именно архитектурные ошибки стоят самой большой крови.
Вроде бы все умеют ходить, но на мостах перила всегда есть.
Почему обязательно *nix код, я и в винде при использовании mingw ставлю -Wall -Werror и иногда -Wextra
Лучше решать проблемы по мере их возникновения, а не копить их.
Не к вам лично, а вообще: И где же все эти замечательные программы, собираемые разными компиляторами и с разными -Wall? Я где не посмотрю код, г*вно, г*вном. И у меня в общем то тоже код не лучше выходит… :)

P.S. А у Вас есть готовый проект (.vcproj) для разрабатываемого Вами qutIMа? А то я бы прям сейчас попробовал на нем разрабатываемый статический анализатор общего назначения. Посмотрим, как там с -Wall и смогу ли я что-то найти своим изделием. :)
Готового нету, но можно легко сгенерить при помощи cmake'а, впрочем для студии, к сожалению, все доп варнинги не включены, ибо студийным компилером почти не пользуемся.
Я не уловил перехода от «я всегда ставлю -Wall» до «даже не пытаемся собрать студийным компилятором»…
Оборот, при использовании MinGW, ни о чем не говорит, да? Есть у нас человечек, который студийным компилером собирает и иногда присылает пачку варнингов, но код вообще без предупреждений собирается при помощи gcc и clang (за исключением пары модулей, но там уже проблемы с шаблонами в самом clang'е). За студийный полностью отвечать не могу, мне проще и быстрее собирать при помощи кросскомпилятора. Тем не менее, в результате выходят полностью рабочие бинари. Опять же ввиду отсутствия прекомпиленых либ Qt под W64 и отсутствия же поддержки W64 в MSVS Express Edition я просто физически не имею возможности собирать под W64. Кому интересно, можете конечно заморочится, собрать целиком Qt под W64, потом все зависимые библиотеки, а потом еще подправить cmake скрипты на предмет всяких странных неожиданностей.
-WAll прежде всего от детских и тупых ошибок спасает
жесть, что варнинги привязаны к deprecated ключу — еще один гвоздь в планы перехода на vs2010 до появления первого сервис пака — у нас всяких проблем с переходом просто вагон — vs2003 -> vs2005 мигрировалось просто на ура — ни одного исправления или отваливания фич. vs2008 -> vs2010 просто epic fail.
Топик в равной мере относится и к VS2008, к сожалению. Там та же проблема.
Не совсем понятно, почему варнинги вообще генериться должны.
Ведь в озвученных примерах приведение типов — явное.
То есть программист так задумал. Ему так надо.
Ну с одной стороны да, с другой стороны варнинг как раз и кидается чтобы уточнить у программиста, действительно ли он так задумал или просто опечатался
Не совсем. В С они бросаются при наличии возможных ошибок (например, разные размер типов прии привдение отличным от продвижения типа)

А в С++ воообще есть реинтрепт, который читается: я сам или дурак, или очень умный, тогда все пруюбма
Тема хорошая, правильная — но глаза зацепили «младшие 4 гигабайта памяти». my ass, младшие четыре гигабайта… (ушел посыпать голову пеплом и вспоминать XMS).
А я помнится и XMS и EMS пробовал) Когда игрушку под дос ваял) XMS оказалась попроще, насколько я помню, для доступа. Хотя мб уже и путаю.

Вообще конечно забавные времена были, под разные приложения — разные конфигурации в autoexec.bat и config.sys… Кому то EMS нужна, кому то наоборот…
Я не сишник, но разве int не должен быть платформозависимым типом?
A «plain» int object has the natural size suggested by the architecture of the execution environment

Соответственно int должен быть 16битным на 16 разрядной платформе, 32 битным на 32х и 64битным на 64х разрядной платформе соответственно. Почему вдруг в виндовсе решили его оставить 32битным мне непонятно.
Фактически мы имеем лишь такую схему chat<=short<=int<=long<=long long
*не int, а long разумеется, который в Unix'е таки стал 64 битным
Ну, насколько я понял из поиска, сделано это для прикрытия задниц криворуких программистов, которые полагали, что размер int заведомо 4 байта, и вместо чего-то такого SizeOf(Integer) — это у меня на Delphi так — писали тупо константу.

Получается, что режим поддержки кривых рук прошит намертво, и только define может помочь?
define может только навредить :-). Если вы имеете ввиду дефайном сделать int 64-битным. Другие библиотеки такого подвоха не ожидают.

Ну если в тех библиотеках размер int всегда 4 байта, то да :-)
UFO landed and left these words here
Главное — чтобы был хоть какой-то способ написать исходный код явно так, чтобы предупреждений не было.

Классический способ — приведение через интегральный тип с размером указателя:

void *ptr = x;
int y = (int)(size_t)ptr;

int i = x;
return (void*)(size_t)i;
Sign up to leave a comment.