'\" t .\" Title: git-push .\" Author: [FIXME: author] [see http://docbook.sf.net/el/author] .\" Generator: DocBook XSL Stylesheets v1.79.1 .\" Date: 01/05/2019 .\" Manual: Git Manual .\" Source: Git 2.20.1 .\" Language: English .\" .TH "GIT\-PUSH" "1" "01/05/2019" "Git 2\&.20\&.1" "Git Manual" .\" ----------------------------------------------------------------- .\" * Define some portability stuff .\" ----------------------------------------------------------------- .\" ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ .\" http://bugs.debian.org/507673 .\" http://lists.gnu.org/archive/html/groff/2009-02/msg00013.html .\" ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ .ie \n(.g .ds Aq \(aq .el .ds Aq ' .\" ----------------------------------------------------------------- .\" * set default formatting .\" ----------------------------------------------------------------- .\" disable hyphenation .nh .\" disable justification (adjust text to left margin only) .ad l .\" ----------------------------------------------------------------- .\" * MAIN CONTENT STARTS HERE * .\" ----------------------------------------------------------------- .SH "NAME" git-push \- Update remote refs along with associated objects .SH "SYNOPSIS" .sp .nf \fIgit push\fR [\-\-all | \-\-mirror | \-\-tags] [\-\-follow\-tags] [\-\-atomic] [\-n | \-\-dry\-run] [\-\-receive\-pack=] [\-\-repo=] [\-f | \-\-force] [\-d | \-\-delete] [\-\-prune] [\-v | \-\-verbose] [\-u | \-\-set\-upstream] [\-o | \-\-push\-option=] [\-\-[no\-]signed|\-\-signed=(true|false|if\-asked)] [\-\-force\-with\-lease[=[:]]] [\-\-no\-verify] [ [\&...]] .fi .sp .SH "DESCRIPTION" .sp Updates remote refs using local refs, while sending objects necessary to complete the given refs\&. .sp You can make interesting things happen to a repository every time you push into it, by setting up \fIhooks\fR there\&. See documentation for \fBgit-receive-pack\fR(1)\&. .sp When the command line does not specify where to push with the \fB\fR argument, \fBbranch\&.*\&.remote\fR configuration for the current branch is consulted to determine where to push\&. If the configuration is missing, it defaults to \fIorigin\fR\&. .sp When the command line does not specify what to push with \fB\&.\&.\&.\fR arguments or \fB\-\-all\fR, \fB\-\-mirror\fR, \fB\-\-tags\fR options, the command finds the default \fB\fR by consulting \fBremote\&.*\&.push\fR configuration, and if it is not found, honors \fBpush\&.default\fR configuration to decide what to push (See \fBgit-config\fR(1) for the meaning of \fBpush\&.default\fR)\&. .sp When neither the command\-line nor the configuration specify what to push, the default behavior is used, which corresponds to the \fBsimple\fR value for \fBpush\&.default\fR: the current branch is pushed to the corresponding upstream branch, but as a safety measure, the push is aborted if the upstream branch does not have the same name as the local one\&. .SH "OPTIONS" .PP .RS 4 The "remote" repository that is destination of a push operation\&. This parameter can be either a URL (see the section GIT URLS below) or the name of a remote (see the section REMOTES below)\&. .RE .PP \&... .RS 4 Specify what destination ref to update with what source object\&. The format of a parameter is an optional plus \fB+\fR, followed by the source object , followed by a colon \fB:\fR, followed by the destination ref \&. .sp The is often the name of the branch you would want to push, but it can be any arbitrary "SHA\-1 expression", such as \fBmaster~4\fR or \fBHEAD\fR (see \fBgitrevisions\fR(7))\&. .sp The tells which ref on the remote side is updated with this push\&. Arbitrary expressions cannot be used here, an actual ref must be named\&. If \fBgit push []\fR without any \fB\fR argument is set to update some ref at the destination with \fB\fR with \fBremote\&.\&.push\fR configuration variable, \fB:\fR part can be omitted\(emsuch a push will update a ref that \fB\fR normally updates without any \fB\fR on the command line\&. Otherwise, missing \fB:\fR means to update the same ref as the \fB\fR\&. .sp The object referenced by is used to update the reference on the remote side\&. Whether this is allowed depends on where in \fBrefs/*\fR the reference lives as described in detail below, in those sections "update" means any modifications except deletes, which as noted after the next few sections are treated differently\&. .sp The \fBrefs/heads/*\fR namespace will only accept commit objects, and updates only if they can be fast\-forwarded\&. .sp The \fBrefs/tags/*\fR namespace will accept any kind of object (as commits, trees and blobs can be tagged), and any updates to them will be rejected\&. .sp It\(cqs possible to push any type of object to any namespace outside of \fBrefs/{tags,heads}/*\fR\&. In the case of tags and commits, these will be treated as if they were the commits inside \fBrefs/heads/*\fR for the purposes of whether the update is allowed\&. .sp I\&.e\&. a fast\-forward of commits and tags outside \fBrefs/{tags,heads}/*\fR is allowed, even in cases where what\(cqs being fast\-forwarded is not a commit, but a tag object which happens to point to a new commit which is a fast\-forward of the commit the last tag (or commit) it\(cqs replacing\&. Replacing a tag with an entirely different tag is also allowed, if it points to the same commit, as well as pushing a peeled tag, i\&.e\&. pushing the commit that existing tag object points to, or a new tag object which an existing commit points to\&. .sp Tree and blob objects outside of \fBrefs/{tags,heads}/*\fR will be treated the same way as if they were inside \fBrefs/tags/*\fR, any update of them will be rejected\&. .sp All of the rules described above about what\(cqs not allowed as an update can be overridden by adding an the optional leading \fB+\fR to a refspec (or using \fB\-\-force\fR command line option)\&. The only exception to this is that no amount of forcing will make the \fBrefs/heads/*\fR namespace accept a non\-commit object\&. Hooks and configuration can also override or amend these rules, see e\&.g\&. \fBreceive\&.denyNonFastForwards\fR in \fBgit-config\fR(1) and \fBpre\-receive\fR and \fBupdate\fR in \fBgithooks\fR(5)\&. .sp Pushing an empty allows you to delete the ref from the remote repository\&. Deletions are always accepted without a leading \fB+\fR in the refspec (or \fB\-\-force\fR), except when forbidden by configuration or hooks\&. See \fBreceive\&.denyDeletes\fR in \fBgit-config\fR(1) and \fBpre\-receive\fR and \fBupdate\fR in \fBgithooks\fR(5)\&. .sp The special refspec \fB:\fR (or \fB+:\fR to allow non\-fast\-forward updates) directs Git to push "matching" branches: for every branch that exists on the local side, the remote side is updated if a branch of the same name already exists on the remote side\&. .sp \fBtag \fR means the same as \fBrefs/tags/:refs/tags/\fR\&. .RE .PP \-\-all .RS 4 Push all branches (i\&.e\&. refs under \fBrefs/heads/\fR); cannot be used with other \&. .RE .PP \-\-prune .RS 4 Remove remote branches that don\(cqt have a local counterpart\&. For example a remote branch \fBtmp\fR will be removed if a local branch with the same name doesn\(cqt exist any more\&. This also respects refspecs, e\&.g\&. \fBgit push \-\-prune remote refs/heads/*:refs/tmp/*\fR would make sure that remote \fBrefs/tmp/foo\fR will be removed if \fBrefs/heads/foo\fR doesn\(cqt exist\&. .RE .PP \-\-mirror .RS 4 Instead of naming each ref to push, specifies that all refs under \fBrefs/\fR (which includes but is not limited to \fBrefs/heads/\fR, \fBrefs/remotes/\fR, and \fBrefs/tags/\fR) be mirrored to the remote repository\&. Newly created local refs will be pushed to the remote end, locally updated refs will be force updated on the remote end, and deleted refs will be removed from the remote end\&. This is the default if the configuration option \fBremote\&.\&.mirror\fR is set\&. .RE .PP \-n, \-\-dry\-run .RS 4 Do everything except actually send the updates\&. .RE .PP \-\-porcelain .RS 4 Produce machine\-readable output\&. The output status line for each ref will be tab\-separated and sent to stdout instead of stderr\&. The full symbolic names of the refs will be given\&. .RE .PP \-d, \-\-delete .RS 4 All listed refs are deleted from the remote repository\&. This is the same as prefixing all refs with a colon\&. .RE .PP \-\-tags .RS 4 All refs under \fBrefs/tags\fR are pushed, in addition to refspecs explicitly listed on the command line\&. .RE .PP \-\-follow\-tags .RS 4 Push all the refs that would be pushed without this option, and also push annotated tags in \fBrefs/tags\fR that are missing from the remote but are pointing at commit\-ish that are reachable from the refs being pushed\&. This can also be specified with configuration variable \fBpush\&.followTags\fR\&. For more information, see \fBpush\&.followTags\fR in \fBgit-config\fR(1)\&. .RE .PP \-\-[no\-]signed, \-\-signed=(true|false|if\-asked) .RS 4 GPG\-sign the push request to update refs on the receiving side, to allow it to be checked by the hooks and/or be logged\&. If \fBfalse\fR or \fB\-\-no\-signed\fR, no signing will be attempted\&. If \fBtrue\fR or \fB\-\-signed\fR, the push will fail if the server does not support signed pushes\&. If set to \fBif\-asked\fR, sign if and only if the server supports signed pushes\&. The push will also fail if the actual call to \fBgpg \-\-sign\fR fails\&. See \fBgit-receive-pack\fR(1) for the details on the receiving end\&. .RE .PP \-\-[no\-]atomic .RS 4 Use an atomic transaction on the remote side if available\&. Either all refs are updated, or on error, no refs are updated\&. If the server does not support atomic pushes the push will fail\&. .RE .PP \-o