|
| 1 | +--- |
| 2 | +title: 'Use agent mode (Preview)' |
| 3 | +description: Use GitHub Copilot Agent to iterate on code in Visual Studio by making code edits, running commands, and reading error/build context. |
| 4 | +ms.date: 5/13/2025 |
| 5 | +ms.topic: get-started |
| 6 | +author: anandmeg |
| 7 | +ms.author: meghaanand |
| 8 | +ms.manager: mijacobs |
| 9 | +ms.subservice: ai-tools |
| 10 | +ms.collection: ce-skilling-ai-copilot |
| 11 | +monikerRange: '>= vs-2022' |
| 12 | +--- |
| 13 | +# Use Copilot agent mode in Visual Studio (Preview) |
| 14 | + |
| 15 | +With GitHub Copilot's agent mode in Visual Studio, you can use natural language to specify a high-level task. AI will then autonomously reason through the request, plan the work needed, and apply the changes to your codebase. Agent mode combines code editing and tool invocation to accomplish the task you specified. As it processes your request, it monitors the outcome of edits and tools, and iterates to resolve any issues that arise. |
| 16 | + |
| 17 | +The key difference from Copilot Chat is that agent mode can: |
| 18 | + |
| 19 | +* Run commands and builds to interpret the environment or execute a task (for example, database migrations, dotnet restore, etc.). |
| 20 | +* Iterate on errors, failed builds, or unit test results until it either requires additional input or considers the task complete. |
| 21 | + |
| 22 | +## Prerequisites |
| 23 | + |
| 24 | ++ [Visual Studio 2022 version 17.14](/visualstudio/releases/2022/release-history) or later. |
| 25 | ++ [Sign in to Visual Studio using a GitHub account](work-with-github-accounts.md) with [Copilot access](https://docs.github.com/en/copilot/about-github-copilot/what-is-github-copilot#getting-access-to-copilot). <br/> |
| 26 | + + You can use [GitHub Copilot for Free](copilot-free-plan.md). Sign up and leverage AI to code faster and more efficiently. |
| 27 | + |
| 28 | +## Get started with agent mode |
| 29 | + |
| 30 | +To get started with Copilot agent mode in Visual Studio, enable the feature in **Tools** > **Options** > **GitHub** > **Coplit** > **Copilot Chat** > **Enable agent mode in the chat pane**. |
| 31 | + |
| 32 | +## Use agent mode |
| 33 | + |
| 34 | +In agent mode, Copilot operates autonomously and determines the relevant context for your prompt. |
| 35 | + |
| 36 | +Follow these steps to get started: |
| 37 | + |
| 38 | +1. Ensure agent mode is enabled by selecting **Enable agent mode in the chat pane** in **Tools** > **Options** > **GitHub** > **Copilot** > **Copilot Chat**. |
| 39 | + |
| 40 | + :::image type="content" source="media/vs-2022/copilot-agent/copilot-agent-setting-updated.png" alt-text="Screenshot that shows the enable agent mode setting in Options." lightbox="media/vs-2022/copilot-agent/copilot-agent-setting-updated.png"::: |
| 41 | + |
| 42 | +2. Open the Copilot Chat window, select **Ask** to expand the mode dropdown, and then select **Agent**. |
| 43 | + |
| 44 | + :::image type="content" source="media/vs-2022/copilot-agent/copilot-agent-dropdown.png" alt-text="Screenshot that shows Copilot agent mode selector." lightbox="media/vs-2022/copilot-agent/copilot-agent-dropdown.png"::: |
| 45 | + |
| 46 | +3. Enter your prompt for making edits in the chat input field and select **Send** or press **Enter** to submit it. You can specify a high-level requirement, and you don't have to specify which files to work on. In agent mode, Copilot determines the relevant context and the files to edit autonomously. |
| 47 | + |
| 48 | +4. Agent mode might invoke multiple tools to accomplish different tasks. Optionally, select the **Tools** icon to configure which additional tools can be used for responding to your request. |
| 49 | + |
| 50 | + :::image type="content" source="media/vs-2022/copilot-agent/copilot-agent-tools.png" alt-text="Screenshot that shows additional tools used by agent mode." lightbox="media/vs-2022/copilot-agent/copilot-agent-tools.png"::: |
| 51 | + |
| 52 | +5. Confirm tool invocations and terminal commands. Before running a terminal command or a non-builtin tool, Copilot requests confirmation to continue. This is because tools might run locally on your machine and perform actions that modify files or data. |
| 53 | + |
| 54 | + :::image type="content" source="media/vs-2022/copilot-agent/copilot-agent-command-approval.png" alt-text="Screenshot that shows agent command approval." lightbox="media/vs-2022/copilot-agent/copilot-agent-command-approval.png"::: |
| 55 | + |
| 56 | +6. Copilot detects issues and problems in code edits and terminal commands, and then iterates and performs additional actions to resolve them. For example, agent mode might run unit tests as a result of a code edit. If the tests fail, it uses the test outcome to resolve the issue. Copilot agent mode iterates multiple times to resolve issues and problems. |
| 57 | + |
| 58 | +7. As Copilot processes your request, notice that Copilot streams the suggested code edits directly in the editor. Review the suggested edits and either keep or discard the suggested edits as a whole in **Total Changes** in the chat window, or individually by clicking on a file and reviewing the code diffs presented in the editor. |
| 59 | + |
| 60 | + :::image type="content" source="media/vs-2022/copilot-agent/copilot-agent-keep-undo.png" alt-text="Screenshot that shows the list of suggested edits." lightbox="media/vs-2022/copilot-agent/copilot-agent-keep-undo.png"::: |
| 61 | + |
| 62 | +8. If you want to review individual code changes made by the agent, you can either review the specific change made at each step, or review the cumulative changes from the last time changes were kept or undone. |
| 63 | + |
| 64 | + :::image type="content" source="media/vs-2022/copilot-agent/copilot-agent-stepwise-edits.png" alt-text="Screenshot that shows accessing individual edit diffs with Copilot agent." lightbox="media/vs-2022/copilot-agent/copilot-agent-stepwise-edits.png"::: |
| 65 | + |
| 66 | + :::image type="content" source="media/vs-2022/copilot-agent/copilot-agent-cumulative-edits.png" alt-text="Screenshot that shows accessing cumulative edit diffs with Copilot agent." lightbox="media/vs-2022/copilot-agent/copilot-agent-cumulative-edits.png"::: |
| 67 | + |
| 68 | +9. Continue to iterate on the code changes to refine the edits or implement additional features. |
| 69 | + |
| 70 | +## Agent mode tools |
| 71 | + |
| 72 | +Agent mode can use the following tools: |
| 73 | + |
| 74 | +* Built-in tools |
| 75 | +* [MCP tools](mcp-servers.md) |
| 76 | + |
| 77 | +You can view and manage the tools that can be used for responding to a request. Select the **Tools** icon in the chat window to view and manage the tools that are available in agent mode. |
| 78 | + |
| 79 | +:::image type="content" source="media/vs-2022/copilot-agent-mcp/copilot-agent-partial-tools.png" alt-text="Screenshot that shows Copilot agent tool selector." lightbox="media/vs-2022/copilot-agent-mcp/copilot-agent-partial-tools.png"::: |
| 80 | + |
| 81 | +Based on the outcome of a tool, Copilot might invoke other tools to accomplish the overall request. For example, if a code edit results in syntax errors in the file, Copilot might explore another approach and suggest different code changes. |
| 82 | + |
| 83 | +Additional tools added by running MCP servers are not automatically enabled, they are unchecked by default and must be checked to be activated. |
| 84 | + |
| 85 | +## Manage tool approvals |
| 86 | + |
| 87 | +When a tool is invoked, Copilot requests confirmation to run the tool. This is because tools might run locally on your machine and perform actions that modify files or data. |
| 88 | + |
| 89 | +:::image type="content" source="media/vs-2022/copilot-agent/copilot-agent-command-approval.png" alt-text="Screenshot that shows tool confirmation request." lightbox="media/vs-2022/copilot-agent/copilot-agent-command-approval.png"::: |
| 90 | + |
| 91 | +In the chat window, after a tool invocation, use the **Allow** dropdown options to automatically confirm the specific tool for the current session, solution, or all future invocations. |
| 92 | + |
| 93 | +You can reset tool confirmation selections in **Tools** > **Options** > **GitHub** > **Copilot** > **Tools**. |
| 94 | + |
| 95 | +:::image type="content" source="media/vs-2022/copilot-agent/copilot-agent-tool-config.png" alt-text="Screenshot that shows tool confirmation options." lightbox="media/vs-2022/copilot-agent/copilot-agent-tool-config.png"::: |
| 96 | + |
| 97 | +<!-- TODO: Define what "Reset solution setting does --> |
| 98 | + |
| 99 | +## Accept or discard edits |
| 100 | + |
| 101 | +Copilot lists the files that were edited in the list of **Total Changes** in the Chat window. |
| 102 | + |
| 103 | +:::image type="content" source="media/vs-2022/copilot-agent/copilot-agent-keep-undo.png" alt-text="Screenshot that shows the Total Changes list." lightbox="media/vs-2022/copilot-agent/copilot-agent-keep-undo.png"::: |
| 104 | + |
| 105 | +Click on each file to review changes individually, where you can **Keep** or **Undo** edits made to each chunk of code. |
| 106 | + |
| 107 | +Alternatively, in the **Total Changes** list, select **Keep** or **Undo** for all edits made since the last time you clicked **Keep** or **Undo**. |
| 108 | + |
| 109 | +## Revert edits |
| 110 | + |
| 111 | +As you're sending requests to make edits to your code, you might want to roll back some of these changes, for example, when you want to use another implementation strategy or if Copilot starts walking down the wrong path when generating edits. To do so, select **Restore** next to the checkpoint prior to the prompt that included changes you didn't want. |
| 112 | + |
| 113 | +:::image type="content" source="media/vs-2022/copilot-agent/copilot-agent-checkpoint.png" alt-text="Screenshot that shows reverting edits." lightbox="media/vs-2022/copilot-agent/copilot-agent-checkpoint.png"::: |
| 114 | + |
| 115 | +Currently, Visual Studio Copilot Agent doesn't support stepwise undo/redo. |
| 116 | + |
| 117 | +## Interrupt an agent mode request |
| 118 | + |
| 119 | +To interrupt an ongoing request, you can cancel it. |
| 120 | +This stops all running tools and terminal commands. |
| 121 | + |
| 122 | +To stop a build, select **Build** in the top toolbar, and then select **Cancel** or use the **Ctrl + Break** keyboard shortcut. |
| 123 | + |
| 124 | +## Frequently asked questions |
| 125 | + |
| 126 | +#### I don't see Ask and Agent mode in the GitHub Copilot Chat window. |
| 127 | + |
| 128 | +Take the following troubleshooting steps in the order specified: |
| 129 | +- Make sure you're using Visual Studio 17.14 or later: check the version at **Help** > **About Visual Studio**. If you're not using version 17.14 or later, launch the Visual Studio Installer and update your build. |
| 130 | +- Make sure you've selected the **Enable agent mode in the chat pane** setting in **Tools** > **Options** > **GitHub** > **Copilot Chat**. |
| 131 | +- Try restarting Visual Studio. |
| 132 | + |
| 133 | +#### When should I use Ask mode vs. Agent mode? |
| 134 | + |
| 135 | +- Ask mode is excellent when you want 100% confidence that no code edits are made unless you explicitly select **Apply** or copy and paste the code yourself. |
| 136 | +- Agent mode can handle the same conceptual questions, generate code examples without applying them, along with its agent capabilities of editing code. |
| 137 | +- If you are looking to use MCP capabilities, you must have agent mode selected. |
| 138 | + |
| 139 | +#### What happened to Copilot Edits in Visual Studio? |
| 140 | + |
| 141 | +- We perceive agent mode to be an evolution of Edits, with greater ability to iterate on errors, use tools, and automatically apply code changes. |
| 142 | +- For the initial releases of Visual Studio 2022 version 17.14, Edits mode is still available if you uncheck the **Enable agent mode in the chat pane** setting in **Tools** > **Options** > **GitHub** > **Copilot** > **Copilot Chat**. |
| 143 | + |
| 144 | +#### As an administrator, how do I control use of agent mode for Visual Studio users? |
| 145 | + |
| 146 | +Agent mode in Visual Studio is governed by the **Editor preview features** flag in the GitHub Copilot dashboard for administrators. |
| 147 | +If the administrator turns off this setting, users under that subscription won’t be able to use agent mode in Visual Studio. |
| 148 | + |
| 149 | +For more information, see [managing policies and features for copilot in your enterprise](https://docs.github.com/en/enterprise-cloud@latest/copilot/managing-copilot/managing-copilot-for-your-enterprise/managing-policies-and-features-for-copilot-in-your-enterprise#editor-preview-features). |
| 150 | + |
| 151 | +## Related content |
| 152 | + |
| 153 | +- [GitHub Copilot Edits](copilot-edits.md) |
| 154 | +- [GitHub Copilot Free](https://aka.ms/ghdocscopilotfreepage) |
0 commit comments