Set up a Git repository
When you clone an existing Git repository, or put an existing project under Git version control, DataGrip automatically detects if Git is installed on your computer. If the IDE can't locate a Git executable, it suggests downloading it.
DataGrip supports Git from the Windows Subsystem for Linux 2 (WSL2), which is available in Windows 10 version 2004.
If Git is not installed on Windows, DataGrip searches for Git in WSL and uses it from there. Also, DataGrip automatically switches to Git from WSL for projects that are opened when you use the \\wsl$ path.
If you need to manually configure DataGrip to use Git from WSL, go to the Version Control | Git page of the IDE settings Control+Alt+S, click the Browse icon in the Path to Git executable field and select Git from WSL via the \wsl$
path, for example, \\wsl$\debian\usr\bin\git
.
Clone and attach a directory to the existing project
DataGrip allows you to check out (in Git terms clone) an existing repository and attach the directory with cloned files to the existing project.
Only the attached directory will be associated with the remote Git repository.
To start cloning a Git repository, do one of the following:
From the main menu, select
. If the version control integration was already eenabled for the project, select .If no project is currently opened, click Get from VCS on the Welcome screen.
In the Get from Version Control dialog, specify the URL of the remote repository you want to clone, or select one of the VCS hosting services on the left.
If you are already logged in to the selected hosting service, completion will suggest the list of available repositories that you can clone.
In the Trust an Open Project '<project_name>'? project security dialog, click Don't Open to stay in the current project with the database connections and other settings.
In the Files tool window ( ), click the Attach Directory to Project button () in the toolbar. In the file browser that opens, navigate to the cloned directory and open it.
Register the VCS root directory by doing the following:
In the Settings dialog (Control+Alt+S), open version control settings ( ). This page shows a list of project directories and version control systems associated with them (if no directories have been added, the list only contains the project root).
Click the Add button ().
In the Add VCS Directory Mapping dialog, select the Directory option. Type the path to the directory that you want to associate with a version control system, or click the Browse button () and select the dumps directory.
From the VCS list, select Git.
Click OK.
Create a project by cloning a Git repository
DataGrip allows you to check out (in Git terms clone) an existing repository and create a new project based on the data you've downloaded.
The entire project will be associated with the remote Git repository.
To start cloning a Git repository, do one of the following:
From the main menu, select
. If the version control integration was already eenabled for the project, select .If no project is currently opened, click Get from VCS on the Welcome screen.
In the Get from Version Control dialog, specify the URL of the remote repository you want to clone, or select one of the VCS hosting services on the left.
If you are already logged in to the selected hosting service, completion will suggest the list of available repositories that you can clone.
In the Trust an Open Project '<project_name>'? project security dialog, select the way you want to open the project: Trust Project or Preview in Safe Mode.
Put an existing project under Git version control
You can create a local Git repository based on the existing project.
Associate the entire project with a single Git repository
Press Alt+` to open the VCS Operations Popup and select Enable Version Control Integration.
Alternatively, from the main menu, select
.Choose Git as the version control system and click OK.
The entire project then will be associated with a single Git directory, so there is no need to add each file to the Git directory individually.
After VCS integration is enabled, DataGrip will ask you whether you want to share project settings files via VCS. You can choose Always Add to synchronize project settings with other repository users who work with DataGrip.
Associate different directories within the project with different Git repositories
In the Files tool window, select the project that you want to put under Git.
From the main menu, choose
.In the dialog that opens, specify the directory where a new Git repository will be created.
Git does not support external paths, so if you choose a directory that is outside your project root, make sure that the folder where the repository is going to be created also contains the project root.
If you are creating multiple Git repositories inside the project structure, repeat the previous steps for each directory.
After you have initialized a Git repository for your project or directory, you need to add files to the repository.
Add files to the local repository
In the Commit tool window Alt+0, expand the Unversioned Files node.
Select the files you want to add to Git or the entire changelist and press Control+Alt+A or choose Add to VCS from the context menu.
You can also add files to your local Git repository from the Files tool window: select the files you want to add, and press Control+Alt+A or choose Git | Add from the context menu.
When Git integration is enabled in your project or directory, DataGrip suggests adding each newly created file under Git, even if it was added from outside DataGrip. You can change this behavior in the Version Control | Confirmation page of the IDE settings Control+Alt+S. If you want certain files to always remain unversioned, you can ignore them.
Exclude files from version control (ignore)
Sometimes you may need to leave certain files unversioned. These can be VCS administration files, artifacts of utilities, backup copies, and so on. You can ignore files through DataGrip, and the IDE will not suggest adding them to Git and will highlight them as ignored.
You can only ignore unversioned files, that is files that you see in the Unversioned Files changelist. If a file is added to Git but not committed, you can right-click it in the Local Changes view and choose Rollback.
Git lets you list ignored file patterns in two kinds of configuration files:
.git/info/exclude file.
Patterns listed in this file only apply to the local copy of the repository.
This file is created automatically when you initialize or check out a Git repository.
One or more .gitignore files in the VCS root directory and its subdirectories.
These files are checked into the repository so that the ignore patterns in them are available to the entire team. Therefore, it is a most common place to store the ignored file patterns.
If there is no .gitignore file in the VCS root directory, you can right-click anywhere in the Files tool window, choose and type .gitignore in the New File dialog.
Add files to .gitignore or .git/info/exclude
Decide what kind of Git configuration file you are going to use to ignore files. If in doubt, use .gitignore.
Locate the unversioned file or folder you want to ignore in the Local Changes view or in Files tool window. File colors in these views help you identify the status of the file.
Right click the selection and choose Git | Add to .gitignore or Git | Add to .git/info/exclude.
File colors in these views help you identify the status of the file.
If you need to exclude files by a certain pattern, or files of a certain type, you can edit the .gitignore
or .git/info/exclude
file directly. See .gitignore patterns format.
Check status
DataGrip allows you to check the status of your local working copy compared to the repository version of the project or directory. It uses specific colors to let you see which files have been modified, which new files have been added to the VCS, and which files are not being tracked by Git.
Open the Local Changes view.
The Changes changelist shows all files that have been modified since you last synchronized with the remote repository (highlighted in blue), and all new files that have been added to the VCS but have not been committed yet (highlighted in green).
The Unversioned Files changelist shows all files that have been added to your project or directory, but that are not being tracked by Git.
For more info on changelists, see Group changes into different changelists.
Track changes to a file in the editor
You can also track changes to a file as you modify it in the editor. All changes are highlighted with change markers that appear in the gutter next to the modified lines, and show the type of changes introduced since you last synchronized with the repository. When you commit changes to the repository, change markers disappear.
The changes you introduce to the text are color-coded:
line added.
line changed.
line deleted.
You can manage changes using a toolbar that appears when you hover the mouse cursor over a change marker and then click it. The toolbar is displayed together with a frame showing the previous contents of the modified line:
You can roll back changes by clicking and explore the differences between the current and the repository version of the current line by clicking . To highlight the fragments that were changed, click .
Instead of reverting the whole file, you can copy any part of the contents of this popup and paste it into the editor.
Add a remote repository
If you created a Git repository based on local sources, you need to add a remote repository to be able to collaborate on your Git project, as well as to eliminate the risks of storing all of your codebase locally. You push changes to a remote repository when you need to share your work and pull data from it to integrate changes made by other contributors into your local repository version.
If you have cloned a remote Git repository, for example from GitHub, the remote is configured automatically and you do not have to specify it when you want to sync with it. The default name Git gives to the remote you've cloned from is origin.
Define a remote
Create an empty repository on any Git hosting, such as Bitbucket or GitHub. You can create a repository on GitHub without leaving DataGrip: see Share a project on GitHub.
Invoke the Push dialog when you are ready to push your commits by selecting from the main menu, or press Control+Shift+K.
If you haven't added any remotes so far, the Define remote link will appear instead of a remote name. Click it to add a remote.
In the dialog that opens, specify the remote name and the URL where it will be hosted, and click OK.
Add a second remote
In some cases, you also need to add a second remote repository. This may be useful, for example, if you have cloned a repository that you do not have write access to, and you are going to push changes to your own fork of the original project. Another common scenario is that you have cloned your own repository that is somebody else's project fork, and you need to synchronize with the original project and fetch changes from it.
From the main menu, choose Git Remotes dialog will open.
. TheClick the Add button on the toolbar or press Alt+Insert.
In the dialog that opens, specify the remote name and URL and click OK.
To edit a remote (for example, to change the name of the original project that you have cloned), right-click the remote branch in the Branches pane of the Git Log tool window, and select Edit Remote from the context menu.
You can also edit a remote from the Push Dialog by clicking its name.
To remove a repository that is no longer valid, right-click it in the Branches pane of the Git Log tool window, and select Remove Remote from the context menu.