News

How Visual Studio IntelliCode Helped Shape GitHub Copilot and Modern AI

Microsoft has baked advanced GitHub Copilot tech into the latest edition of Visual Studio, but the aging IntelliCode IDE feature actually helped shape the modern experience.

That shaping comes in the form of UX paradigms that originated specifically with IntelliCode -- introduced in 2018 -- and later became AI standards. In other words, the way a user interacts with Copilot and other AI coding assistants is based on the way IntelliCode worked.

This little side story is just one part of a fascinating new read about the history of Visual Studio, IntelliCode and GitHub Copilot, an Oct. 16 post titled "How we build GitHub Copilot into Visual Studio."

"IntelliCode was built before open standards for leveraging AI models had gained traction so much of the integration is bespoke," the team said. "However, IntelliCode helped inform UX paradigms that would be generally adopted for future AI interactions such as 'ghost text' for completions and 'tab to accept' for repeated edits." Indeed, those UX mechanisms for AI functionality are now being used in other IDEs and editors also.

Otherwise, today's post showcases the behind-the-scenes issues and decisions that need to be made in complex integration scenarios like adding Copilot AI to Visual Studio and its existing IntelliCode functionality that pioneered the field of automatic code-completion and other developer help. Since they work differently, the team had to decide which way to approach the project.

For example, Copilot functionality comes in two arbitrary flavors, completions and chat, with the latter being part of a follow-on Copilot X project that facilitates much more sophisticated developer interaction including code generation, explanations, and more.

The Visual Studio team decided to focus on chat, which led to many more benefits that continue to improve the developer experience via AI.

Basic 'Chat' Architecture
[Click on image for larger view.] Basic 'Chat' Architecture (source: Microsoft).

"The Visual Studio team set out to deeply integrate 'chat' functionality into Visual Studio," the team said. "This started with basic features like a chat tool window and inline chat; however, many other features have subsequently been added which leverage this 'chat' functionality, such as rename suggestions, generating commit and PR messages, helping to diagnose exceptions, etc."

That required some engineering work, basically creating .NET 8 processes instead of some Node or older .NET Framework processes used by IntelliCode. Those Node processes -- outside of the devenv.exe process used by Visual Studio and also IntelliCode -- were created to help facilitate development across various Copilot clients like JetBrains, but don't work well in the Visual Studio architecture.

That choice, also, paid off in other dividends.

"This architecture has allowed us to leverage/influence many .NET improvements, for example: server-sent events, System.Text.Json to JSON schema mapping, tokenizers, various aspects of semantic kernel, and others. This includes the recently announced Microsoft.Extensions.AI.Preview."

Another benefit is that the out-of-process .NET components can help the team leverage and inform new framework types in .NET 8/9 that help with the creation of "intelligent" AI-powered apps.

Considering all that, the Visual Studio integration with Copilot seems to be working much better than the integration with Copilot and Visual Studio's IntelliSense, the non-machine-learning precursor to IntelliCode. Instead of machine learning tech leveraged by IntelliCode and Copilot, IntelliSense used static code analysis and language semantics, which caused issues as detailed in the articles:

Anyway, the team is promising more exciting goodies coming up.

"This is a bit of the history and high-level architecture of GitHub Copilot integration in Visual Studio," the team said at the end of the lengthy, detailed post. "AI is progressing exceedingly rapidly and building on .NET is one way that the VS team can keep pace. There will be many enhancements, changes, benefits, and surprises in upcoming VS and GitHub Copilot releases, so keep an eye out!"

About the Author

David Ramel is an editor and writer at Converge 360.

comments powered by Disqus

Featured

  • The Science Behind User Interface Design

    UI design expert Billy Hollis helps developers and designers grasp the principles of the human visual system to create interfaces that are not only functional but also intuitive and engaging.

  • Random Forest Regression and Bagging Regression Using C#

    Dr. James McCaffrey from Microsoft Research presents a complete end-to-end demonstration of the random forest regression technique (and a variant called bagging regression), where the goal is to predict a single numeric value. The demo program uses C#, but it can be easily refactored to other C-family languages.

  • Compare New GitHub Copilot Free Plan for Visual Studio/VS Code to Paid Plans

    The free plan restricts the number of completions, chat requests and access to AI models, being suitable for occasional users and small projects.

  • Diving Deep into .NET MAUI

    Ever since someone figured out that fiddling bits results in source code, developers have sought one codebase for all types of apps on all platforms, with Microsoft's latest attempt to further that effort being .NET MAUI.

  • Copilot AI Boosts Abound in New VS Code v1.96

    Microsoft improved on its new "Copilot Edit" functionality in the latest release of Visual Studio Code, v1.96, its open-source based code editor that has become the most popular in the world according to many surveys.

Subscribe on YouTube