78 lines
2.6 KiB
Plaintext
78 lines
2.6 KiB
Plaintext
GIT URLS[[URLS]]
|
|
----------------
|
|
|
|
One of the following notations can be used
|
|
to name the remote repository:
|
|
|
|
===============================================================
|
|
- rsync://host.xz/path/to/repo.git/
|
|
- http://host.xz/path/to/repo.git/
|
|
- https://host.xz/path/to/repo.git/
|
|
- git://host.xz/path/to/repo.git/
|
|
- git://host.xz/~user/path/to/repo.git/
|
|
- ssh://{startsb}user@{endsb}host.xz/path/to/repo.git/
|
|
- ssh://{startsb}user@{endsb}host.xz/~user/path/to/repo.git/
|
|
- ssh://{startsb}user@{endsb}host.xz/~/path/to/repo.git
|
|
===============================================================
|
|
|
|
SSH is the default transport protocol. You can optionally specify
|
|
which user to log-in as, and an alternate, scp-like syntax is also
|
|
supported. Both syntaxes support username expansion,
|
|
as does the native git protocol. The following three are
|
|
identical to the last three above, respectively:
|
|
|
|
===============================================================
|
|
- {startsb}user@{endsb}host.xz:/path/to/repo.git/
|
|
- {startsb}user@{endsb}host.xz:~user/path/to/repo.git/
|
|
- {startsb}user@{endsb}host.xz:path/to/repo.git
|
|
===============================================================
|
|
|
|
To sync with a local directory, use:
|
|
|
|
===============================================================
|
|
- /path/to/repo.git/
|
|
===============================================================
|
|
|
|
REMOTES
|
|
-------
|
|
|
|
In addition to the above, as a short-hand, the name of a
|
|
file in `$GIT_DIR/remotes` directory can be given; the
|
|
named file should be in the following format:
|
|
|
|
URL: one of the above URL format
|
|
Push: <refspec>
|
|
Pull: <refspec>
|
|
|
|
Then such a short-hand is specified in place of
|
|
<repository> without <refspec> parameters on the command
|
|
line, <refspec> specified on `Push:` lines or `Pull:`
|
|
lines are used for `git-push` and `git-fetch`/`git-pull`,
|
|
respectively. Multiple `Push:` and `Pull:` lines may
|
|
be specified for additional branch mappings.
|
|
|
|
Or, equivalently, in the `$GIT_DIR/config` (note the use
|
|
of `fetch` instead of `Pull:`):
|
|
|
|
[remote "<remote>"]
|
|
url = <url>
|
|
push = <refspec>
|
|
fetch = <refspec>
|
|
|
|
The name of a file in `$GIT_DIR/branches` directory can be
|
|
specified as an older notation short-hand; the named
|
|
file should contain a single line, a URL in one of the
|
|
above formats, optionally followed by a hash `#` and the
|
|
name of remote head (URL fragment notation).
|
|
`$GIT_DIR/branches/<remote>` file that stores a <url>
|
|
without the fragment is equivalent to have this in the
|
|
corresponding file in the `$GIT_DIR/remotes/` directory.
|
|
|
|
URL: <url>
|
|
Pull: refs/heads/master:<remote>
|
|
|
|
while having `<url>#<head>` is equivalent to
|
|
|
|
URL: <url>
|
|
Pull: refs/heads/<head>:<remote>
|