| ContentId | 5f83254d-2817-4398-9321-456789abcdef | ||||
|---|---|---|---|---|---|
| DateApproved | 12/10/2025 | ||||
| MetaDescription | Quickly get started with Git source control in Visual Studio Code. Initialize a repository, stage changes, and commit code in minutes. | ||||
| Keywords |
|
Get up and running with Git in Visual Studio Code in minutes. This guide covers the essentials of setting up a repository, saving your changes, and syncing your code.
-
Install Git: make sure Git is installed on your computer. Download Git
-
Open VS Code: make sure you have the latest version of Visual Studio Code installed.
You can start with an existing Git repository or a local project folder.
Clone a repository if you want to work on code that is already hosted on GitHub, Azure DevOps, or another Git provider. If you have previously cloned the repository, you can open the folder directly in VS Code and VS Code will detect the Git repository automatically.
To clone a repository in VS Code:
-
Open the Source Control view (
kb(workbench.view.scm)) and select Clone RepositoryAlternatively, open the Command Palette (
kb(workbench.action.showCommands)) and enterGit: Clone. -
Enter the repository URL (for example,
https://github.com/microsoft/PowerToys)If you're cloning from GitHub, you can also select Clone from GitHub and sign in to your GitHub account to see a list of your repositories.
-
Select a parent folder on your computer to save the project
-
Select Open when prompted to open the cloned repository in VS Code
-
Confirm whether you trust the repository in the Workspace Trust dialog
[!CAUTION] Only trust repositories from sources you know. Untrusted code can potentially harm your computer.
To start a new project with Git, you can initialize a repository in an existing local folder. This option creates a new Git repository in your folder to track changes.
-
Open your project folder in VS Code (File > Open Folder...).
-
Open the Source Control view (
kb(workbench.view.scm)) and select Initialize RepositoryAlternatively, open the Command Palette (
kb(workbench.action.showCommands)) and enterGit: Initialize Repository.
Git tracks changes to files in your project. The Source Control view in VS Code is your hub for managing these changes without using the command line.
Let's make a simple code change and use the Source Control view and diff editor to review it.
-
Edit an existing file in your project, and save it.
If you've just initialized a new repository, you can move on to the next step.
-
Open the Source Control view (
kb(workbench.view.scm)).Notice that the changed file(s) are listed under Changes with a "U" (untracked) or "M" (modified) icon next to them. The source control icon in the Activity Bar also shows a badge with the number of affected files.
-
To review the changes to a file, select it in the Source Control view to open a diff editor.
A diff editor shows the differences between the current version of the file and the last committed version. If the window is wide enough, the diff editor displays a side-by-side comparison, otherwise the changes are shown inline.
[!TIP] If you have a Copilot subscription, select the Code Review button in the Source Control view to perform an AI-powered code review of your changes before committing them.
Git uses a two-step process to save changes: Stage (prepare) and Commit (save). In the Source Control view, changes are first listed under Changes and after staging them, they move to Staged Changes where they are ready to be committed.
-
To stage your changes, do one of the following:
-
(Optional) You can unstage changes or discard changes if needed:
-
To unstage a file, hover over it in the Staged Changes list and select the - (minus) button
-
To discard changes to a file, right-click it in the Changes list and select Discard Changes
-
-
To commit your staged changes you can provide a commit message.
-
Enter a commit message in the text box at the top of the Source Control view.
You can also use AI to generate a commit message based on your staged changes by selecting the sparkle icon in the commit message input box.
-
Select Commit to commit your changes to your Git history
After committing, the staged changes are cleared from the Source Control view and saved in your local Git history.
[!NOTE] Only staged changes are included in a commit. If you have unstaged changes, they remain listed under Changes for future commits.
-
-
To view your commit history, select the Source Control Graph in the Source Control view.
If your repository is connected to a remote server (for example, GitHub or Azure DevOps), you can sync your local commits with the remote repository.
-
Open the Source Control view (
kb(workbench.view.scm)) -
Select Sync Changes to pull the latest changes from the remote and push your local commits
Alternatively, the Status Bar shows sync status and enables you to sync changes by selecting the sync icon (rotating arrows).
-
Select it to pull new changes from the server and push your commits.
-
To pull or push individually, select the ellipsis menu (...) in the Source Control view and choose Pull or Push.
Tip
If you started with a local folder (Option B) and want to save it to GitHub, use the Publish to GitHub button in the Source Control view.
Now that you know the basics, explore more features:
- Branches and Worktrees - Learn about branch management and parallel development.
- Repositories and Remotes - Learn about cloning, publishing, and syncing with remote repositories.
- Resolve Merge Conflicts - Learn how to handle conflicts when merging branches.
- Working with GitHub - Learn about Pull Requests and Issues.
- Troubleshooting - Diagnose and resolve Git issues.
- Source Control Overview - Full reference for source control features.









