10 лет сайту viva64.com!


Сайту viva64.com — основной площадке разработчиков анализатора кода PVS-Studio исполнилось 10 лет! Домен был зарегистрирован 09.11.2006 года, а последнее серьезное обновление дизайна было выполнено в декабре 2010 года. Пришло время что-то поменять.

Участники проекта


Сейчас сайтом viva64.com занимаются 4 человека:


Остальные люди занимаются созданием контента и не имеют отношения к инфраструктуре сайта, его внешнему виду и работоспособности.

Что делает компания


Мы делаем свой программный продукт. Это инструмент для программистов — анализатор кода PVS-Studio. Он помогает найти ошибки в программах путем анализа исходного кода. Компании-клиенты экономят деньги за счет раннего обнаружения ошибок до стадии бета-тестирования и, тем более, публичного выпуска. Этот программный продукт мы и продаем.

Для продвижения анализатора PVS-Studio мы пишем статьи о проверке проектов с открытым исходным кодом, в которых находим ошибки с помощью нашего инструмента.

Концепция сайта


Долгое время даже мы сами не могли сформулировать к какому типу сайтов относится наш ресурс.

С одной стороны, у нас есть компания, а значит, это корпоративный сайт. Но мы не Disney и не Microsoft, поэтому про нашу компанию никому ничего знать не интересно.

С другой стороны, у нас есть продукт для программистов, но в эпоху AppStore, Play Market и прочих сторов, сайт отдельного продукта не так-то уж интересен конечным пользователям. Многие успешные продукты вообще обходятся без сайта и ничего.

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

Объединив все это в одну концепцию, мы пришли к следующему. У нас контентный сайт. Однако с любой его страницы должно быть понятно, что есть такой программный продукт PVS-Studio.

Какую мысль мы хотим донести посетителю сайта?


Итак, у нас контентный проект. Но какую мысль мы хотим донести до тех, кто оказался у нас на сайте? Сначала надо разобраться с тем, как посетители попадают к нам на сайт и какие страницы пользуются популярностью. Обратимся к Google Analytics. Вот обзор источников трафика за 10 месяцев 2016 года (Acquisition Overview for Jan-Oct 2016):

Picture 1


При этом, если смотреть самые популярные страницы, то главная страница сайта будет лишь на 15 месте. Таким образом, можно сделать вывод, что люди почти никогда не бывают на главной странице сайта, а всегда попадают на какой-то опубликованный на сайте контент (статьи) или из поиска, или из социальных сетей, или по ссылке с другого ресурса.

Первый важный вывод: посетители всегда попадают сразу «в середину» сайта, минуя главные страницы, а значит пытаться «провести» человека с главной до покупки продукта (условно) — идея так себе.

Хорошо, с этим разобрались. Но как тогда «вести» посетителя сайта к покупке продукта? Ведь в конце концов все статьи пишутся ради этого.

Мы считаем, что наш цикл продажи составляет около трех-шести месяцев. За это время человек должен прочитать 3-4 статьи про PVS-Studio и проверить инструмент на своем проекте. Дальше, если нам повезет, и инструмент человеку понравится, то он его купит.

Таким образом, наша задача донести до посетителя сайта сразу две мысли:

  • Надо прочитать 3-4 статьи, а не уйти после той, на которую он пришел.
  • Надо авторитетно и с фактами убедить, что предлагаемый программный продукт не пустышка, не мошенничество, а реально крутая штука.

Для того, чтобы человек прочитал 3-4 статьи, надо показать ему, что эти статьи есть на сайте. Поэтому у нас есть блок «Последние статьи», который должен попадаться на глаза.

Мы делаем огромную работу — находим ошибки в проектах с исходным кодом, и это помогает человеку поверить в инструмент. Задача сайта сделать так, чтобы посетитель узнал о проверках. Поэтому у нас есть блок «сколько мы проверили проектов и сколько нашли ошибок». Перейдя в этот раздел, пользователь видит полный список проектов, которые мы когда-либо проверяли и все найденные ошибки.

Находясь на любой странице сайта, посетитель должен понимать, что есть такой программный продукт PVS-Studio и его можно на этом сайте получить. Поэтому в разных местах «разбросаны» упоминания об анализаторе кода.

Какие конкретно элементы разработаны для достижения цели сайта


Мы определились, что цель сайта – проинформировать посетителя, что на сайте есть интересные статьи про проверку проектов, и написаны они не без помощи PVS-Studio. Который, в свою очередь, является объективно достойным инструментом.

Как же конкретно эту мысль мы доносим? Поехали по пунктам.

Шапка сайта


В шапке сайта написано, чем занимается компания («Мы делаем анализатор кода»). По моему опыту, часто сайт, в который даже вложено много денег, не всегда отражает деятельность компании. И ладно, когда это многопрофильные компании вроде Siemens или Samsung. Но часто даже небольшие организации на 10-20 человек настолько увлекаются креативом, что сайт весь прыгает и переливается, но что компания предлагает — непонятно.

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

Левое меню сайта


Левое меню сайта является супер минималистичным. В нем содержатся только самые важные пункты. Что на нашем сайте самое важное? По нашему мнению:

  • Блог, чтобы всегда можно было почитать «что новенького проверили».
  • Список проверенных проектов и список найденных в них ошибок с конкретными числами, чтобы люди видели, что мы работаем.
  • Советы по программированию.
  • Ну и, конечно, наш программный продукт.

Подвал сайта


Подвал довольно простой:

  • Еще одно напоминание о PVS-Studio.
  • Список основных страниц и разделов сайта.
  • Контакты.
  • Twitter, RSS.
  • Поиск по сайту.

Правый блок сайта (сайд-бар)


В правом блоке разместились следующие традиционные элементы:

  • Последние статьи.
  • Трансляция твиттера.
  • Список ссылок «это интересно».

Из нетрадиционных элементов:

  • Блок «проверенных проектов» — с количеством проектов и числом найденных ошибок.
  • Блок «примеры ошибок» — реальные фрагменты кода из разных проектов.

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

Для поклонников продукта


Как у любого продукта с историей, у PVS-Studio есть поклонники (и ненавистники, но про них мне нечего сказать). Для этой категории людей мы подготовили раздел с бесплатной сувенирной продукцией.

Picture 4


У нас на сайте можно скачать обои на рабочий стол, а также картинки для печати на майках и кружках. Очень забавно бывает увидеть в чьем-то офисе эти вещи.

Интервью с разработчиками сайта


Статья о разработке новой версии сайта была бы неполной без комментариев со стороны самих участников процесса. Я попросил ответить их на несколько вопросов.

Сергей Харлеев, веб-дизайнер


ЕР: Сергей, скажи, пожалуйста, насколько легко далась концепция сайта? Все-таки не магазин, не лендинг, не просто блог. Как ты понял, что мы делаем?

СХ: Да, проект оказался больше и сложнее чем на первый взгляд. Основная сложность была в удержании грани, не перебарщивать с маркетингом. Но при этом не забывать основную задачу сайта — продажу продукта. Целевая аудитория у нас особая, придирчивая, и не терпит навязчивость. Поэтому мы внутри компании создали импровизированную фокус группу из программистов и на ней откатывали некоторые элементы и блоки сайта.

Для начала во главу угла мы поставили публикации, ведь в первую очередь viva64.com это обучающий информационный ресурс. Поэтому основной упор был на удобочитаемость статей, и удобство пользователей. А сам анализатор PVS-Studio ушёл на второй план, переехав в подраздел.

Мы не используем такие элементы маркетинга как разноцветные баннеры, большие красивые иллюстрации, кричащие заголовки, так как подобные вещи разработчики не уважают. И такими фишками возможно получить только обратный эффект.

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

ЕР: Какими способами было решено возвращать пользователей на сайт?

Вообще в мире способов много, но не каждый подходит для нашей аудитории. Например, мы не используем e-mail подписку, так как наши пользователи мягко говоря недолюбливают рассылки, также и социальные сети. Выбор пал на два канала, где у нас уже есть подписчики, это твиттер Андрея Карпова, и RSS.

ЕР: Насколько сильно полет творческой мысли подвергался цензуре?

СХ: В начале бывали моменты когда меня заносило в плане графики, например, с концепцией волшебного мира, как в мультике «Время приключений» для нашего героя — единорога. Но команда меня остепенила, так как фокус внимания уходил с нашего героя. Но когда ты не один месяц живешь с продуктом, начинаешь хорошо его понимать, принципы, философию, и ближе к завершению, я с клиентом и командой был на одной волне.

ЕР: Сколько страниц в итоге пришлось отрисовать? Насколько типично такое количество страниц?

СХ: Более 60 макетов, для каждой страницы проектировалась планшетная и мобильная версия. Подобный подход типичный для онлайн сервисов, но не часто используется для корпоративных и информационных сайтов.

ЕР: Чем этот проект отличался от других твоих проектов?

СХ: У меня впервые заказали бренд-бук для сайта, с правилами использования шрифтов, цветов, расстояний, элементов и блоков. Это было откровение, оказалось на редкость удобный инструмент, и для разработчиков, и для самого себя, документ заметно ускорил и упростил процесс.

Константин Потапов, веб-разработчик


ЕР: Константин, первый вопрос про сроки. В какие временные рамки ты первоначально оценивал проект и сколько в итоге получилось? Как думаешь почему большое такое расхождение?

КП: Изначально я видел лишь простой элементарный сайт со статьями. И оценил создание сайта в более современном дизайне в 3 недели. Сколько получилось я не в курсе, как говорят «после релиза сайта его жизнь только начинается».

ЕР: Ну я-то про сроки все знаю. Над дизайном с Сергеем мы начали работать в середине мая 2016, закончили (условно конечно) в середине ноября, то есть полгода. Первые работы над кодом сайта начались в июле. Хоть можно сказать, что это к дизайну не имело отношения, но это было нужно для того, чтобы появилось понимание, что сайт «больше чем кажется». Непосредственно новый дизайн начали верстать и кодировать в середине сентября, а релиз был в середине декабря. То есть три месяца на знакомство с кодом и три — на основную работу.

Ну да, почти три недели и получается… (Сарказм)

КП: Я не предполагал, что у такого маленького сайта такие большие внутренности. И это было как хорошо, так и плохо. Из хорошего там была крутая система публикации статей на сайт. Материал люди готовили в Word, специальным самодельным плагином преобразовывали это в набор .html специального вида, которые можно публиковать как на основном, так и на других сайтах. Кроме того, там были интеграции с приложением PVS-Studio, куча маркетинговой аналитики.

Из плохого там было много «production-кода». Как я любил говорить своим программистам «это не production, тут не место для костылей». Но взвесив все за и против и потратив пару недель на попытку уместить все яйца в одной корзине, а также значительное время на причесывание legacy-кода, пришел к выводу об эволюционном подходе. Судя по всему, вариант «все взять и переписать» для таких проектов уже не работает.

Отдельной сложностью был новый дизайн. Я привык работать структурно, по жестким сеткам и над смыслом, а не эмоциональной подачей (благо не умею красиво рисовать). Я вижу много недостатков, но как известно «идеальный продукт стоит бесконечных денег, бесконечно времени и не существует в природе». Поэтому пришлось идти на компромиссы.

ЕР: Кстати какой размер сайта сейчас? Размер контента и размер исходников.

КП: В момент написания этого текста у нас есть вот что:

  • Общих статей (блог, новости, терминология, уроки и т.п.) — 836;
  • Статей документации — 512 (как и положено программистам);

Итого примерно 1350 страниц на русском и английском языках. Кроме того, есть 255 (откуда эти программистские числа?) страниц с примерами ошибок.

Короче, получается примерно полторы тысячи статей на русском и английском.

Если говорить про код, то это 14 мегабайт кода не считая библиотек, но это слегка искусственный показатель. А для любителей статического анализа кода вот еще более искусственный на картинке.

Picture 2


ЕР: Расскажи про «начинку» на которой работает сайт? Какие технологии использовались?

КП: Это сайт с богатой историей, который существует 10 лет, делался разными программистами. Наверное, слово «говнокод» вычистят при правке текста, поэтому скажу так обтекаемо. С учетом этого, как ответственный человек, я решил по минимуму использовать нестандартные или редкие технологии чтобы не было проблем с поиском разработчика, если меня собьет самолет. Внутри стандартный Python 2.7, Django 1.9. Если бы я начинал проект с нуля, я бы использовал более современные технологии и, возможно, еще внедрю их в процессе рефакторинга. Но тут как с первой брачной ночью — эта честь до меня выпала другому человеку 10 лет назад :-).

ЕР: Об особенностях верстки есть что рассказать?

КП: Я старался по максимуму внедрить «универсальную» верстку и зарезал (возможно зря) готовую верстку в БЭМ-стиле (это когда каждый элемент верстается отдельно). Этот подход хорош для неуправляемых проектов с сотней разработчиков и горячими изменениями. Но я сторонник того что CSS — это каскадная таблица стилей, и как минимум пытался работать в этой парадигме. Также я старался по максимуму использовать возможности фреймворка (imposition framework), чтобы просто приверстывать многие элементы, совсем не залезая в CSS. Но блин — это всегда компромисс. И я не уверен, что мое решение наилучшее. Например, сейчас я хотел бы переделать верстку через SASS и сделать ее еще гибче. Когда я начинал, были не решены многие композиционные вопросы, которые всплывают в процессе разработки. Кроме того, я не до конца воплотил все дизайнерские идеи Сергея, но старался сделать это по максимуму.

Сайт — это софт, а как сказал в свое время директор HP (если не ошибаюсь) — хочешь делать классный софт, делай свое железо. Есть много разных устройств, и разрешений, и я старался найти компромисс.

ЕР: Как был организован процесс разработки? Ветки, разные сервера, все такое. Побольше подробностей только!

КП:

У нас вот какая инфраструктура сейчас:

  • Боевой сервер — это понятно.
  • Stage-сервер (для разработки) в режиме горячего переключения нового релиза и старого сайта для теста изменений.
  • «Спящий сервер» (как мы его назвали) для резервного разворачивания полной копии боевого.

На программном уровне были внедрены автоматизации и синхронизации между разными серверами. Похоже, это оправдалось на 200%. Можно обновить версию сайта «по воздуху» прямо из системы администрирования. Кроме того, есть еще отдельный сервер на Jenkins, который автоматически конвертирует .docx-статьи в .html и заливает их на сайт.

ЕР: Много ли приходилось переделывать по несколько раз и если да, то почему?

КП: Я очень уважаю эффективность. И не понимаю людей, которые могут сидеть и смотреть в монитор по два часа подряд, дожидаясь пяти вечера или пока их не подтолкнет начальник. Этот сайт поставил передо мной архитектурный вызов с которым я раньше так плотно сталкивался лишь однажды, и я не считаю, что смог его решить в полной мере. Я окончил физтех и у меня на подкорке прошита идеология ученый-инженер-исследователь. Я создал где-то 5 версий движка с разным переплетением технологий и архитектур, но уперся в то что поменять «все и сразу» слишком рискованно. Помню я как-то разрабатывал IP-телефонию для Таджикистана. Но у них там электричество тогда было по карточкам, не то что интернет. И я, помимо прочих, столкнулся с проблемой что им нужен именно G729 кодек (а не open-source 723). Лицензией на который обладали лишь Intel и кто-то еще. Но суть в том, что из-за экономии 5% трафика я чуть не заработал нервный срыв.

Но в этом проекте было кому остановить меня вовремя от этих попыток перфекционизма.

ЕР: Теперь, постфактум, какую бы ты дал временную оценку для разработки новой версии дизайна сайта? А новой версии движка сайта?

КП: Три недели на все. При условии, что не нужна интеграция с существующей инфраструктурой, дизайн соберу я на готовых компонентах и редактирование статей через админку. А что? Это же просто сайт со статьями!!! Надеюсь вы поняли, что это сарказм.

ЕР: Какие дальнейшие шаги с сайтом необходимо сделать?

КП: Как минимум, обязательно нужно следующее:

  • Асинхронно грузить статику.
  • Поупражняться в магии с настройками сервера.
  • Улучшить отображение сайта на разных устройствах.
  • Провести «учебные тревоги» и проверить как функционируют резервные системы.
  • Задокументировать текущую систему (но у меня с этим проблемы).
  • Если смогу создать доки, хотел бы уйти в отпуск или умереть с чувством что «работа сделана» :-).

Илья Тетерин, инженер Linux


ЕР: Илья, расскажи историю, благодаря которой мы познакомились?

ИТ: Основной сайт отключили якобы за спам, да еще и начали заносить в черные списки за якобы распространение вирусов. Потребовалось срочно разбираться, что происходит, и это больше по моей части. В юности был в хакерской тусовке, кое-какие навыки остались. Впрочем, оказалось, что никакие злобные диверсанты не действовали, а всего лишь недостаточно хорошо организована защита от самых обычных вирусов, крадущих пароли от FTP. Офис-то защитили нормально, а вот на домашних компьютерах, где тоже бывает служебная информация, всё дыряво. Впрочем, сложно в этом упрекать рядовую софтовую фирму, когда на аналогичные грабли нарвались даже кандидаты в президенты США и их команды. Сейчас, думаю, ситуация значительно улучшилась, от опасных протоколов избавились, права всем порезали, сделали внушение сотрудникам и т.д.

ЕР: Так, а расскажи про железо, на котором работает сайт.

ИТ: Для данного сайта не требуется каких-то экстраординарных вычислительных мощностей, но нужна стабильная работа. Используется виртуальный выделенный сервер, он обеспечивает хороший резерв по прочности. В случае если что-то пойдет не так (рост посещаемости на порядки, DDoS-атаки) — мы готовы в кратчайшие сроки мигрировать на более мощный сервер или даже организовать кластер, а также подключить внешние сервисы защиты, чтобы обеспечить бесперебойную работу сайта.

ЕР: Какие задачи по организации работы сервера были решены, а что еще только предстоит сделать в ближайшем будущем?

ИТ: Планомерно снижается уязвимость системы для внешних угроз и скорость восстановления в случае поломки. Перешли на более безопасные протоколы обмена, навели порядок с ролями пользователей и их правами доступа. Бэкап теперь делается в облачный сервис с трехкратным резервированием.

Сейчас на завершающем этапе организация репозитариев для пользователей Linux-версии PVS-Studio, благодаря чему нашим продуктом будет удобно пользоваться и особенно обновляться. Хотелось бы еще внедрить регламенты обеспечения информационной безопасности и работы с резервными копиями. А то тройной бекап — это хорошо, но его же надо и проверять все-таки.

Кроме того, стоит создать скрипт автоматического развертывания готовой системы из образа на любом сервере (чтобы это делалось за минуты, а не за десятки минут).

ЕР: Уже хочу это все!

Заключение


Мы хорошо поработали над новым сайтом, но не считаем свою работу законченной. Поэтому будем рады получить ваши замечания, пожелания по улучшению и просто комментарии о новой версии сайта www.viva64.com.


Если хотите поделиться этой статьей с англоязычной аудиторией, то прошу использовать ссылку на перевод: Evgeniy Ryzhkov. The new design of viva64.com. The story behind it, told by the PVS-Studio developers
Поделиться с друзьями
-->

Комментарии (44)


  1. karter
    27.12.2016 11:13
    +1

    Здравствуйте! Мне показалось, или первая и вторая футболка в сувенирах одинаковые?


    1. lookid
      27.12.2016 11:40

      Там должны быть мужские, женские или просто мужские. А то какие-то приталенные.


      1. EvgeniyRyzhkov
        27.12.2016 11:43

        Там нет футболок, там только картинки, которые вы сами можете распечатать на любые модели.


      1. karter
        27.12.2016 11:43
        +1

        Ну, там надписи разные «Майка с классическим единорогом» и «Майка с единорогом в майке », а рисунки одинаковые.
        http://www.viva64.com/ru/merchandise/1/
        http://www.viva64.com/ru/merchandise/2/


        1. EvgeniyRyzhkov
          27.12.2016 11:44

          Баг, спасибо, поправим.


          1. karter
            27.12.2016 11:45

            Пожалуйста.


  1. hardtop
    27.12.2016 11:36

    Интересно, если Django — устаревшая технология, то что же выбрать более мощного\удобного\на острие технологий?

    А так — вполне типичная история… Оценили, написали, доделали… И да, 3 недели )))


    1. EvgeniyRyzhkov
      27.12.2016 11:50

      Думаю надо понимать так, что используемая версия Django была устаревшей, а не в целом Django.


  1. hdfan2
    27.12.2016 13:30

    Сайт хороший, приятный, но вот что слегка царапнуло глаз: зачем (и сверху, и снизу) рядом с кнопкой «Contact us» ещё и ссылка на email? При том, что при нажатии по «Contact us» открывается страница с формой, где опять же есть ссылка на email? По-моему, достаточно оставить её на странице с формой обратной связи, чуть-чуть разгрузив основную страницу. И ещё — это у меня глюки, или правая половина кнопки «Contact us» (где-то начиная с «a») не реагирует на мышь? Проверял на linux-е в Firefox и Chome.


    1. EvgeniyRyzhkov
      27.12.2016 13:39

      Есть люди, которые хотят тупо написать e-mail. А есть те, кто хочет форму на сайте. По этой причине есть и почта, и форма.


      1. hdfan2
        27.12.2016 14:01

        Это понятно. Но на странице Feedback и так есть ссылка на email. Дублирование получается. Впрочем, мелочь, решать вам.


  1. rustler2000
    27.12.2016 13:37

    «Download and try» ведет на windows версию даже если браузер из под линукса


    1. EvgeniyRyzhkov
      27.12.2016 13:39

      Сейчас подавляющее количество пользователей под Windows, поэтому основная версия — эта.


      1. rustler2000
        27.12.2016 13:54

        Блин а как триальную лицензию запросить? Ссылки нету :S
        Реально интерестно посмотреть на ложно позитивные сообщения. Да и вообще заработает ли на наших крестах )))


        1. EvgeniyRyzhkov
          27.12.2016 14:50

          Ссылки на что? Чем вот эта ссылка не ссылка? http://www.viva64.com/en/pvs-studio-download/


          1. rustler2000
            27.12.2016 15:02

            Ну да скачал — думал достаточно. Начал запускать.
            На практически самом сладком месте выясняется что еще лицензию триальную нужно запросить по e-mail.


            1. EvgeniyRyzhkov
              27.12.2016 15:05

              Там написано, что вы можете продлить триал, если заполните форму и нажмете кнопку. Все будет сделано в автоматическом режиме. Ничего запрашивать по e-mail не нужно.


              1. rustler2000
                27.12.2016 15:10

                Я под линукс — выкачал .tar.gz — .lic внутри нету. В итоге ничего ничего не попробовать


                1. EvgeniyRyzhkov
                  27.12.2016 15:15

                  Для Linux да, другая модель — напишите на support@viva64.com — пришлем лицензию.


                  1. rustler2000
                    27.12.2016 15:19

                    Спасибо! Уточнил в мыле


                  1. rustler2000
                    28.12.2016 09:41

                    Действительно V597? Или оно просто по мемсету на локальную переменную реагирует?

                        boo *p = malloc(sizeof(boo));
                        if (p == NULL) return NULL;
                        memset(p, 0, sizeof(boo));
                        ....
                        return boo;
                    


                    1. Andrey2008
                      28.12.2016 10:14

                      Код недостаточен для ответа. Если там где… нет использования 'p', то анализатор прав. Покажите весь код функции.


                      1. rustler2000
                        28.12.2016 11:31

                        Пермишинов нету показать — но там много ассайнов в члены структуру и в конце не return boo а конечно же return p.
                        Если там все члены изменены — может ругаться так?


                        1. Andrey2008
                          28.12.2016 16:08

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


                          1. rustler2000
                            29.12.2016 10:16
                            +1

                            typedef struct {
                            	void* b;
                            } a;
                            
                            a* custom_struct_malloc()
                            {
                            	a* p = malloc(sizeof(a));
                            	if (p == NULL) return NULL;
                            	memset(p, 0, sizeof(a));
                            
                            	void* priv = malloc(1024);
                            	if (priv == NULL) {
                            		free(p);
                            		return NULL;
                            	}
                            	p->b = priv;
                            
                            	return p;
                            }
                            


                            Честно говоря, хотелось бы знать, на основание чего компайлер может выбросить мемсет, только изза того что p не используется в одной из ветки


                            1. Andrey2008
                              29.12.2016 10:39

                              Удалить memset() он не может, но теоретически может выполнить его после второй проверки:

                              typedef struct {
                              	void* b;
                              } a;
                              
                              a* custom_struct_malloc()
                              {
                              	a* p = malloc(sizeof(a));
                              	if (p == NULL) return NULL;
                              
                              	void* priv = malloc(1024);
                              	if (priv == NULL) {
                              		free(p);
                              		return NULL;
                              	}
                              	memset(p, 0, sizeof(a));
                              	p->b = priv;
                              
                              	return p;
                              }
                              


                              Если до этого массив бы использовался для работы с приватными данными, то возможен вариант, когда мы можем выйти из функции, не затерев этот буфер. Конечно, это притянуто за уши и вполне всё может работать. Однако, это не место для испытания удачи.

                              Если программист не работает с приватными данными, то ему следует просто отключите эту диагностику в настройках. А если работает, то надо править такие места, не пытаясь гадать удалится вызов или нет. Они потенциально опасны и этого достаточно.


                              1. rustler2000
                                29.12.2016 11:22

                                А можно выключить диагностику per function но чтобы оно на используемые макросы не влияло?


                                1. Andrey2008
                                  29.12.2016 11:28

                                  Нет. Но комментариями можно включать выключенные диагностики для файла.


                                  1. quzor
                                    29.12.2016 13:46

                                    Жаль, что продукте, который стоит > 5000 евро такой элементарной функции нет.


                                    1. Andrey2008
                                      29.12.2016 14:54
                                      +1

                                      Жаль, что продукте, который стоит > 5000 евро такой элементарной функции нет.

                                      Нет смысла заниматься таким микроупралвением. Зачем включать/выключать отдельные диагностики для отдельных функций? Это странно и опасно, так как в процессе редактирования кода можно забывать что-то включить. Для подавления предупреждений есть множество других механизмов, которые покрывают типовые сценарии. По крайней мере клиенты последнее время не просят добавлять какие-то новые режимы. Значит всё что действительно нужно, уже есть.


                              1. quzor
                                29.12.2016 13:51

                                Теоритически многое что может в этом мире произойти.
                                И эти люди пишут статический анализатор? Остановите поезд, я сойду.
                                Компилятор не переставит местами если массив будет использоваться.
                                А сказки про

                                Однако, это не место для испытания удачи.

                                просто смехотворны и зайдут только для далеких менеджеров.


                                1. Andrey2008
                                  29.12.2016 14:56
                                  +1

                                  Что именно смехотворно? То, что компилятор имеет право убрать/передвинуть вызов, на пока он допустим на месте и всё хорошо? Вы ещё мне расскажите, что memset() на месте всегда в нормальных компиляторах обязан быть.


  1. quzor
    27.12.2016 15:24
    +1

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


    1. EvgeniyRyzhkov
      27.12.2016 15:24

      Вы преувеличиваете про все ресурсы…


  1. springimport
    27.12.2016 16:45

    Мне кажется что на сайте не хватает отзывов.


    1. EvgeniyRyzhkov
      27.12.2016 18:53

      Вы имеете ввиду отзывы клиентов? Оказывается это не так просто. Разрешение на публикацию отзыва с реальным именем и компанией выдает чуть ли не президент компании. Это ОЧЕНЬ забюрократизированный момент, у пользователей есть прямой запрет на публикацию своего мнение от имени компании. А анонимные отзывы конечно никому не интересны.


    1. splav_asv
      28.12.2016 01:03

      Можно не от имени компании, а личное мнение, как пользователя. Являющегося сотрудником компании.


      1. EvgeniyRyzhkov
        28.12.2016 09:07

        Нельзя указывать название компании рядом с именем человека. В его контракте это явно прописано. А писать мнение John Doe о том, какой классный продукт — кого этим удивишь?


        1. splav_asv
          28.12.2016 11:58

          А это не противоречит конституции??? Свобода слова и тд… Человек же не говорит от имени компании, а от своего. Просто указывает место работы.


          1. EvgeniyRyzhkov
            28.12.2016 12:28

            Мне без разницы мнение жителей США о конституции РФ, но в трудовом контракте у них явно это записано и они не идут на это нарушение. Мы очень много про это общались с ними.


          1. splav_asv
            28.12.2016 13:25

            А с нашими?


            1. EvgeniyRyzhkov
              28.12.2016 13:41

              А с нашими нам не надо :-). Какое дело клиентам из Microsoft и Google о впечатлении Василия из ФГУП «Интеграл»?

              Мы все-таки на Европу/США работаем, поэтому приходится под их подстраиваться.


              1. quzor
                28.12.2016 14:44
                -1

                Мы все-таки на Европу/США работаем

                Но регулярно спамим все русскоязычные ресурсы.
                Л — Логика


  1. webkumo
    27.12.2016 19:29

    Опять сайт с прибитой гвоздями шириной? Доколе?!