mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-11-03 08:02:36 +09:00 
			
		
		
		
	Clarify Agit PR creation documentation See https://github.com/go-gitea/gitea/issues/27579
		
			
				
	
	
		
			53 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			53 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
---
 | 
						|
date: "	2022-09-01T20:50:42+0000"
 | 
						|
title: "Agit Setup"
 | 
						|
slug: "agit-setup"
 | 
						|
sidebar_position: 12
 | 
						|
toc: false
 | 
						|
draft: false
 | 
						|
aliases:
 | 
						|
  - /en-us/agit-setup
 | 
						|
menu:
 | 
						|
  sidebar:
 | 
						|
    parent: "usage"
 | 
						|
    name: "Agit Setup"
 | 
						|
    sidebar_position: 12
 | 
						|
    identifier: "agit-setup"
 | 
						|
---
 | 
						|
 | 
						|
# Agit Setup
 | 
						|
 | 
						|
In Gitea `1.13`, support for [agit](https://git-repo.info/en/2020/03/agit-flow-and-git-repo/) was added.
 | 
						|
**Note**: git version 2.29 or higher is required on the server side for this to work.
 | 
						|
 | 
						|
## Creating PRs with Agit
 | 
						|
 | 
						|
Agit allows to create PRs while pushing code to the remote repo.
 | 
						|
This can be done by pushing to the branch followed by a specific refspec (a location identifier known to git).
 | 
						|
The following example illustrates this:
 | 
						|
 | 
						|
```shell
 | 
						|
git push origin HEAD:refs/for/main
 | 
						|
```
 | 
						|
 | 
						|
The command has the following structure:
 | 
						|
 | 
						|
- `HEAD`: The target branch
 | 
						|
- `origin`: The target repository (not a fork!)
 | 
						|
- `HEAD`: The local branch containing the changes you are proposing
 | 
						|
- `refs/<for|draft|for-review>/<branch>`: The target PR type and configuration
 | 
						|
  - `for`: Create a normal PR with `<branch>` as the target branch
 | 
						|
  - `draft`/`for-review`: Currently ignored silently
 | 
						|
  - `<branch>/`: The branch you want your changes to be merged into
 | 
						|
- `-o <topic|title|description>`: Options for the PR
 | 
						|
  - `topic`: The topic of this change. It will become the name of the branch holding the changes waiting for review.  This is REQUIRED to trigger a pull request.
 | 
						|
  - `title`: The PR title (optional but recommended), only used for topics not already having an associated PR.
 | 
						|
  - `description`: The PR description (optional but recommended), only used for topics not already having an associated PR.
 | 
						|
  - `force-push`: confirm force update the target branch
 | 
						|
 | 
						|
Here's another advanced example for creating a new PR targeting `main` with `topic`, `title`, and `description`:
 | 
						|
 | 
						|
```shell
 | 
						|
git push origin HEAD:refs/for/main -o topic="Topic of my PR" -o title="Title of the PR" -o description="# The PR Description\nThis can be **any** markdown content.\n- [x] Ok"
 | 
						|
```
 |