2015-04-26 12:48:37 +05:30
|
|
|
# Project forking workflow
|
|
|
|
|
2016-04-02 18:10:28 +05:30
|
|
|
Forking a project to your own namespace is useful if you have no write
|
|
|
|
access to the project you want to contribute to. If you do have write
|
|
|
|
access or can request it, we recommend working together in the same
|
|
|
|
repository since it is simpler. See our [GitLab Flow](gitlab_flow.md)
|
|
|
|
document more information about using branches to work together.
|
2015-04-26 12:48:37 +05:30
|
|
|
|
|
|
|
## Creating a fork
|
|
|
|
|
2016-04-02 18:10:28 +05:30
|
|
|
Forking a project is in most cases a two-step process.
|
2015-04-26 12:48:37 +05:30
|
|
|
|
|
|
|
|
2016-04-02 18:10:28 +05:30
|
|
|
1. Click on the fork button located in the middle of the page or a project's
|
|
|
|
home page right next to the stars button.
|
2015-04-26 12:48:37 +05:30
|
|
|
|
2016-04-02 18:10:28 +05:30
|
|
|
data:image/s3,"s3://crabby-images/7bd88/7bd88c89e9d96cfa3a6dd78bb12fd4ca566de9d9" alt="Fork button"
|
2015-04-26 12:48:37 +05:30
|
|
|
|
2016-04-02 18:10:28 +05:30
|
|
|
---
|
|
|
|
|
|
|
|
1. Once you do that, you'll be presented with a screen where you can choose
|
|
|
|
the namespace to fork to. Only namespaces (groups and your own
|
|
|
|
namespace) where you have write access to, will be shown. Click on the
|
|
|
|
namespace to create your fork there.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/1457e/1457e9f4d2a96c7f67c864138707ec1f04e4ab3c" alt="Choose namespace"
|
|
|
|
|
|
|
|
---
|
|
|
|
|
|
|
|
**Note:**
|
|
|
|
If the namespace you chose to fork the project to has another project with
|
|
|
|
the same path name, you will be presented with a warning that the forking
|
|
|
|
could not be completed. Try to resolve the error and repeat the forking
|
|
|
|
process.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/2f891/2f8913bde9ce4e13b30c17f76087d180d4460943" alt="Path taken error"
|
|
|
|
|
|
|
|
---
|
|
|
|
|
|
|
|
After the forking is done, you can start working on the newly created
|
|
|
|
repository. There, you will have full [Owner](../permissions/permissions.md)
|
|
|
|
access, so you can set it up as you please.
|
2015-04-26 12:48:37 +05:30
|
|
|
|
|
|
|
## Merging upstream
|
|
|
|
|
2016-04-02 18:10:28 +05:30
|
|
|
Once you are ready to send your code back to the main project, you need
|
|
|
|
to create a merge request. Choose your forked project's main branch as
|
|
|
|
the source and the original project's main branch as the destination and
|
|
|
|
create the [merge request](merge_requests.md).
|
2015-04-26 12:48:37 +05:30
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/13bdc/13bdcb2c2363f9f26b20566384f8991ea2d36c78" alt="Selecting branches"
|
|
|
|
|
2016-04-02 18:10:28 +05:30
|
|
|
You can then assign the merge request to someone to have them review
|
|
|
|
your changes. Upon pressing the 'Accept Merge Request' button, your
|
|
|
|
changes will be added to the repository and branch you're merging into.
|
2015-04-26 12:48:37 +05:30
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/e6c24/e6c248aa3a8c753306dee5fdf52c7720b3d032bd" alt="New merge request"
|
|
|
|
|
2016-04-02 18:10:28 +05:30
|
|
|
[gitlab flow]: https://about.gitlab.com/2014/09/29/gitlab-flow/ "GitLab Flow blog post"
|