Для получения триального ключа
заполните форму ниже
Team License (базовая версия)
Enterprise License (расширенная версия)
* Нажимая на кнопку, вы даете согласие на обработку
своих персональных данных. См. Политику конфиденциальности

** На сайте установлена reCAPTCHA и применяются
Политика конфиденциальности и Условия использования Google.
Запросите информацию о ценах
Новая лицензия
Продление лицензии
--Выберите валюту--
USD
EUR
GBP
RUB
* Нажимая на кнопку, вы даете согласие на обработку
своих персональных данных. См. Политику конфиденциальности

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

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

** На сайте установлена reCAPTCHA и применяются
Политика конфиденциальности и Условия использования Google.
Мне интересно попробовать плагин на:
* Нажимая на кнопку, вы даете согласие на обработку
своих персональных данных. См. Политику конфиденциальности

** На сайте установлена reCAPTCHA и применяются
Политика конфиденциальности и Условия использования Google.
Ваше сообщение отправлено.

Мы ответим вам на


Если вы так и не получили ответ, пожалуйста, проверьте папку
Spam/Junk и нажмите на письме кнопку "Не спам".
Так Вы не пропустите ответы от нашей команды.

>
>
Visual Studio отказывается от поддержки…

Visual Studio отказывается от поддержки Add-In расширений в Community Previews 14

05 Авг 2014

Не так давно Microsoft показала широкой общественности, как будет выглядеть следующая версия Visual Studio, сейчас известная под именем Visual Studio 14 CTP (Community Technology Preview). После установки последней доступной версии CTP, одним из первых, что сразу бросилось мне в глаза, стало исчезновение пункта Add-In Manager в меню Tools. Прошёл уже год с тех пор, как Add-In плагины были официально объявлены deprecated в Visual Studio 2013, и вот похоже, что в новой версии студии их поддержка будет окончательно прекращена.

Для тех, кто незнаком с нюансами разработки плагинов для Visual Studio, следует уточнить, что под Add-In'ами в данном контексте мы понимаем разновидность модулей расширения (проще - plug-in'ов) для Visual Studio. Данный тип плагинов появился в Visual Studio достаточно давно. С тех пор появились и другие возможности расширить стандартный функционал Visual Studio, как дополняющие то, что могут делать Add-In'ы, так и дублирующие их возможности, но в более удобном для разработчиков и конечных пользователей виде (MPF, VSPackage, MEF). Не станем сейчас заострять внимание на этих моментах, скажу лишь, что вы можете более детально изучить вопрос расширения среды Visual Studio в нашей серии статей, посвящённой этой тематике.

Продукт PVS-Studio, помимо непосредственно самого C++ анализатора, включает в себя плагины для интеграции в несколько разных IDE, и в первую очередь, конечно, в Visual Studio. Когда-то, во времена первых версий PVS-Studio, для интеграции с Visual Studio мы использовали Add-In плагины. Однако уже достаточно давно мы мигрировали все наши проекты на формат плагина VSPackage.

Понятно, что для разработчиков расширений к Visual Studio, которые всё ещё используют Add-In для интеграции в среду разработки (а такие плагины, как ни странно, до сих пор существуют и развиваются), наступает время мигрировать свои проекты на более современный формат. Однако, меня больше заинтересовал вопрос – может ли планируемый отказ Microsoft от дальнейшей поддержки Add-in создать какие-то проблемы для нас – т.е. тех, кто уже использует формат VSPackage в своих продуктах.

На первый взгляд – проблем возникнуть не должно. Ведь маловероятно, что в обозримом будущем Microsoft откажется от поддержки VSPackage, хотя бы потому, что значительная часть стандартных компонентов Visual Studio реализована как раз в таком формате. Однако, этот комментарий к данной новости от Карлоса Квинтеро (Carlos Quintero, MVP, специализирующийся на тематике Microsoft Extensibility), заставил меня задуматься и взглянуть на данную проблему под несколько другим углом.

В частности, нашему плагину для запуска статического анализа на файлах проекта требуется собрать об этих файлах всю информацию, касающуюся их построения – параметры запуска компилятора, параметры конфигураций проекта и т.п. Для этого плагин использует интерфейсы из объекта EnvDTE – "верхнего" интерфейса модели автоматизации Visual Studio. Однако, модель автоматизации Visual Studio изначально создавалась как раз для поддержки макросов и Add-In'ов, и появилась она ещё в первой Visual Studio.NET 2002, VSPackage появились несколько позже. Итак, поддержка макросов исчезла в Visual Studio 2012, поддержка Add-in'ов скорее всего пропадёт в грядущей версии... что же дальше? Не решит ли Microsoft в один "прекрасный момент" отказаться и от EnvDTE целиком, тем более всё больше компонентов Visual Studio уже используют WPF, MEF, интерфейсы MPF (тот же Package, описывающий VSPackage плагин) и службы среды. EnvDTE же может стать (а возможно, и уже стал) лишним промежуточным слоем, оставленным лишь для совместимости.

Нужно сказать, что мы серьёзно ещё не рассматривали вариант полного отказа от интерфейсов из EnvDTE. Я лично, например, не представляю на данный момент, как можно более удобно (ну или хотя бы так же удобно) обходить дерево проекта, получать списки всех необходимых файлов и их параметры сборки, без использования таких интерфейсов, как VCProject и ProjectItem. Тем более, что конкретно PVS-Studio должна поддерживать такие старые версии Visual Studio, как 2005 и 2008, в которых ещё не используется проектная модель vcxproj, основанная на MSBuild (т.е. интерфейсы из Microsoft.Build там не помогут). Это вопрос, безусловно, требует отдельного и детального изучения.

Но одновременно нельзя сказать, что мы совсем не готовы к такому развитию событий. В своей заметке (на которую я давал ссылку выше), Карлос Квинтеро предлагает отделять код, непосредственно использующий API студии от остального кода плагина – бизнес логики, пользовательских интерфейсов и т.п. При необходимости перехода на новый API, такой подход позволит сохранить большую часть кода неизменной, создав лишь новую "прослойку" для других интерфейсов среды.

Наш плагин (или говоря точнее - плагины) уже пошли по аналогичному пути ещё несколько лет назад, правда вызвано это было другой причиной - необходимостью обеспечить поддержку нескольким средам разработки, помимо Visual Studio. И хотя коммерческий результат от поддержки этих сред (и в частности, RAD Studio \ C++ Builder) оставляет желать лучшего, данный подход позволил нам в дальнейшем легко создать на основе кода плагинов независимый инструмент для анализа C++ проектов и работы с логами проверки – PVS-Studio Standalone, и в будущем, если до этого дойдёт, позволит нам чуть менее болезненно провести миграцию с интерфейсов EnvDTE.

Популярные статьи по теме
Технологии, используемые в анализаторе кода PVS-Studio для поиска ошибок и потенциальных уязвимостей

Дата: 21 Ноя 2018

Автор: Андрей Карпов

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

Дата: 22 Окт 2018

Автор: Андрей Карпов

PVS-Studio, как и другие статические анализаторы кода, часто выдаёт ложные срабатывания. Но не стоит спешить считать странные срабатывания ложными. Это короткая история о том, как PVS-Studio вновь ок…
Зло живёт в функциях сравнения

Дата: 19 Май 2017

Автор: Андрей Карпов

Возможно, читатели помнят мою статью под названием "Эффект последней строки". В ней идёт речь о замеченной мной закономерности: ошибка чаще всего допускается в последней строке однотипных блоков текс…
Характеристики анализатора PVS-Studio на примере EFL Core Libraries, 10-15% ложных срабатываний

Дата: 31 Июл 2017

Автор: Андрей Карпов

После большой статьи про проверку операционной системы Tizen мне было задано много вопросов о проценте ложных срабатываний и о плотности ошибок (сколько ошибок PVS-Studio выявляет на 1000 строк кода)…
PVS-Studio ROI

Дата: 30 Янв 2019

Автор: Андрей Карпов

Время от времени нам задают вопрос, какую пользу в денежном эквиваленте получит компания от использования анализатора PVS-Studio. Мы решили оформить ответ в виде статьи и привести таблицы, которые по…
Главный вопрос программирования, рефакторинга и всего такого

Дата: 14 Апр 2016

Автор: Андрей Карпов

Вы угадали, ответ - "42". Здесь приводится 42 рекомендации по программированию, которые помогут избежать множества ошибок, сэкономить время и нервы. Автором рекомендаций выступает Андрей Карпов - тех…
Как и почему статические анализаторы борются с ложными срабатываниями

Дата: 20 Мар 2017

Автор: Андрей Карпов

В своей предыдущей статье я писал, что мне не нравится подход, при котором статические анализаторы кода оцениваются с помощью синтетических тестов. В статье приводился пример, воспринимаемый анализат…
Бесплатный PVS-Studio для тех, кто развивает открытые проекты

Дата: 22 Дек 2018

Автор: Андрей Карпов

В канун празднования нового 2019 года команда PVS-Studio решила сделать приятный подарок всем контрибьюторам open-source проектов, хостящихся на GitHub, GitLab или Bitbucket. Им предоставляется возмо…
Эффект последней строки

Дата: 31 Май 2014

Автор: Андрей Карпов

Я изучил множество ошибок, возникающих в результате копирования кода. И утверждаю, что чаще всего ошибки допускают в последнем фрагменте однотипного кода. Ранее я не встречал в книгах описания этого …
PVS-Studio для Java

Дата: 17 Янв 2019

Автор: Андрей Карпов

В седьмой версии статического анализатора PVS-Studio мы добавили поддержку языка Java. Пришло время немного рассказать, как мы начинали делать поддержку языка Java, что у нас получилось и какие дальн…

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

Следующие комментарии

На сайте установлена reCAPTCHA и применяются
Политика конфиденциальности и Условия использования Google.
Этот сайт использует куки и другие технологии, чтобы предоставить вам более персонализированный опыт. Продолжая просмотр страниц нашего веб-сайта, вы принимаете условия использования этих файлов. Если вы не хотите, чтобы ваши данные обрабатывались, пожалуйста, покиньте данный сайт. Подробнее →
Принять