From b9b052ec8d8d7b44ee90851b01cc91714615d895 Mon Sep 17 00:00:00 2001 From: Peter Lasne Date: Fri, 2 Jun 2023 08:06:03 -0400 Subject: [PATCH] added AI (#971) * added AI * added inline * some changes related to feedback * updated per feedback --------- Co-authored-by: Tess Ferrandez --- docs/developer-experience/code-completion.md | 60 ------------------ docs/developer-experience/copilots.md | 67 ++++++++++++++++++++ 2 files changed, 67 insertions(+), 60 deletions(-) delete mode 100644 docs/developer-experience/code-completion.md create mode 100644 docs/developer-experience/copilots.md diff --git a/docs/developer-experience/code-completion.md b/docs/developer-experience/code-completion.md deleted file mode 100644 index d9d95e826e..0000000000 --- a/docs/developer-experience/code-completion.md +++ /dev/null @@ -1,60 +0,0 @@ -# Code Completion - -Code completion is a feature used in live programming that actively reads the user's current code in context to present code suggestions in real-time. The code suggestions may be intended to complete the code for efficiency or improve the code quality. - -## Code Completion Tools - -### 1. GitHub Co-Pilot: A Code Completion Tool - -![GitHub Code Pilot](images/github-copilot.png) - -Benefits: - -- Autocompletion of verbose boilerplate code - - For example, constructors, getters, setters, and other common code - - Writing mocks for unit tests -- Auto-generated code suggestions based on: - - function names - - descriptive comments - - existing code -- Easy to get started, and works automatically -- Works with many common languages including Python, JavaScript, TypeScript, Ruby, Go, C#, or C++. - -Downsides: - -- Experience is limited in offline scenarios. - -Usage: - -Install the VS Code Extension, and log in to your Microsoft GitHub Account. - -Sign Up: - -[GitHub-CoPilot - Home Page](https://aka.ms/github/copilot) - -Docs: - -[GitHub-CoPilot - GitHub - Docs](https://docs.github.com/en/copilot) - -### 2. VS Code's Intellisense - -![Visual Studio Code - Intellisense](images/VSCode.png) - -Benefits: - -- Native feature of VS Code -- Works with many common languages out of the box (JavaScript, TypeScript, JSON, HTML, CSS, SCSS, and Less) -- Has a marketplace for additional code completion extensions needed for other languages like Python, C/C++, C#, Java, Go, plus more. -- Works offline - -Downsides: - -- Can conflict with GitHub CoPilot if both are enabled. - -Usage: - -Install the VS Code. Install additional extensions for additional language support. - -Docs: - -[VSCode Intellisense - Docs](https://code.visualstudio.com/docs/editor/intellisense) diff --git a/docs/developer-experience/copilots.md b/docs/developer-experience/copilots.md new file mode 100644 index 0000000000..dd253e3e63 --- /dev/null +++ b/docs/developer-experience/copilots.md @@ -0,0 +1,67 @@ +# Copilots + +There are a number of AI tools that can improve the developer experience. This article will discuss tooling that is available as well as advice on when it might be appropriate to use such tooling. + +## GitHub Copilot + +The current version of GitHub Copilot can provide code completion in many popular IDEs. For instance, the [VS Code extension](https://marketplace.visualstudio.com/items?itemName=GitHub.copilot) that can be installed from the VS Code Marketplace. It requires a GitHub account to use. For more information about what IDEs are supported, what languages are supported, cost, features, etc., please checkout out the information on [Copilot](https://github.com/features/copilot) and [Copilot for Business](https://resources.github.com/copilot-for-business/). + +Some example use-cases for GitHub Copilot include: + +- __Write Documentation__. For example, the above paragraph was written using Copilot. + +- __Write Unit Tests__. Given that setup and assertions are often consistent across unit tests, Copilot tends to be very accurate. + +- __Unblock__. It is often hard start writing when staring at a blank page, Copilot can fill the space with something that may or may not be what you ultimately want to do, but it can help get you in the right headspace. + +If you want Copilot to write something useful for you, try writing a comment that describes what your code is going to do - it can often take it from there. + +## GitHub Copilot Labs + +Copilot has a [GitHub Copilot Labs extension](https://marketplace.visualstudio.com/items?itemName=GitHub.copilot-labs) that offers additional features that are not yet ready for prime-time. For VS Code, you can install it from the VS Code Marketplace. These features include: + +- __Explain__. Copilot can explain what the code is doing in natural language. + +- __Translate__. Copilot can translate code from one language to another. + +- __Brushes__. You can select code that Copilot then modifies inline based on a "brush" you select, for example, to make the code more readable, fix bugs, improve debugging, document, etc. + +- __Generate Tests__. Copilot can generate unit tests for your code. Though currently this is limited to JavaScript and TypeScript. + +## GitHub Copilot X + +The next version of Copilot offers a number of new use-cases beyond code completion. These include: + +- __Chat__. Rather than just providing code completion, Copilot will be able to have a conversation with you about what you want to do. It has context about the code you are working on and can provide suggestions based on that context. Beyond just writing code, consider using chat to: + + - __Build SQL Indexes__. Given a query, ChatGPT can generate a SQL index that will improve the performance of the query. + + - __Write Regular Expressions__. These are notoriously difficult to write, but ChatGPT can generate them for you if you give some sample input and describe what you want to extract. + + - __Improve and Validate__. If you are unsure of the implications of writing code a particular way, you can ask questions about it. For instance, you might ask if there is a way to write the code that is more performant or uses less memory. Once it gives you an opinion, you can ask it to provide documentation validating that assertion. + +- __Explain__. Copilot can explain what the code is doing in natural language. + +- __Write Code__. Given prompting by the developer it can write code that you can one-click deploy into existing or new files. + +- __Debug__. Copilot can analyze your code and propose solutions to fix bugs. + +It can do most of what Labs can do with "brushes" as "topics", but whereas Labs changes the code in your file, the chat functionality just shows what it would change in the window. However, there is also an "inline mode" for GitHub Copilot Chat that allows you to make changes to your code inline which does not have this same limitation. + +## ChatGPT / Bing Chat + +For coding, generic AI chat tools such as ChatGPT and Bing Chat are less useful, but they still have their place. GitHub Copilot will only answer "questions about coding" and it's interpretation of that rule can be a little restrictive. Some cases for using ChatGPT or Bing Chat include: + +- __Write Documentation__. Copilot can write documentation, but using ChatGPT or Bing Chat, you can expand your documentation to include business information, use-cases, additional context, etc. + +- __Change Perspective__. ChatGPT can impersonate a persona or even a system and answer questions from that perspective. For example, you can ask it to explain what a particular piece of code does from the perspective of a user. You might have ChatGPT imagine it is a database adminstrator and ask it to explain how to improve a particular query. + +When using Bing Chat, experiment with modes, sometimes changing to Creative Mode can give the results you need. + +## Prompt Engineering + +Chat AI tools are only as good as the prompts you give them. The quality and appropriateness of the output can vary greatly depending on the prompt. In addition, many of these tools restrict the number of prompts you can send in a given amount of time. To learn more about prompt engineering, you might review some open source documentation [here](https://github.com/brexhq/prompt-engineering). + +## Considerations + +It is important when using AI tools to understand how the data (including private or commercial code) might be used by the system. Read more about how GitHub Copilot handles your data and code [here](https://resources.github.com/copilot-for-business/).