Build an VSCode Extension with ChatGPT

JavaScriptJavaScriptBeginner
Practice Now

Introduction

This project will guide you through the process of creating a VSCode extension that lets the user adjust the heading level of selected Markdown text. By the end, you'll have a functional extension that enhances the Markdown editing experience in Visual Studio Code.

๐Ÿ‘€ Preview

Extension Preview

๐ŸŽฏ Tasks

In this project, you will learn:

  • How to create the scaffolding for a VSCode extension using TypeScript.
  • How to integrate TypeScript with Node.js and VSCode configurations.
  • How to develop the core functionality to adjust heading levels of selected Markdown text.
  • How to write configuration files for building, debugging, and running the extension.

๐Ÿ† Achievements

After completing this project, you will be able to:

  • Design and develop VSCode extensions using TypeScript.
  • Handle user interactions and text selections within the VSCode environment.
  • Parse and manipulate Markdown syntax.
  • Generate and manage multiple files in a project.
  • Configure TypeScript, Node.js, and VSCode for seamless development.

Skills Graph

%%%%{init: {'theme':'neutral'}}%%%% flowchart RL javascript(("`JavaScript`")) -.-> javascript/BasicConceptsGroup(["`Basic Concepts`"]) javascript(("`JavaScript`")) -.-> javascript/AdvancedConceptsGroup(["`Advanced Concepts`"]) javascript(("`JavaScript`")) -.-> javascript/DOMManipulationGroup(["`DOM Manipulation`"]) javascript(("`JavaScript`")) -.-> javascript/ToolsandEnvironmentGroup(["`Tools and Environment`"]) javascript(("`JavaScript`")) -.-> javascript/NetworkingGroup(["`Networking`"]) javascript/BasicConceptsGroup -.-> javascript/variables("`Variables`") javascript/AdvancedConceptsGroup -.-> javascript/error_handle("`Error Handling`") javascript/DOMManipulationGroup -.-> javascript/dom_select("`DOM Selection`") javascript/DOMManipulationGroup -.-> javascript/dom_manip("`DOM Manipulation`") javascript/DOMManipulationGroup -.-> javascript/event_handle("`Event Handling`") javascript/ToolsandEnvironmentGroup -.-> javascript/debugging("`Debugging`") javascript/ToolsandEnvironmentGroup -.-> javascript/version_control("`Version Control`") javascript/NetworkingGroup -.-> javascript/http_req("`HTTP Requests`") javascript/NetworkingGroup -.-> javascript/api_interact("`API Interaction`") subgraph Lab Skills javascript/variables -.-> lab-445699{{"`Build an VSCode Extension with ChatGPT`"}} javascript/error_handle -.-> lab-445699{{"`Build an VSCode Extension with ChatGPT`"}} javascript/dom_select -.-> lab-445699{{"`Build an VSCode Extension with ChatGPT`"}} javascript/dom_manip -.-> lab-445699{{"`Build an VSCode Extension with ChatGPT`"}} javascript/event_handle -.-> lab-445699{{"`Build an VSCode Extension with ChatGPT`"}} javascript/debugging -.-> lab-445699{{"`Build an VSCode Extension with ChatGPT`"}} javascript/version_control -.-> lab-445699{{"`Build an VSCode Extension with ChatGPT`"}} javascript/http_req -.-> lab-445699{{"`Build an VSCode Extension with ChatGPT`"}} javascript/api_interact -.-> lab-445699{{"`Build an VSCode Extension with ChatGPT`"}} end

Install smol-ai

In addition, We make use of the smol-ai framework to generate code.

smol-ai description from the README:

This is a prototype of a "junior developer" agent (aka smol dev) that scaffolds an entire codebase out for you once you give it a product spec, but does not end the world or overpromise AGI. instead of making and maintaining specific, rigid, one-shot starters, like create-react-app, or create-nextjs-app, this is basically create-anything-app where you develop your scaffolding prompt in a tight loop with your smol dev.

We like smol-ai because of its simplicity. The entire code generation logic is in a single Python file consisting of three primary functions:

  1. generate a list of files that are needed to carry out the prompt (eg. package.json, index.js, ...)
  2. generate a list of shared dependencies that are needed to carry out the prompt (eg. axios, react, ...)
  3. for each file in the generated file list, generate code that would go into the file, making use of shared dependencies if applicable

Note that smol-ai also provides other capabilities like the ability to debug errors and generate a prompt based on the current code base.

Tasks

  1. Clone the smol-ai repository

    You need to clone the https://github.com/smol-ai/developer repository to the /home/labex/project directory.

  2. Configure smol-ai

    You need read the smol-ai README and configure the OpenAI API key.

โœจ Check Solution and Practice

Init This Extension

There is a basic prompt describing this project:

a vscode extension that lets the user adjust the heading level of the selected text. it should have three commands: increase heading level, decrease heading level, and set heading level

Note that the prompt is short and general. You can try to improve the prompt by adding more details about the project.

You can run smol-ai to generate the project. After a few minutes spent generating code, smol-ai created the files in the developer/generated directory.

Tasks

  1. Initialize the project

    View the smol-ai README, then using smol-ai to generate the project.

  2. Configure the project

    You need to view the generated code. If necessary, the prompt can be adjusted to regenerate.

Expected Result

There is a example of the generated code in the developer/generated directory. Your result may be different.

.
โ”œโ”€โ”€ extension
โ”‚ย ย  โ”œโ”€โ”€ package.json
โ”‚ย ย  โ”œโ”€โ”€ src
โ”‚ย ย  โ”‚ย ย  โ”œโ”€โ”€ commands
โ”‚ย ย  โ”‚ย ย  โ”‚ย ย  โ”œโ”€โ”€ decreaseHeadingLevel.ts
โ”‚ย ย  โ”‚ย ย  โ”‚ย ย  โ”œโ”€โ”€ increaseHeadingLevel.ts
โ”‚ย ย  โ”‚ย ย  โ”‚ย ย  โ””โ”€โ”€ setHeadingLevel.ts
โ”‚ย ย  โ”‚ย ย  โ””โ”€โ”€ extension.ts
โ””โ”€โ”€ shared_dependencies.md
โœจ Check Solution and Practice

Test This Extension

To test this extension, we need to successfully execute the following steps:

  1. Install Dependencies;
  2. Compile Code;
  3. Run Extension.

Install Dependencies

You need to run the following commands in the generated directory.

yarn

There may be some issues when installing dependencies. You need to fix the issues.

Tasks

  1. Fix the issues when installing dependencies.

    You can ask the AI to fix the issues.

Expected Result

When the issues are fixed, You may see the following example results.

$ yarn

...
[3/5] ๐Ÿšš Fetching packages...
[4/5] ๐Ÿ”— Linking dependencies...
[5/5] ๐Ÿ”จ Building fresh packages...
โœจ Done in 4.31s.
โœจ Check Solution and Practice

Build This Extension

Because typescript is a compiled language, we need to execute a build step to compile the code to javascript. The package.json comes with the following scripts:

"scripts": {
    "vscode:prepublish": "npm run compile",
    "compile": "tsc -p ./",
    "watch": "tsc -watch -p ./",
    "postinstall": "node ./node_modules/vscode/bin/install",
    "test": "npm run compile && node ./node_modules/vscode/bin/test"
},

We can build the code by running the following command:

tsc --init
yarn compile

There may be some issues when compiling the code. You need to fix the issues.

Tasks

  1. Fix the issues when compiling the code.

    You can ask the AI to fix the issues.

Expected Result

When the issues are fixed, You may see the following example results.

$ tsc -p ./
โœจ Done in 0.80s.
โœจ Check Solution and Practice

Run This Extension

Running a vscode extension requires that you go to the "Run and Debug" panel and launch the vscode extension task when the extension.ts file is active in the editor.

Run and Debug panel

There may be some issues when running the extension. You need to fix the issues.

Tasks

  1. Fix the issues when running the extension.

    You can ask the AI to fix the issues.

Expected Result

When the issues are fixed, You may see the extension running correctly.

extension running correctly
โœจ Check Solution and Practice

Summary

It works ๐Ÿฅณ

So how did we do? We got a working extension. We got it to accomplish the goal set out in our prompt.

The journey to this point was not "automatic". We ran into many issues along the way. Lacking prior knowledge of typescript, node.js and vscode, these issues would have taken a while to debug.

And even though the code we were able to generate working code, there are still many improvements to be made:

  • There are no instructions on how to develop, use, or publish the extension;
  • There is no .gitignore for typescript/javascript/vscode artifacts;
  • There is no launch.json file that configures running the extension in development;
  • There are no tests;
  • There is no code reuse.

Other JavaScript Tutorials you may like