Streamline C++ Code Intelligence Setup in Copilot CLI Microsoft released a setup LSP skill for the C++ language server plugin in Copilot CLI, enabling developers to generate compile_commands.json for CMake, MSBuild, and custom build systems. The skill simplifies configuring IDE-style semantic intelligence for code navigation, diagnostics, and code changes outside the IDE. C++ developers can now bring IDE-style semantic intelligence into Copilot CLI with less setup. The C++ language server plugin https://github.com/microsoft/cpp-language-server/ supports richer code navigation, diagnostics, symbol understanding, and code changes by using the same build context your compiler does. That build context usually comes from a compile commands.json file, which tells the language server how each source file is compiled. Instead of manually wiring that file together, the C++ language server plugin now provides a setup LSP skill https://github.com/microsoft/cpp-language-server/blob/main/plugins/cpp-language-server/skills/generate-compile-commands/SKILL.md that can help generate or refresh compile commands for common project types, including CMake and MSBuild. For custom build systems, teams can still provide their own compile commands.json file or create a project-specific skill https://github.com/microsoft/cpp-language-server/blob/main/AUTHORING EXTRACTOR SKILL.md that captures their build setup once and makes it repeatable. To get started with the C++ language server for Copilot CLI, please download via the Copilot Plugins https://github.com/github/copilot-plugins marketplace and follow the Quick Start guide in the repo https://github.com/microsoft/cpp-language-server/ -quick-start to accept EULA and configure compile commands.json : /plugin install cpp-language-server@copilot-plugins Whether your project uses CMake, MSBuild, or a custom build pipeline, the goal is the same: make it easier for you to configure the C++ language server for Copilot CLI so Copilot can provide better navigation, diagnostics, explanations, and code changes, even when you’re outside the IDE. Fill out form https://forms.office.com/Pages/ResponsePage.aspx?id=v4j5cvGGr0GRqy180BHbR3y0EFonU1lFoDzxL3GpYptUNDg0MzRWVkUyU0wxOU5BNEZXTkdFTFA3NC4u Configuring the language server The language server needs a compile commands.json file to understand your project. If you do not already have one generated via your build, you can utilize the skill to generate this for you. To generate compile commands, type “regenerate compile commands” or “load project” in Copilot CLI, based on your desired configuration and platform if necessary . See “Recommended configuration path by project type” section below for suggestions based on your project build configuration. Note: If your configuration changes, the skill should be re-invoked to regenerate your compile commands.json to keep the LSP server in sync. The LSP server will automatically watch for changes to the compile commands.json file. Recommended configuration path by project type CMake projects For CMake-based projects, if you don’t have a compile commands.json already generated from your CMake builds. the recommended path is to use the skill to onboard the project to generate compile commands.json . You can also generate a compile commands.json by passing set to “ -DCMAKE EXPORT COMPILE COMMANDS https://cmake.org/cmake/help/latest/variable/CMAKE EXPORT COMPILE COMMANDS.html TRUE ” when configuring CMake. CMake has native support for compile command generation and the skill can help configure the project, so the language server has the compilation database it needs. MSBuild projects For MSBuild-based projects, users have two options. For teams that want a guided setup, the skill can still help onboard the project by producing the configuration needed for the language server. However, if you’d like to generate your own compile commands, you can refer to this sample application https://github.com/microsoft/msbuild-extractor-sample for an example of how to generate compile commands.json from MSBuild projects. While the sample application is designed to work out-of-the-box for many projects, it may require adaptation for complex projects. Custom build systems Custom builds often use hermetic, vendored, or wrapper-based toolchains that standard discovery cannot always detect. For teams with custom toolchains, a project-specific skill https://docs.github.com/en/copilot/concepts/agents/about-agent-skills can capture the setup once and make it repeatable. The detailed guidance provided in the cpp-language-server repo https://github.com/microsoft/cpp-language-server/blob/main/README.md covers when custom configuration is needed, what settings to pin, and how to structure a skill so Copilot can regenerate compile commands reliably. It is especially useful for repositories where the default extractor produces incomplete output, picks up the wrong toolchain, or needs to run through a repo-provided build environment. Getting started with the Microsoft C++ language server The Microsoft C++ language server is available as a Copilot CLI plugin and runs on Windows, Linux, and macOS. An active GitHub Copilot subscription https://github.com/features/copilot/plans?ref cta=See+pricing+and+plans&ref loc=hero&ref page=%2Ffeatures copilot copilot ai code editor&cft=copilot li.features copilot is required. To get started, install the C++ language server plugin from the Copilot Plugins marketplace and follow the Quick Start guide https://github.com/microsoft/cpp-language-server/ -quick-start : /plugin install cpp-language-server@copilot-plugins The Microsoft C++ language server requires a small amount of setup so it can understand your project the same way your compiler does: - Authenticate with GitHub Copilot CLI - Provide or generate a compile commands.json file for your project Share your feedback Let us know your feedback and if there’s anything else you’d like to see. Help us improve the Microsoft C++ server for Copilot CLI by filling out this short survey: Fill out form https://forms.office.com/Pages/ResponsePage.aspx?id=v4j5cvGGr0GRqy180BHbR3y0EFonU1lFoDzxL3GpYptUNDg0MzRWVkUyU0wxOU5BNEZXTkdFTFA3NC4u . To report a problem or suggest an improvement, open an issue https://github.com/microsoft/cpp-language-server/ -reporting-feedback in our GitHub repo.