- Create a file
- Highlight lines
- Upload a file
- Create a directory
- Create a new branch
- Create a new tag
Sometimes it’s easier to make quick changes directly from the GitLab interface than to clone the project and use the Git command-line tool. In this feature highlight, we look at how you can create a new file, directory, branch, or tag from the file browser. All of these actions are available from a single dropdown menu.
Enter a filename in the Filename box. Then, add file content in the editor area. Add a descriptive commit message and choose a branch. The branch field defaults to the branch you were viewing in the file browser. If you enter a new branch name, a checkbox displays, allowing you to start a new merge request after you commit the changes.
When you are satisfied with your new file, click Commit Changes at the bottom.
You can use shortcuts when editing a file through the Web Editor. It uses the same shortcuts as the Web IDE. For details, read the documentation for Command Palette.
When starting a new project, there are some common files that the new project might need. GitLab displays a message to help you:
When clicking on either
.gitignore and so on, a dropdown displays
to provide you a template that may be suitable for your project:
The license, changelog, contribution guide, or
.gitlab-ci.yml file can also
be added through a button on the project page. In this example, the license
has already been created, which creates a link to the license itself.
Web Editor enables you to highlight a single line by adding specially formatted
hash information to the URL’s file path segment. For example, the file path segment
MY_FILE.js#L3 instructs the Web Editor to highlight line 3.
The Web Editor also enables you to highlight multiple lines using a similar pattern. In
this case, the file path segment
MY_FILE.js#L3-10 instructs the Web Editor to
highlight lines 3 to 10 of the file.
You don’t need to construct these lines manually. Instead, you can:
- Hover over the number of a line you want to be highlighted when sharing.
- Right-click the number with your mouse.
Click Copy Link Address in the context menu.
The ability to create a file is great when the content is text. However, this doesn’t work well for binary data such as images, PDFs, or other binary file types. In this case, you need to upload a file.
From a project’s files page, click the ‘+’ button to the right of the branch selector. Choose Upload file from the dropdown:
After the upload dialog pops up, there are two ways to upload your file. Either drag and drop a file on the popup or use the click to upload link. After you select a file to upload, a file preview displays.
Enter a commit message, choose a branch, and click Upload file when you are ready.
To keep files in the repository organized it is often helpful to create a new directory.
From a project’s files page, click the plus button (
+) to the right of the branch selector.
Choose New directory from the dropdown.
In the new directory dialog, enter a directory name, a commit message, and choose the target branch. Click Create directory to finish.
There are multiple ways to create a branch from the GitLab web interface.
Introduced in GitLab 8.6.
If your development workflow requires an issue for every merge request, you can create a branch directly from the issue to speed the process up. The new branch, and later its merge request, are marked as related to this issue. Once merged, the merge request closes the issue. You can see a Create merge request dropdown below the issue description.
The Create merge request button doesn’t display if:
- A branch with the same name already exists.
- A merge request already exists for this branch.
- Your project has an active fork relationship.
To make this button appear, one possible workaround is to remove your project’s fork relationship. After removal, the fork relationship cannot be restored. This project can no longer be able to receive or send merge requests to the source project, or other forks.
This dropdown contains the options Create merge request and branch and Create branch.
After selecting one of these options, a new branch or branch and merge request
is created based on your project’s default branch. By default, this branch is
The branch name is based on an internal ID, and the issue title. The example
screenshot above creates a branch named
When you click the Create branch button in an empty repository project, GitLab performs these actions:
- Creates a
- Commits a blank
README.mdfile to it.
- Creates and redirects you to a new branch based on the issue title.
If your project is configured with a deployment service like Kubernetes,
GitLab prompts you to set up auto deploy
by helping you create a
After the branch is created, you can edit files in the repository to fix
the issue. When a merge request is created based on the newly-created branch,
the description field displays the issue closing pattern
Closes #ID, where
ID is the ID of the issue. This closes the issue when the
merge request is merged.
If you want to make changes to several files before creating a new merge request, you can create a new branch upfront.
From a project’s files page, choose New branch from the dropdown.
- Enter a new Branch name.
- (Optional) Change the Create from field to choose which branch, tag, or commit SHA this new branch originates from. This field autocompletes if you start typing an existing branch or tag.
Click Create branch to return to the file browser on this new branch.
You can now make changes to any files, as needed. When you’re ready to merge
the changes back to
master, you can use the widget at the top of the screen.
This widget only appears for a period of time after you create the branch or
Tags help you mark major milestones such as production releases and release candidates. You can create a tag from a branch or a commit SHA:
From a project’s files page, choose New tag from the dropdown.
- Give the tag a name such as
- Choose the branch or SHA from which you want to create this new tag.
- (Optional) Add a message and release notes. The release notes section supports Markdown format.
- (Optional) Upload an attachment.
Click Create tag, and GitLab redirects you to the tag list page.
When creating or uploading a new file or creating a new directory, you can
trigger a new merge request rather than committing directly to
- Enter a new branch name in the Target branch field.
- GitLab displays the Start a new merge request with these changes check box.
Commit your changes, and GitLab redirects you to a new merge request form.
If you’d prefer to not use your primary email address for commits created through the web editor, you can choose to use another of your linked email addresses from the User Settings > Edit Profile page.