Documentation / git-push.txton commit t/lib-httpd: only route auth/dumb to dumb repos (05b5771)
   1git-push(1)
   2===========
   3
   4NAME
   5----
   6git-push - Update remote refs along with associated objects
   7
   8
   9SYNOPSIS
  10--------
  11[verse]
  12'git push' [--all | --mirror | --tags] [-n | --dry-run] [--receive-pack=<git-receive-pack>]
  13           [--repo=<repository>] [-f | --force] [--prune] [-v | --verbose] [-u | --set-upstream]
  14           [<repository> [<refspec>...]]
  15
  16DESCRIPTION
  17-----------
  18
  19Updates remote refs using local refs, while sending objects
  20necessary to complete the given refs.
  21
  22You can make interesting things happen to a repository
  23every time you push into it, by setting up 'hooks' there.  See
  24documentation for linkgit:git-receive-pack[1].
  25
  26
  27OPTIONS[[OPTIONS]]
  28------------------
  29<repository>::
  30        The "remote" repository that is destination of a push
  31        operation.  This parameter can be either a URL
  32        (see the section <<URLS,GIT URLS>> below) or the name
  33        of a remote (see the section <<REMOTES,REMOTES>> below).
  34
  35<refspec>...::
  36        The format of a <refspec> parameter is an optional plus
  37        `+`, followed by the source ref <src>, followed
  38        by a colon `:`, followed by the destination ref <dst>.
  39        It is used to specify with what <src> object the <dst> ref
  40        in the remote repository is to be updated.
  41+
  42The <src> is often the name of the branch you would want to push, but
  43it can be any arbitrary "SHA-1 expression", such as `master~4` or
  44`HEAD` (see linkgit:gitrevisions[7]).
  45+
  46The <dst> tells which ref on the remote side is updated with this
  47push. Arbitrary expressions cannot be used here, an actual ref must
  48be named. If `:`<dst> is omitted, the same ref as <src> will be
  49updated.
  50+
  51The object referenced by <src> is used to update the <dst> reference
  52on the remote side, but by default this is only allowed if the
  53update can fast-forward <dst>.  By having the optional leading `+`,
  54you can tell git to update the <dst> ref even when the update is not a
  55fast-forward.  This does *not* attempt to merge <src> into <dst>.  See
  56EXAMPLES below for details.
  57+
  58`tag <tag>` means the same as `refs/tags/<tag>:refs/tags/<tag>`.
  59+
  60Pushing an empty <src> allows you to delete the <dst> ref from
  61the remote repository.
  62+
  63The special refspec `:` (or `+:` to allow non-fast-forward updates)
  64directs git to push "matching" branches: for every branch that exists on
  65the local side, the remote side is updated if a branch of the same name
  66already exists on the remote side.  This is the default operation mode
  67if no explicit refspec is found (that is neither on the command line
  68nor in any Push line of the corresponding remotes file---see below).
  69
  70--all::
  71        Instead of naming each ref to push, specifies that all
  72        refs under `refs/heads/` be pushed.
  73
  74--prune::
  75        Remove remote branches that don't have a local counterpart. For example
  76        a remote branch `tmp` will be removed if a local branch with the same
  77        name doesn't exist any more. This also respects refspecs, e.g.
  78        `git push --prune remote refs/heads/*:refs/tmp/*` would
  79        make sure that remote `refs/tmp/foo` will be removed if `refs/heads/foo`
  80        doesn't exist.
  81
  82--mirror::
  83        Instead of naming each ref to push, specifies that all
  84        refs under `refs/` (which includes but is not
  85        limited to `refs/heads/`, `refs/remotes/`, and `refs/tags/`)
  86        be mirrored to the remote repository.  Newly created local
  87        refs will be pushed to the remote end, locally updated refs
  88        will be force updated on the remote end, and deleted refs
  89        will be removed from the remote end.  This is the default
  90        if the configuration option `remote.<remote>.mirror` is
  91        set.
  92
  93-n::
  94--dry-run::
  95        Do everything except actually send the updates.
  96
  97--porcelain::
  98        Produce machine-readable output.  The output status line for each ref
  99        will be tab-separated and sent to stdout instead of stderr.  The full
 100        symbolic names of the refs will be given.
 101
 102--delete::
 103        All listed refs are deleted from the remote repository. This is
 104        the same as prefixing all refs with a colon.
 105
 106--tags::
 107        All refs under `refs/tags` are pushed, in
 108        addition to refspecs explicitly listed on the command
 109        line.
 110
 111--receive-pack=<git-receive-pack>::
 112--exec=<git-receive-pack>::
 113        Path to the 'git-receive-pack' program on the remote
 114        end.  Sometimes useful when pushing to a remote
 115        repository over ssh, and you do not have the program in
 116        a directory on the default $PATH.
 117
 118-f::
 119--force::
 120        Usually, the command refuses to update a remote ref that is
 121        not an ancestor of the local ref used to overwrite it.
 122        This flag disables the check.  This can cause the
 123        remote repository to lose commits; use it with care.
 124
 125--repo=<repository>::
 126        This option is only relevant if no <repository> argument is
 127        passed in the invocation. In this case, 'git push' derives the
 128        remote name from the current branch: If it tracks a remote
 129        branch, then that remote repository is pushed to. Otherwise,
 130        the name "origin" is used. For this latter case, this option
 131        can be used to override the name "origin". In other words,
 132        the difference between these two commands
 133+
 134--------------------------
 135git push public         #1
 136git push --repo=public  #2
 137--------------------------
 138+
 139is that #1 always pushes to "public" whereas #2 pushes to "public"
 140only if the current branch does not track a remote branch. This is
 141useful if you write an alias or script around 'git push'.
 142
 143-u::
 144--set-upstream::
 145        For every branch that is up to date or successfully pushed, add
 146        upstream (tracking) reference, used by argument-less
 147        linkgit:git-pull[1] and other commands. For more information,
 148        see 'branch.<name>.merge' in linkgit:git-config[1].
 149
 150--thin::
 151--no-thin::
 152        These options are passed to linkgit:git-send-pack[1]. A thin transfer
 153        significantly reduces the amount of sent data when the sender and
 154        receiver share many of the same objects in common. The default is
 155        \--thin.
 156
 157-q::
 158--quiet::
 159        Suppress all output, including the listing of updated refs,
 160        unless an error occurs. Progress is not reported to the standard
 161        error stream.
 162
 163-v::
 164--verbose::
 165        Run verbosely.
 166
 167--progress::
 168        Progress status is reported on the standard error stream
 169        by default when it is attached to a terminal, unless -q
 170        is specified. This flag forces progress status even if the
 171        standard error stream is not directed to a terminal.
 172
 173--recurse-submodules=check::
 174        Check whether all submodule commits used by the revisions to be
 175        pushed are available on a remote tracking branch. Otherwise the
 176        push will be aborted and the command will exit with non-zero status.
 177
 178
 179include::urls-remotes.txt[]
 180
 181OUTPUT
 182------
 183
 184The output of "git push" depends on the transport method used; this
 185section describes the output when pushing over the git protocol (either
 186locally or via ssh).
 187
 188The status of the push is output in tabular form, with each line
 189representing the status of a single ref. Each line is of the form:
 190
 191-------------------------------
 192 <flag> <summary> <from> -> <to> (<reason>)
 193-------------------------------
 194
 195If --porcelain is used, then each line of the output is of the form:
 196
 197-------------------------------
 198 <flag> \t <from>:<to> \t <summary> (<reason>)
 199-------------------------------
 200
 201The status of up-to-date refs is shown only if --porcelain or --verbose
 202option is used.
 203
 204flag::
 205        A single character indicating the status of the ref:
 206(space);; for a successfully pushed fast-forward;
 207`+`;; for a successful forced update;
 208`-`;; for a successfully deleted ref;
 209`*`;; for a successfully pushed new ref;
 210`!`;; for a ref that was rejected or failed to push; and
 211`=`;; for a ref that was up to date and did not need pushing.
 212
 213summary::
 214        For a successfully pushed ref, the summary shows the old and new
 215        values of the ref in a form suitable for using as an argument to
 216        `git log` (this is `<old>..<new>` in most cases, and
 217        `<old>...<new>` for forced non-fast-forward updates).
 218+
 219For a failed update, more details are given:
 220+
 221--
 222rejected::
 223        Git did not try to send the ref at all, typically because it
 224        is not a fast-forward and you did not force the update.
 225
 226remote rejected::
 227        The remote end refused the update.  Usually caused by a hook
 228        on the remote side, or because the remote repository has one
 229        of the following safety options in effect:
 230        `receive.denyCurrentBranch` (for pushes to the checked out
 231        branch), `receive.denyNonFastForwards` (for forced
 232        non-fast-forward updates), `receive.denyDeletes` or
 233        `receive.denyDeleteCurrent`.  See linkgit:git-config[1].
 234
 235remote failure::
 236        The remote end did not report the successful update of the ref,
 237        perhaps because of a temporary error on the remote side, a
 238        break in the network connection, or other transient error.
 239--
 240
 241from::
 242        The name of the local ref being pushed, minus its
 243        `refs/<type>/` prefix. In the case of deletion, the
 244        name of the local ref is omitted.
 245
 246to::
 247        The name of the remote ref being updated, minus its
 248        `refs/<type>/` prefix.
 249
 250reason::
 251        A human-readable explanation. In the case of successfully pushed
 252        refs, no explanation is needed. For a failed ref, the reason for
 253        failure is described.
 254
 255Note about fast-forwards
 256------------------------
 257
 258When an update changes a branch (or more in general, a ref) that used to
 259point at commit A to point at another commit B, it is called a
 260fast-forward update if and only if B is a descendant of A.
 261
 262In a fast-forward update from A to B, the set of commits that the original
 263commit A built on top of is a subset of the commits the new commit B
 264builds on top of.  Hence, it does not lose any history.
 265
 266In contrast, a non-fast-forward update will lose history.  For example,
 267suppose you and somebody else started at the same commit X, and you built
 268a history leading to commit B while the other person built a history
 269leading to commit A.  The history looks like this:
 270
 271----------------
 272
 273      B
 274     /
 275 ---X---A
 276
 277----------------
 278
 279Further suppose that the other person already pushed changes leading to A
 280back to the original repository you two obtained the original commit X.
 281
 282The push done by the other person updated the branch that used to point at
 283commit X to point at commit A.  It is a fast-forward.
 284
 285But if you try to push, you will attempt to update the branch (that
 286now points at A) with commit B.  This does _not_ fast-forward.  If you did
 287so, the changes introduced by commit A will be lost, because everybody
 288will now start building on top of B.
 289
 290The command by default does not allow an update that is not a fast-forward
 291to prevent such loss of history.
 292
 293If you do not want to lose your work (history from X to B) nor the work by
 294the other person (history from X to A), you would need to first fetch the
 295history from the repository, create a history that contains changes done
 296by both parties, and push the result back.
 297
 298You can perform "git pull", resolve potential conflicts, and "git push"
 299the result.  A "git pull" will create a merge commit C between commits A
 300and B.
 301
 302----------------
 303
 304      B---C
 305     /   /
 306 ---X---A
 307
 308----------------
 309
 310Updating A with the resulting merge commit will fast-forward and your
 311push will be accepted.
 312
 313Alternatively, you can rebase your change between X and B on top of A,
 314with "git pull --rebase", and push the result back.  The rebase will
 315create a new commit D that builds the change between X and B on top of
 316A.
 317
 318----------------
 319
 320      B   D
 321     /   /
 322 ---X---A
 323
 324----------------
 325
 326Again, updating A with this commit will fast-forward and your push will be
 327accepted.
 328
 329There is another common situation where you may encounter non-fast-forward
 330rejection when you try to push, and it is possible even when you are
 331pushing into a repository nobody else pushes into. After you push commit
 332A yourself (in the first picture in this section), replace it with "git
 333commit --amend" to produce commit B, and you try to push it out, because
 334forgot that you have pushed A out already. In such a case, and only if
 335you are certain that nobody in the meantime fetched your earlier commit A
 336(and started building on top of it), you can run "git push --force" to
 337overwrite it. In other words, "git push --force" is a method reserved for
 338a case where you do mean to lose history.
 339
 340
 341Examples
 342--------
 343
 344`git push`::
 345        Works like `git push <remote>`, where <remote> is the
 346        current branch's remote (or `origin`, if no remote is
 347        configured for the current branch).
 348
 349`git push origin`::
 350        Without additional configuration, works like
 351        `git push origin :`.
 352+
 353The default behavior of this command when no <refspec> is given can be
 354configured by setting the `push` option of the remote.
 355+
 356For example, to default to pushing only the current branch to `origin`
 357use `git config remote.origin.push HEAD`.  Any valid <refspec> (like
 358the ones in the examples below) can be configured as the default for
 359`git push origin`.
 360
 361`git push origin :`::
 362        Push "matching" branches to `origin`. See
 363        <refspec> in the <<OPTIONS,OPTIONS>> section above for a
 364        description of "matching" branches.
 365
 366`git push origin master`::
 367        Find a ref that matches `master` in the source repository
 368        (most likely, it would find `refs/heads/master`), and update
 369        the same ref (e.g. `refs/heads/master`) in `origin` repository
 370        with it.  If `master` did not exist remotely, it would be
 371        created.
 372
 373`git push origin HEAD`::
 374        A handy way to push the current branch to the same name on the
 375        remote.
 376
 377`git push origin master:satellite/master dev:satellite/dev`::
 378        Use the source ref that matches `master` (e.g. `refs/heads/master`)
 379        to update the ref that matches `satellite/master` (most probably
 380        `refs/remotes/satellite/master`) in the `origin` repository, then
 381        do the same for `dev` and `satellite/dev`.
 382
 383`git push origin HEAD:master`::
 384        Push the current branch to the remote ref matching `master` in the
 385        `origin` repository. This form is convenient to push the current
 386        branch without thinking about its local name.
 387
 388`git push origin master:refs/heads/experimental`::
 389        Create the branch `experimental` in the `origin` repository
 390        by copying the current `master` branch.  This form is only
 391        needed to create a new branch or tag in the remote repository when
 392        the local name and the remote name are different; otherwise,
 393        the ref name on its own will work.
 394
 395`git push origin :experimental`::
 396        Find a ref that matches `experimental` in the `origin` repository
 397        (e.g. `refs/heads/experimental`), and delete it.
 398
 399`git push origin +dev:master`::
 400        Update the origin repository's master branch with the dev branch,
 401        allowing non-fast-forward updates.  *This can leave unreferenced
 402        commits dangling in the origin repository.*  Consider the
 403        following situation, where a fast-forward is not possible:
 404+
 405----
 406            o---o---o---A---B  origin/master
 407                     \
 408                      X---Y---Z  dev
 409----
 410+
 411The above command would change the origin repository to
 412+
 413----
 414                      A---B  (unnamed branch)
 415                     /
 416            o---o---o---X---Y---Z  master
 417----
 418+
 419Commits A and B would no longer belong to a branch with a symbolic name,
 420and so would be unreachable.  As such, these commits would be removed by
 421a `git gc` command on the origin repository.
 422
 423GIT
 424---
 425Part of the linkgit:git[1] suite