mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2024-11-22 09:41:07 +00:00
docs: Explain how to open a merge request with screenshots
The merge request workflow can be confusing to people unfamiliar with it, so add screenshots. Also add a new section on how to revise merge requests, since a lot of people tend to open new merge requests to make any changes. Eliminate the separate "How to Prepare a Merge Request for Submission" section -- merge it with the main section. Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/1367>
This commit is contained in:
parent
3fa1895342
commit
8594878337
5 changed files with 220 additions and 150 deletions
BIN
subprojects/gst-docs/images/contribute/fork-gstreamer.png
Normal file
BIN
subprojects/gst-docs/images/contribute/fork-gstreamer.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 58 KiB |
BIN
subprojects/gst-docs/images/contribute/fork-settings.png
Normal file
BIN
subprojects/gst-docs/images/contribute/fork-settings.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 133 KiB |
BIN
subprojects/gst-docs/images/contribute/mr-settings.png
Normal file
BIN
subprojects/gst-docs/images/contribute/mr-settings.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 60 KiB |
BIN
subprojects/gst-docs/images/contribute/submit-mr.png
Normal file
BIN
subprojects/gst-docs/images/contribute/submit-mr.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 116 KiB |
|
@ -94,32 +94,67 @@ in GitHub, and uses the same [workflow][gitlab-merge-request-workflow].
|
||||||
|
|
||||||
[gitlab-merge-request-workflow]: https://docs.gitlab.com/ce/user/project/merge_requests/index.html#overview
|
[gitlab-merge-request-workflow]: https://docs.gitlab.com/ce/user/project/merge_requests/index.html#overview
|
||||||
|
|
||||||
In order to submit a merge request you first need a personal fork of the
|
In a nutshell, you will:
|
||||||
project / gstreamer module in question. To fork a module go to
|
|
||||||
the module in question (e.g. <https://gitlab.freedesktop.org/gstreamer/gstreamer>)
|
1. [Clone](https://github.com/git-guides/git-clone) the gstreamer repository on
|
||||||
and hit the fork button. A new repository will be created in your user namespace
|
your development machine
|
||||||
(<https://gitlab.freedesktop.org/$USERNAME/gstreamer>). You will be redirected
|
1. Create a [fork](https://docs.gitlab.com/ee/user/project/repository/forking_workflow.html)
|
||||||
|
of it in your gitlab namespace
|
||||||
|
1. Add that fork as a [git "remote"](https://github.com/git-guides/git-remote)
|
||||||
|
to the clone on your machine
|
||||||
|
1. Setup a [branch](https://docs.gitlab.com/ee/user/project/repository/branches/)
|
||||||
|
with the commits you want to submit
|
||||||
|
1. Push that branch to the fork in your gitlab namespace
|
||||||
|
1. Open request to merge that branch into the main repository, which is called a
|
||||||
|
[merge request](https://docs.gitlab.com/ee/user/project/merge_requests/)
|
||||||
|
|
||||||
|
#### Pre-requisites
|
||||||
|
|
||||||
|
In order to submit a merge request you must first:
|
||||||
|
|
||||||
|
1. Sign into or create an account on the [Freedesktop GitLab website](https://gitlab.freedesktop.org)
|
||||||
|
2. Setup SSH keys in the [GitLab user settings](https://gitlab.freedesktop.org/profile/keys)
|
||||||
|
3. Clone the gstreamer repository on your development machine
|
||||||
|
|
||||||
|
#### Forking the gstreamer repository
|
||||||
|
|
||||||
|
Then you need to create a *personal* fork of gstreamer. To fork gstreamer go to
|
||||||
|
[the repository](https://gitlab.freedesktop.org/gstreamer/gstreamer) and hit
|
||||||
|
the "Fork" button:
|
||||||
|
|
||||||
|
![Forking gstreamer](images/contribute/fork-gstreamer.png)
|
||||||
|
|
||||||
|
Select the namespace (your username), ensure that the visibility is set to
|
||||||
|
"Public", and hit the "Fork project" button:
|
||||||
|
|
||||||
|
![Fork settings](images/contribute/fork-settings.png)
|
||||||
|
|
||||||
|
A new repository will be created in your user namespace
|
||||||
|
(<https://gitlab.freedesktop.org/$GITLAB_USERNAME/gstreamer>). You will be redirected
|
||||||
there automatically once the forking process is finished. For big repositories
|
there automatically once the forking process is finished. For big repositories
|
||||||
the forking might take a few minutes.
|
the forking might take a few minutes.
|
||||||
|
|
||||||
Once this is done you can add your personal fork as new remote to your existing checkout with
|
Once this is done you can add your personal fork as new remote to the gstreamer
|
||||||
|
repository clone you made in step 3 above with the following command (replace
|
||||||
|
`$GITLAB_USERNAME` with your actual gitlab username):
|
||||||
|
|
||||||
git remote add my-personal-gitlab-fork git@gitlab.freedesktop.org:$USERNAME/gstreamer.git
|
git remote add $GITLAB_USERNAME git@gitlab.freedesktop.org:$GITLAB_USERNAME/gstreamer.git
|
||||||
|
|
||||||
Check with
|
Check with
|
||||||
|
|
||||||
git fetch my-personal-gitlab-fork
|
git fetch $GITLAB_USERNAME
|
||||||
|
|
||||||
that it is accessible and working.
|
that it is accessible and working.
|
||||||
|
|
||||||
If you have not done so already, you may need to first
|
Common mistakes at this point are:
|
||||||
[set up SSH keys in your GitLab User Settings](https://gitlab.freedesktop.org/profile/keys).
|
|
||||||
|
|
||||||
**Once you have done that, please make your repository public.** By default
|
a) [Not setting up an SSH key](https://gitlab.freedesktop.org/profile/keys)
|
||||||
newly-forked repositories might be private, but that causes problems for
|
|
||||||
maintainers and merge bots, so please go to the newly-created repository's
|
b) Having a private fork. You can change your fork to public in the settings:
|
||||||
settings (https://gitlab.freedesktop.org/$USERNAME/gstreamer/edit) and set
|
https://gitlab.freedesktop.org/$GITLAB_USERNAME/gstreamer/edit (replace `$GITLAB_USERNAME`
|
||||||
the visibility to public. Thanks!
|
with your actual gitlab username)
|
||||||
|
|
||||||
|
#### Setting up your branch
|
||||||
|
|
||||||
Next, you make a git branch with one or more commits you want to submit
|
Next, you make a git branch with one or more commits you want to submit
|
||||||
for review and merging. For that you will first need a local branch which
|
for review and merging. For that you will first need a local branch which
|
||||||
|
@ -127,25 +162,172 @@ you can create with e.g.
|
||||||
|
|
||||||
git checkout -b fix-xyz
|
git checkout -b fix-xyz
|
||||||
|
|
||||||
You can then push that branch to your personal fork git repository with
|
Then you can make your modifications and create a local commit with e.g.
|
||||||
|
|
||||||
git push my-personal-gitlab-fork
|
git commit path/to/file1.[ch]
|
||||||
|
|
||||||
|
This will pop up an editor where you can create your commit message. It should
|
||||||
|
look something like:
|
||||||
|
|
||||||
|
exampledemux: fix seeking without index in push mode
|
||||||
|
|
||||||
|
Without an index we would refuse to seek in push mode. Make
|
||||||
|
seeking without an index work by estimating the position
|
||||||
|
to seek to. It might not be 100% accurate, but better than
|
||||||
|
nothing.
|
||||||
|
|
||||||
|
Then exit the editor, and you should have a commit.
|
||||||
|
|
||||||
|
Please make sure your commits are as terse and precise as possible. Do not
|
||||||
|
include 'clean-ups' or non-functional changes, since they distract from the
|
||||||
|
real changes and make things harder to review, and also lower the chances that
|
||||||
|
the patch will still apply cleanly to the latest version in git. If you feel
|
||||||
|
there are things to clean up, please submit the clean-ups as a separate patch
|
||||||
|
that does not contain any functional changes. See
|
||||||
|
[Writing Good Commit Messages](#writing-good-commit-messages) for more
|
||||||
|
information.
|
||||||
|
|
||||||
|
It's best to run `git add` or `git commit` on specific directories or files
|
||||||
|
instead of using `git commit -a`, as it's too easy to accidentally contaminate
|
||||||
|
a patch with changes that belong into it with `git commit -a`, in particular
|
||||||
|
changes to the `common` submodule.
|
||||||
|
|
||||||
|
You can check your commit(s) with `git show` or `git log -p` or using a GUI
|
||||||
|
such as `gitg` or `gitk`.
|
||||||
|
|
||||||
|
Make sure the author is correctly set to your full name and e-mail address.
|
||||||
|
|
||||||
|
If you haven't used git before, it would be a good idea to tell it who you are:
|
||||||
|
|
||||||
|
git config --global user.name "George S. Treamer"
|
||||||
|
git config --global user.email "george.s.treamer@example.com"
|
||||||
|
|
||||||
|
You can make changes to the last commit using:
|
||||||
|
|
||||||
|
- `git commit --amend` to fix up the commit message
|
||||||
|
|
||||||
|
- `git commit --amend --author='John You <john@you.com>'` to fix up the author
|
||||||
|
|
||||||
|
- `git add path/to/file1.[ch]; git commit --amend` to incorporate fixes
|
||||||
|
made to the files since the last commit (i.e. what shows up in `git diff`).
|
||||||
|
If you just want to add some of the changes, but not all of them you can
|
||||||
|
use `git add -p file.c`, then it will ask you for each individual change
|
||||||
|
whether you want to add it or leave it.
|
||||||
|
|
||||||
|
Once everything looks fine, you can push the branch to your personal fork git
|
||||||
|
repository with:
|
||||||
|
|
||||||
|
git push -u $GITLAB_USERNAME
|
||||||
|
|
||||||
You can use
|
You can use
|
||||||
|
|
||||||
git push --dry-run my-personal-gitlab-fork
|
git push -u --dry-run $GITLAB_USERNAME
|
||||||
|
|
||||||
for testing to see what would happen without actually doing anything yet.
|
for testing to see what would happen without actually doing anything yet.
|
||||||
|
As before, replace `$GITLAB_USERNAME` with your actual gitlab username.
|
||||||
|
|
||||||
After you have pushed the branch to your personal fork you will see a link
|
After you have pushed the branch to your personal fork you will see a link
|
||||||
on the terminal with which you can create a merge request for the upstream
|
on the terminal with which you can create a merge request for the upstream
|
||||||
repository. You can also do this later by going to the
|
repository. It will look something like this:
|
||||||
branch list of your personal repository at
|
|
||||||
<https://gitlab.freedesktop.org/$USERNAME/gstreamer/branches>
|
|
||||||
and then hitting the 'Merge Request' button when ready. This will open a new
|
|
||||||
page where you can enter a description of the changes you are submitting.
|
|
||||||
|
|
||||||
Couple of additional points:
|
```sh
|
||||||
|
$ git push -u $GITLAB_USERNAME
|
||||||
|
Enumerating objects: 4436, done.
|
||||||
|
Counting objects: 100% (4436/4436), done.
|
||||||
|
Delta compression using up to 8 threads
|
||||||
|
Compressing objects: 100% (1161/1161), done.
|
||||||
|
Writing objects: 100% (3616/3616), 1.47 MiB | 8.12 MiB/s, done.
|
||||||
|
Total 3616 (delta 2973), reused 3022 (delta 2443), pack-reused 0
|
||||||
|
remote: Resolving deltas: 100% (2973/2973), completed with 704 local objects.
|
||||||
|
remote:
|
||||||
|
remote: To create a merge request for fix-xyz, visit:
|
||||||
|
remote: https://gitlab.freedesktop.org/$GITLAB_USERNAME/gstreamer/-/merge_requests/new?merge_request%5Bsource_branch%5D=fix-xyz
|
||||||
|
remote:
|
||||||
|
To gitlab.freedesktop.org:$GITLAB_USERNAME/gstreamer.git
|
||||||
|
* [new branch] fix-xyz -> fix-xyz
|
||||||
|
Branch 'fix-xyz' set up to track remote branch 'fix-xyz' from '$GITLAB_USERNAME' by rebasing.
|
||||||
|
```
|
||||||
|
|
||||||
|
Clicking on that link will take you to a page where you can enter a description
|
||||||
|
of the changes you are submitting. If your branch contains only one commit, the
|
||||||
|
title and description will be auto-filled using the commit message.
|
||||||
|
|
||||||
|
![Submitting a merge request](images/contribute/submit-mr.png)
|
||||||
|
|
||||||
|
On the same page, ensure that these checkboxes are selected and create the
|
||||||
|
merge request:
|
||||||
|
|
||||||
|
![Merge request settings](images/contribute/mr-settings.png)
|
||||||
|
|
||||||
|
If you don't see the link or want to do this later, you can go to the branch
|
||||||
|
list of your personal repository at <https://gitlab.freedesktop.org/$GITLAB_USERNAME/gstreamer/branches>
|
||||||
|
and hit the 'Merge Request' button when ready. This will open a new page where
|
||||||
|
you can select the source project `$GITLAB_USERNAME/gstreamer` + source branch
|
||||||
|
`fix-xyz` and the target project `gstreamer/gstreamer` and target branch
|
||||||
|
`main`. Then you will be able to enter a description of the changes you are
|
||||||
|
submitting.
|
||||||
|
|
||||||
|
|
||||||
|
#### Revising your merge request
|
||||||
|
|
||||||
|
You will often need to revise the commits in your merge request based on review
|
||||||
|
by maintainers of the project. You **do not** need to open a new merge request
|
||||||
|
to do that. You need to edit the commits in your local branch and force-push it
|
||||||
|
to sync the branch in your namespace. That will automatically update the merge
|
||||||
|
request.
|
||||||
|
|
||||||
|
The most common case is when you have a single commit in your branch that you
|
||||||
|
want to edit. To do this, first make any changes you want to do, then check the
|
||||||
|
branch status:
|
||||||
|
|
||||||
|
```sh
|
||||||
|
$ git status
|
||||||
|
On branch fix-xyz
|
||||||
|
Your branch is up to date with '$GITLAB_USERNAME/fix-xyz'.
|
||||||
|
|
||||||
|
Changes not staged for commit:
|
||||||
|
(use "git add <file>..." to update what will be committed)
|
||||||
|
(use "git restore <file>..." to discard changes in working directory)
|
||||||
|
modified: subprojects/gst-docs/markdown/contribute/index.md
|
||||||
|
|
||||||
|
no changes added to commit (use "git add" and/or "git commit -a")
|
||||||
|
```
|
||||||
|
|
||||||
|
Next, add the changes and amend your commit:
|
||||||
|
|
||||||
|
```sh
|
||||||
|
$ git add subprojects/gst-docs/markdown/contribute/index.md
|
||||||
|
$ git commit --amend
|
||||||
|
```
|
||||||
|
|
||||||
|
This will open your editor and allow you to edit the commit message if
|
||||||
|
necessary. Closing the editor will save the new (updated) commit.
|
||||||
|
|
||||||
|
Next, push the changes to your remote branch:
|
||||||
|
|
||||||
|
```sh
|
||||||
|
$ git push --force-with-lease
|
||||||
|
```
|
||||||
|
|
||||||
|
This will overwrite the old commit in your remote branch with the new commit
|
||||||
|
that you just created. If this command completes successfully, that's it! The
|
||||||
|
merge request has been automatically updated.
|
||||||
|
|
||||||
|
**If the command fails**, that means that there were changes in the remote
|
||||||
|
branch that you hadn't pulled into your branch before amending your commit.
|
||||||
|
|
||||||
|
This can happen if, for example, someone uses the "Rebase" button on your merge
|
||||||
|
request to rebase the commit(s) on top of the latest changes in the `main`
|
||||||
|
branch.
|
||||||
|
|
||||||
|
In that case you need to resync the two branches. This usually requires you to
|
||||||
|
understand `git rebase`, which is beyond the scope of this document. There's
|
||||||
|
tutorials you can find online, such as [git-rebase.io](https://git-rebase.io/)
|
||||||
|
|
||||||
|
In the simplest case, you might be able to get away with just doing a `git pull
|
||||||
|
--rebase`.
|
||||||
|
|
||||||
|
#### Additional points
|
||||||
|
|
||||||
- If you are submitting a Merge Request for an issue (or multiple issues) that
|
- If you are submitting a Merge Request for an issue (or multiple issues) that
|
||||||
already exist, please add 'Fixes #123' to the commit message of one of your
|
already exist, please add 'Fixes #123' to the commit message of one of your
|
||||||
|
@ -155,13 +337,6 @@ Couple of additional points:
|
||||||
- You do not have to file an issue to go with each Merge Request, it's fine
|
- You do not have to file an issue to go with each Merge Request, it's fine
|
||||||
to just submit a Merge Request on its own.
|
to just submit a Merge Request on its own.
|
||||||
|
|
||||||
- **Please make sure the "Allow commits from members who can merge to the target branch"**
|
|
||||||
**checkbox is enabled when submitting merge requests** as otherwise
|
|
||||||
maintainers (and our merge bot) can't rebase your Merge Request when they
|
|
||||||
want to merge it, which means they won't be able to merge it. If you can't
|
|
||||||
enable the check box that means your personal repository fork is private.
|
|
||||||
In that case, please go to the settings and change visibility to public.
|
|
||||||
|
|
||||||
- If your proposed changes are proposed for review but not ready to be merged
|
- If your proposed changes are proposed for review but not ready to be merged
|
||||||
yet, please prefix the Merge Request title with `WIP:` for Work-in-Progress.
|
yet, please prefix the Merge Request title with `WIP:` for Work-in-Progress.
|
||||||
That will prevent us from inadvertently merging it and make clear its status.
|
That will prevent us from inadvertently merging it and make clear its status.
|
||||||
|
@ -195,13 +370,10 @@ Couple of additional points:
|
||||||
current module. `!100` references merge request 100 in the current project.
|
current module. `!100` references merge request 100 in the current project.
|
||||||
A complete list is available from [gitlab's documentation][special-md-references].
|
A complete list is available from [gitlab's documentation][special-md-references].
|
||||||
|
|
||||||
- Please create separate merge requests for separate issues and for different
|
- Please create separate merge requests for separate issues.
|
||||||
modules. There is no golden rule when something counts as a separate issue,
|
There is no golden rule when something counts as a separate issue,
|
||||||
please just use your best judgment. If a merge request is related to another
|
please just use your best judgment.
|
||||||
merge request in another module please mention that in the description using
|
If there is an issue that requires related fixes in multiple elements
|
||||||
a gitlab reference as outlined above. For example, if you have a change that
|
|
||||||
needs to be done in each module, one issue with one merge request per module
|
|
||||||
is fine. If there is an issue that requires related fixes in multiple elements
|
|
||||||
or libraries, please also feel free to put everything into one issue. If you
|
or libraries, please also feel free to put everything into one issue. If you
|
||||||
just happen to have multiple patches for us but they are not really related,
|
just happen to have multiple patches for us but they are not really related,
|
||||||
please put them in separate issues and merge requests. The main question is
|
please put them in separate issues and merge requests. The main question is
|
||||||
|
@ -216,125 +388,23 @@ Couple of additional points:
|
||||||
- Please do not send pull requests to our github mirror. They will be closed
|
- Please do not send pull requests to our github mirror. They will be closed
|
||||||
automatically.
|
automatically.
|
||||||
|
|
||||||
- Please do not attach patches to existing bugs on [GNOME Bugzilla][bugzilla]
|
|
||||||
If you want to reopen an already closed bug, let one of the developers know
|
|
||||||
and we will look into that on a case-by-case basis.
|
|
||||||
|
|
||||||
- Please do not attach patches to issues.
|
- Please do not attach patches to issues.
|
||||||
|
|
||||||
|
- Please prepare any merge request against a current git checkout of the
|
||||||
|
GStreamer monorepo (gstreamer module), against the tip of the `main` branch.
|
||||||
|
If a merge request is prepared against an old commit or older branch and
|
||||||
|
can't be easily rebased you may be asked to rebase and update the branch on
|
||||||
|
top of the `main` branch.
|
||||||
|
|
||||||
|
- If you have created a new plugin, please submit a merge request that adds it
|
||||||
|
to `subprojects/gst-plugins-bad`, including any required `meson.build`
|
||||||
|
modifications, new files and documentation.
|
||||||
|
|
||||||
|
|
||||||
[special-md-references]: https://docs.gitlab.com/ee/user/markdown.html#special-gitlab-references
|
[special-md-references]: https://docs.gitlab.com/ee/user/markdown.html#special-gitlab-references
|
||||||
[bugzilla]: https://bugzilla.gnome.org/
|
|
||||||
[bugs]: https://gstreamer.freedesktop.org/bugs/
|
[bugs]: https://gstreamer.freedesktop.org/bugs/
|
||||||
[gitlab]: https://gitlab.freedesktop.org/gstreamer
|
[gitlab]: https://gitlab.freedesktop.org/gstreamer
|
||||||
|
|
||||||
### How to Prepare a Merge Request for Submission
|
|
||||||
|
|
||||||
Please prepare any merge request against a current git checkout of the
|
|
||||||
GStreamer monorepo (gstreamer module), against the tip of the `main` branch.
|
|
||||||
If a merge request is prepared against an old commit or older branch and can't
|
|
||||||
be easily rebased you may be asked to rebase and update the branch on top of
|
|
||||||
the `main` branch.
|
|
||||||
|
|
||||||
If you have created a new plugin, please submit a merge request that adds it to
|
|
||||||
`subprojects/gst-plugins-bad`, including any required `meson.build` modifications,
|
|
||||||
new files and documentation.
|
|
||||||
|
|
||||||
#### Preparation: create a personal fork of the git repository on GitLab
|
|
||||||
|
|
||||||
The easiest way to create a merge request is to create one or more local commits
|
|
||||||
for your changes in a branch in a local git repository. This should be a git
|
|
||||||
clone checkout of your fork of the module in question. To fork a module go to
|
|
||||||
the module in question (e.g. <https://gitlab.freedesktop.org/gstreamer/gstreamer>)
|
|
||||||
and hit the fork button. A new repository will be created in your user namespace
|
|
||||||
and should be accessible as
|
|
||||||
<https://gitlab.freedesktop.org/$USERNAME/gstreamer>.
|
|
||||||
|
|
||||||
Clone the main gstreamer repository, like this:
|
|
||||||
|
|
||||||
git clone https://gitlab.freedesktop.org/gstreamer/gstreamer.git
|
|
||||||
|
|
||||||
and then add your personal fork as a git remote like this:
|
|
||||||
|
|
||||||
git remote add my-personal-gitlab-fork git@gitlab.freedesktop.org:$USERNAME/gstreamer.git
|
|
||||||
|
|
||||||
Check with
|
|
||||||
|
|
||||||
git fetch my-personal-gitlab-fork
|
|
||||||
|
|
||||||
that it is accessible and working.
|
|
||||||
|
|
||||||
If you have not done so already, you may need to first
|
|
||||||
[set up SSH keys in your GitLab User Settings](https://gitlab.freedesktop.org/profile/keys).
|
|
||||||
|
|
||||||
#### Creating a branch for the merge request and adding commits to it
|
|
||||||
|
|
||||||
Once you have a git repository with the original code in it, you should create a
|
|
||||||
branch for your change. e.g. to create a branch and checkout:
|
|
||||||
|
|
||||||
git checkout -b topic-branch
|
|
||||||
|
|
||||||
Then you can make your modifications and create a local commit with e.g.
|
|
||||||
|
|
||||||
git commit path/to/file1.[ch]
|
|
||||||
|
|
||||||
This will pop up an editor where you can create your commit message. It should
|
|
||||||
look something like:
|
|
||||||
|
|
||||||
exampledemux: fix seeking without index in push mode
|
|
||||||
|
|
||||||
Without an index we would refuse to seek in push mode. Make
|
|
||||||
seeking without an index work by estimating the position
|
|
||||||
to seek to. It might not be 100% accurate, but better than
|
|
||||||
nothing.
|
|
||||||
|
|
||||||
Then exit the editor, and you should have a commit.
|
|
||||||
|
|
||||||
It's best to run `git add` or `git commit` on specific directories or files
|
|
||||||
instead of using `git commit -a`, as it's too easy to accidentally contaminate
|
|
||||||
a patch with changes that belong into it with `git commit -a`, in particular
|
|
||||||
changes to the `common` submodule.
|
|
||||||
|
|
||||||
You can check your commit(s) with `git show` or `git log -p` or using a GUI
|
|
||||||
such as `gitg` or `gitk`.
|
|
||||||
|
|
||||||
Make sure the author is correctly set to your full name and e-mail address.
|
|
||||||
|
|
||||||
If you haven't used git before, it would be a good idea to tell it who you are:
|
|
||||||
|
|
||||||
$ git config --global user.name "George S. Treamer"
|
|
||||||
$ git config --global user.email "george.s.treamer@example.com"
|
|
||||||
|
|
||||||
You can make changes to the last commit using:
|
|
||||||
|
|
||||||
- `git commit --amend` to fix up the commit message
|
|
||||||
|
|
||||||
- `git commit --amend --author='John You <john@you.com>'` to fix up the author
|
|
||||||
|
|
||||||
- `git add path/to/file1.[ch]; git commit --amend` to incorporate fixes
|
|
||||||
made to the files since the last commit (i.e. what shows up in `git diff`).
|
|
||||||
If you just want to add some of the changes, but not all of them you can
|
|
||||||
use `git add -p file.c`, then it will ask you for each individual change
|
|
||||||
whether you want to add it or leave it.
|
|
||||||
|
|
||||||
Once everything looks fine, push your branch to your local fork e.g. using
|
|
||||||
|
|
||||||
git push your-personal-gitlab-fork your-branch
|
|
||||||
|
|
||||||
This push will display a link to be able create a merge request from your branch.
|
|
||||||
Click this link and fill out the details of the merge request. You can also
|
|
||||||
create a merge request from an existing branch. See the
|
|
||||||
[gitlab documentation][create-mr] for more details.
|
|
||||||
|
|
||||||
Please make sure your commits are as terse and precise as possible. Do not
|
|
||||||
include 'clean-ups' or non-functional changes, since they distract from the
|
|
||||||
real changes and make things harder to review, and also lower the chances that
|
|
||||||
the patch will still apply cleanly to the latest version in git. If you feel
|
|
||||||
there are things to clean up, please submit the clean-ups as a separate patch
|
|
||||||
that does not contain any functional changes.
|
|
||||||
|
|
||||||
[create-mr]: https://docs.gitlab.com/ee/gitlab-basics/add-merge-request.html
|
|
||||||
|
|
||||||
#### Coding Style
|
#### Coding Style
|
||||||
|
|
||||||
Try to stick to the GStreamer indentation and coding style. There is a script
|
Try to stick to the GStreamer indentation and coding style. There is a script
|
||||||
|
|
Loading…
Reference in a new issue