- 4,931
- 6,662
В сети крайне мало толковых билдов под C++. В основном хорошие билды только на web-разработку. В результате расширения очень долго собирались в попытках найти что-то полезное в тонне софта на маркетплейсе, а так же из рекомендаций в рандомных источниках, типа LLVM-канала в ДС. При чем что самое странное - некоторые из расширений очень плохо ищутся по тегу C++ на маркетплейсе, при том, что являются популярными (и при этом их так же нет в подборках).
Сначала пройдусь по C++ экстеншенам, а в конце докину всякого на юзабилити.
Если решили оставлять расширение ради кнопочки дебага с авто-сгенерированым конфигоом, то отключайте Intelli Sense Engine:
clangd не имеет интеграции с CMake и другими системами сборки, так что для него надо экспортировать compile_commands.json (у CMake это флаг
Замечание: clangd и C-mantic оба имеют функцию переключения между исходником и заголовком, но C-mantic делает это лучше, когда файлы находятся в разных папках
Для поддержки doxygen-документации добавьте в конфиг clangd (
Дополнительные расширения для clangd:
CodeLLDB крут тем, что это очень качественная обертка над lldb — можно задать команды инициализации и даже больше:
Более медленные проверки, такие как утечки памяти можно запустить через CodeChecker
CodeChecker поддерживает следующие анализаторы:

P.S. clang из дефолтной поставки android-ndk не умеет в CTU (утечки не найдет)

Требует что бы в PATH, или по одному пути с компилятором была утилита c++filt. Для подсветки кода нужно ставить отдельное расширение для asm

std::format placeholder highlighter - подсветка фигурных скобок для std::format
Color Identifiers - семантическая подсветка (советую в tokenKinds оставить только variable и parameter)
Doxygen Documentation Generator - подсветка doxygen-документации в комментариях, а так же генерация блоков для документации
Error Lens - вывод ошибок слева от строки с кодом, как в QtCreator
Build Output Colorizer - подсветка кода и ошибок, которые выводятся в окно OUTPUT (у CMake будет нормально показывать ошибки компиляции)
TaskNotify (Fork) - вывод уведомлений о завершении тасков
Automatic Editor Sorter - автоматичская сортировка вкладок по алфовиту
cmake-build - дополнение для расширения от Microsoft - выводит уведомления об успешной/неуспешной сборке и открывает вывод CMake в случае ошибок
Windsurf [устарело] - AI-ассистент с чатом и автокомплитом
Сначала пройдусь по C++ экстеншенам, а в конце докину всякого на юзабилити.
Языковой сервер
Microsoft C/C++ - идет нахуй, ну или почти
Расширение из коробки нормально работает с CMake от того же Microsoft, но оно имеет не очень хороший анализатор кода:- медленный
- очень медленный если надо что-то порефакторить или найти ссылки
- не всегда показывает результат compile-time выражений
- часто не правильно разбирает исходники, показывая ошибки там где их нет (особенно часто при кросскомпиляции)
Если решили оставлять расширение ради кнопочки дебага с авто-сгенерированым конфигоом, то отключайте Intelli Sense Engine:
JSON:
{
"C_Cpp.intelliSenseEngine": "Disabled"
}
Настоящий языковой сервер C++
clangd и C-mantic — вместе дают защеку некоторым большим IDE, типа CLion. При том, что второй даже не надо настраиватьclangd не имеет интеграции с CMake и другими системами сборки, так что для него надо экспортировать compile_commands.json (у CMake это флаг
-DCMAKE_EXPORT_COMPILE_COMMANDS=1)Замечание: clangd и C-mantic оба имеют функцию переключения между исходником и заголовком, но C-mantic делает это лучше, когда файлы находятся в разных папках
Для поддержки doxygen-документации добавьте в конфиг clangd (
.clangd в корне проекта):
YAML:
Documentation:
CommentFormat: doxygen
Дополнительные расширения для clangd:
- clangd: CMake integration — интеграция с CMake Tools: передаёт модель сборки напрямую в clangd, избавляя от необходимости экспортировать compile_commands.json вручную
- clangd Non-Self-Contained Header Hook — убирает ложные ошибки в non-self-contained заголовках, подставляя синтетическую преамбулу из включающих единиц трансляции
- clangd: Open documentation — открытие документации (cppreference.com, boost.org и других настраиваемых источников) по Shift+F1 на функции или типе
Патченная версия сервера clangd с дополнительными возможностями. В качестве клиентского расширения используется стандартное.
Сервер:
Все версии патченого сервера: https://nc.sr.team/s/YbgbaJ2DwqPGXJe
Установка:
Для винды распаковываете сервер куда вам удобно, а для ArchLinux он ставится по пути
После этого в настройках расширения clangd указываете путь к серверу
Фичи патченого clangd:
1. CodeLens — добавляет над функциями, классами и типами ссылки на использование/наследования (при клике показывает все ссылки)
Отключить можно добавив в настройках расширения аргумент

2. Postfix completion — добавляет в автодополнение виртуальные операции для генерации свитчей, циклов и кастов
Видео-демка (смотреть обязательно — топ фича от sammcall)
3. inlay hints для паддингов

4. Отображение размеров и оффсетов в HEX, когда значение больше 10

5. Отображение масок для битовых полей (IDA показывает их через маски)

6. Отображение оффсета и размера указателя на функцию в виртуальной таблице

7. Отображение суммарного количества всех паддингов в структуре

8. Подписывание имен аргументов для функций врапперов

9. Если есть вызов шаблонного типа, то он диагностируется с первым вариантом вызова (без компиляции)
10. Поддержка hoisting-функций для оборачивания выделенного кода в новую функцию
Сервер:
- ArchLinux AUR (всегда самая актуальная версия)
- Бинарные версии (лучше собирать самому из AUR):
- Windows:
Все версии патченого сервера: https://nc.sr.team/s/YbgbaJ2DwqPGXJe
Установка:
Для винды распаковываете сервер куда вам удобно, а для ArchLinux он ставится по пути
/opt/clangd/bin/clangdПосле этого в настройках расширения clangd указываете путь к серверу
Фичи патченого clangd:
1. CodeLens — добавляет над функциями, классами и типами ссылки на использование/наследования (при клике показывает все ссылки)
Отключить можно добавив в настройках расширения аргумент
--code-lens=false
2. Postfix completion — добавляет в автодополнение виртуальные операции для генерации свитчей, циклов и кастов
Видео-демка (смотреть обязательно — топ фича от sammcall)
3. inlay hints для паддингов

4. Отображение размеров и оффсетов в HEX, когда значение больше 10

5. Отображение масок для битовых полей (IDA показывает их через маски)

6. Отображение оффсета и размера указателя на функцию в виртуальной таблице

7. Отображение суммарного количества всех паддингов в структуре

8. Подписывание имен аргументов для функций врапперов

9. Если есть вызов шаблонного типа, то он диагностируется с первым вариантом вызова (без компиляции)
10. Поддержка hoisting-функций для оборачивания выделенного кода в новую функцию
Поиск ошибок
Отладчик
Как говорилось выше, можно оставить Microsoft C/C++, но есть так же крутое расширение CodeLLDBCodeLLDB крут тем, что это очень качественная обертка над lldb — можно задать команды инициализации и даже больше:
- можно генерировать HTML через брейкпоинты строя графики, или записывая логи;
- поддерживается reverse-отладка (когда выполнение кода откатывается назад)
- удаленная отладка (например под android)
Статический анализатор
clangd уже имеет часть аналитик от clang-static-analyzer и интеграцию с clang-tidy, но там доступны только быстрые проверкиБолее медленные проверки, такие как утечки памяти можно запустить через CodeChecker
CodeChecker поддерживает следующие анализаторы:
- clang-static-analyzer
- clang-tidy
- cppcheck
- gcc-static-analyzer (выключен по умолчанию, и подходит в основном только для C)

P.S. clang из дефолтной поставки android-ndk не умеет в CTU (утечки не найдет)
CodeCoverage или просмотр посещенных/не посещенных участков кода при выполнении
Coverage Gutters выводит информацию из lcov файлов, а сами lcov файлы можно сгенерировать при помощи Lcov Generator (он поддерживает интеграцию с CMake и launch.json)
Данный сниппет включает генерацию profraw/gcda файлов, которые содержат информацию о строках кода, посещенных во время выполнения программы
Использовать примерно так:
Ну и конфигурировать проект с ключом
Makefile:
include( CheckCXXCompilerFlag )
include( CheckLinkerFlag )
function( configure_coverage target )
check_cxx_compiler_flag( "-fprofile-instr-generate -fcoverage-mapping" COMPILER_SUPPORT_LLVM_COVERAGE )
check_linker_flag( CXX "-fprofile-instr-generate" LINKER_SUPPORT_LLVM_COVERAGE )
if( COMPILER_SUPPORT_LLVM_COVERAGE AND LINKER_SUPPORT_LLVM_COVERAGE )
target_compile_options( ${target} PUBLIC -fprofile-instr-generate -fcoverage-mapping )
target_link_options( ${target} PUBLIC -fprofile-instr-generate )
else()
check_cxx_compiler_flag( "-ftest-coverage" COMPILER_SUPPORT_GNU_COVERAGE )
check_linker_flag( CXX "--coverage" LINKER_SUPPORT_GNU_COVERAGE )
if( COMPILER_SUPPORT_GNU_COVERAGE AND LINKER_SUPPORT_GNU_COVERAGE )
target_compile_options( ${target} PUBLIC -fprofile-arcs -ftest-coverage )
target_link_options( ${target} PUBLIC --coverage )
if( ${CMAKE_CXX_COMPILER_ID} STREQUAL "Clang" )
message( WARNING "Clang generate old format of Gcov and it may be incompatible with you toolchains." )
endif()
endif()
endif()
endfunction()
Использовать примерно так:
Makefile:
add_executable( main main.cpp )
if( main_USE_COVERAGE )
configure_coverage( main )
endif()
-D main_USE_COVERAGE=YESCompiler Explorer или просмотр дизассемблера исходного кода без запуска отладки
C/C++ Compiler explorer компилирует текущий файл в ASM и включает line-by-line отображение.Требует что бы в PATH, или по одному пути с компилятором была утилита c++filt. Для подсветки кода нужно ставить отдельное расширение для asm

Патченная версия с возможностью задать свои аргументы для генерации asm-кода:
Так же в аргументы можно подкинуть grep через пайп, что бы порезать лишнее и ускорить парсинг (расширение все парсит регексами)
Так же в аргументы можно подкинуть grep через пайп, что бы порезать лишнее и ускорить парсинг (расширение все парсит регексами)
Юзабилити
Генерация кода
VS Code C++ class generation tool - создание классов через ПКМ по папке (можно создавать сразу пару и .h и .cpp файлов)Подсветка кода
Better C++ Syntax - фикс подсветки C++ кода. Так же может использоваться другими расширениями, такими как следующееstd::format placeholder highlighter - подсветка фигурных скобок для std::format
Color Identifiers - семантическая подсветка (советую в tokenKinds оставить только variable и parameter)
Doxygen Documentation Generator - подсветка doxygen-документации в комментариях, а так же генерация блоков для документации
Error Lens - вывод ошибок слева от строки с кодом, как в QtCreator
Build Output Colorizer - подсветка кода и ошибок, которые выводятся в окно OUTPUT (у CMake будет нормально показывать ошибки компиляции)
Таски
Tasks - вывод тасков в статусбар (можно выводить не все, выводить группой, а так же задавать иконки и тултипы)TaskNotify (Fork) - вывод уведомлений о завершении тасков
Поведение VSCode
Auto Hide (fork) - автоматическое скрытие нижней панели и сайдбаров (можно настроить, что бы все скрывалось по отдельности)Automatic Editor Sorter - автоматичская сортировка вкладок по алфовиту
cmake-build - дополнение для расширения от Microsoft - выводит уведомления об успешной/неуспешной сборке и открывает вывод CMake в случае ошибок
GIT
Git Graph - отображение коммитов в виде графа. Оттуда же их можно черипикать и мерджить веткиAI
NESweep - локальное AI-решение для автодополнения кода. Форк Sweep AI с поддержкой llama.cpp/ollama бекендов и трёх типов моделей: sweep, zeta2 и zeta2.1Windsurf [устарело] - AI-ассистент с чатом и автокомплитом
Вложения
Последнее редактирование: