From: Philip Oakley <philipoakley@xxxxxxx> Git URLs can accept bundle files for fetch, pull and clone, include in that section. Include git clone in the bundle usage description. Correct the quoting of <git-rev-list-args>. Detail the <git-rev-list-args> options for cloning a complete repo. Signed-off-by: Philip Oakley <philipoakley@iee.email> --- This takes up the advice from peff in https://public-inbox.org/git/20191011161112.GA19741@xxxxxxxxxxxxxxxxxxxxx/ from the original v1 in 2012(!) https://public-inbox.org/git/1348010734-664-2-git-send-email-philipoakley@xxxxxxx/ Hopefully this covers Junio's concerns from that time. -- Philip --- Documentation/git-bundle.txt | 10 +++++++--- Documentation/urls.txt | 3 +++ 2 files changed, 10 insertions(+), 3 deletions(-) diff --git a/Documentation/git-bundle.txt b/Documentation/git-bundle.txt index 7d6c9dcd17..0498e4895d 100644 --- a/Documentation/git-bundle.txt +++ b/Documentation/git-bundle.txt @@ -21,9 +21,9 @@ Some workflows require that one or more branches of development on one machine be replicated on another machine, but the two machines cannot be directly connected, and therefore the interactive Git protocols (git, ssh, http) cannot be used. This command provides support for -'git fetch' and 'git pull' to operate by packaging objects and references +'git fetch' and 'git pull' and 'git clone', to operate by packaging objects and references in an archive at the originating machine, then importing those into -another repository using 'git fetch' and 'git pull' +another repository using 'git fetch' and 'git pull' or 'git clone', after moving the archive by some means (e.g., by sneakernet). As no direct connection between the repositories exists, the user must specify a basis for the bundle that is held by the destination repository: the @@ -35,7 +35,7 @@ OPTIONS create <file>:: Used to create a bundle named 'file'. This requires the - 'git-rev-list-args' arguments to define the bundle contents. + '<git-rev-list-args>' arguments to define the bundle contents. verify <file>:: Used to check that a bundle file is valid and will apply @@ -92,6 +92,10 @@ It is okay to err on the side of caution, causing the bundle file to contain objects already in the destination, as these are ignored when unpacking at the destination. +To create a bundle for 'git clone', use `--branches --tags` for +the <git-rev-list-args>. The (inappropriate) use of `--all` would include +refs from refs/remotes/* hierarchy in the resulting bundle. + EXAMPLES -------- diff --git a/Documentation/urls.txt b/Documentation/urls.txt index bc354fe2dc..1c229d7581 100644 --- a/Documentation/urls.txt +++ b/Documentation/urls.txt @@ -53,6 +53,9 @@ These two syntaxes are mostly equivalent, except the former implies --local option. endif::git-clone[] +'git clone', 'git fetch' and 'git pull', but not 'git push', will also +accept a suitable bundle file. See linkgit:git-bundle[1]. + When Git doesn't know how to handle a certain transport protocol, it attempts to use the 'remote-<transport>' remote helper, if one exists. To explicitly request a remote helper, the following syntax -- 2.23.0.windows.1.21.g947f504ebe8.dirty