- Create a repository
- Add files to a repository
- Commit changes to a repository
- Clone a repository
- Download the code in a repository
- Repository languages
- Repository size
- Repository contributor graph
- Repository history graph
- What happens when a repository path changes
- Related topics
A repository is where you store your code and make changes to it. Your changes are tracked with version control.
Each project contains a repository.
To create a repository, you can:
You can add files to a repository:
- When you create a project.
- After you create a project:
You can commit your changes, to a branch in the repository. When you use the command line, you can commit multiple times before you push.
A commit message identities what is being changed and why.
In GitLab, you can add keywords to the commit
message to perform one of the following actions:
- Trigger a GitLab CI/CD pipeline: If the project is configured with GitLab CI/CD, you trigger a pipeline per push, not per commit.
ci skipkeyword to your commit message to make GitLab CI/CD skip the pipeline.
- Cross-link issues and merge requests: Use cross-linking to keep track of related parts of your workflow. If you mention an issue or a merge request in a commit message, they are displayed on their respective thread.
- Cherry-pick a commit: In GitLab, you can cherry-pick a commit from the UI.
- Revert a commit: Revert a commit from the UI to a selected branch.
- Sign a commit: Use GPG to sign your commits.
Alternatively, you can clone directly into a code editor.
Introduced in GitLab 11.0.
Projects that contain a
.xcworkspace directory can be cloned
into Xcode on macOS.
- From the GitLab UI, go to the project’s overview page.
- Select Clone.
- Select Xcode.
The project is cloned onto your computer and you are prompted to open XCode.
Introduced in GitLab 13.10.
All projects can be cloned into Visual Studio Code. To do that:
- From the GitLab UI, go to the project’s overview page.
- Click Clone.
- Select Clone with Visual Studio Code under either HTTPS or SSH method.
- Select a folder to clone the project into.
When VS Code has successfully cloned your project, it opens the folder.
You can download the source code that’s stored in a repository.
- Above the file list, select the download icon ().
From the options, select the files you want to download.
Download the source code from the current branch you’re viewing.
Download a specific directory. Visible only when you view a subdirectory.
- Artifacts: Download the artifacts from the latest CI job.
- Source code: Download the source code from the current branch you’re viewing. Available extensions:
For the default branch of each repository, GitLab determines which programming languages are used. This information is displayed on the Project information page.
When new files are added, this information can take up to five minutes to update.
Not all files are detected and listed on the Project information page. Documentation, vendor code, and most markup languages are excluded.
You can change this behavior by overriding the default settings.
- In your repository’s root directory, create a file named
Add a line that tells GitLab to include files of this type. For example, to enable
.protofiles, add the following code:
View a list of supported data types.
This feature can use excessive CPU. For more information, see the troubleshooting section.
If your file has one of the following file extensions, GitLab renders the contents of the file’s markup language in the UI.
index file is present in a repository, GitLab renders its contents.
These files can either be plain text or have the extension of a
supported markup language.
- When both a
indexfile are present, the
READMEalways takes precedence.
- When multiple files have the same name but a different extension, the files are
ordered alphabetically. Any file without an extension is ordered last.
README.adoctakes precedence over
README.rsttakes precedence over
Introduced in GitLab 12.6.
GitLab can render OpenAPI specification files. The filename
swagger and the extension must be
json. The following examples are all correct:
To render an OpenAPI file:
- Go to the OpenAPI file in your repository.
- Between the Display source and Edit buttons, select Display OpenAPI. When an OpenAPI file is found, it replaces the Display rendered file button.
The Project information page shows the size of all files in the repository. The size is updated, at most, every 15 minutes. The file size includes repository files, artifacts, and LFS.
The size can differ slightly from one instance to another due to compression, housekeeping, and other factors.
All code contributors are displayed under your project’s Repository > Contributors.
The graph shows the contributor with the most commits to the fewest.
A repository graph displays a visual history of the repository network, including branches and merges. This graph can help you visualize the Git flow strategy used in the repository.
Go to your project’s Repository > Graph.
When a repository path changes, GitLab handles the transition from the old location to the new one with a redirect.
- URLs for the namespace and everything under it, like projects, are redirected to the new URLs.
- Git remote URLs for projects under the namespace redirect to the new remote URL. When you push or pull to a repository that has changed location, a warning message to update your remote is displayed. Automation scripts or Git clients continue to work after a rename.
- The redirects are available as long as the original path is not claimed by another group, user, or project.
To determine which languages are in a repository’s files, GitLab uses a Ruby gem. When the gem parses a file to determine which type it is, the process can use excessive CPU. The gem contains a heuristics configuration file that defines which file extensions must be parsed.
Files with the
.txt extension and XML files with an extension not defined by the gem can take excessive CPU.
The workaround is to specify the language to assign to specific file extensions. The same approach should also allow misidentified file types to be fixed.
Identify the language to specify. The gem contains a configuration file for known data types. To add an entry for text files, for example:
Text: type: prose wrap: true aliases: - fundamental - plain text extensions: - ".txt"
Add or modify
.gitattributesin the root of your repository:
*.txt files have an entry in the heuristics file. This example prevents parsing of these files.