Johannes Schindelin <Johannes.Schindelin@xxxxxx> writes: >> +A complete bundle is one that does not require you to have any > > I have not heard of any "complete" bundle before, and I do not understand > the need for such a definition, either. Sorry, that's mine, not Jidanni's fault. I agree that we do not necessarily have to introduce a new term. >> +as if it was a remote repository, like this: >> + >> +---------------- >> +$ git clone /home/me/tmp/file.bdl mine.git >> +---------------- >> + >> +This will define a remote called "origin" in the resulting >> +repository that lets you fetch and pull from the bundle, just >> +like the previous example lets you do with the remote called >> +"bundle", and from then on you can fetch/pull to update the >> +resulting mine.git repository after replacing the bundle you store >> +at /home/me/tmp/file.bdl with incremental updates. > > IMO this paragraph just adds words, not anything the user does not know > already by that stage. True again. The only justification that an example of cloning from a complete (or "baseless" or "full" or whatever new term we have already agreed that is not needed ;-)) bundle in the example I can think of is that by having such an example way earlier in the example sequence, we could show a full cycle of sneakernetting into a repository. You bootstrap it by cloning from a complete bundle, so that the clone has remotes set up to facilitate further updates via fetch/pull pointing at a known location. Then you drop a new bundle to the same location that is relative to an earlier one, and pull from it to incrementally keep the repository up-to-date. In other words, we currently have a very cursory description that says you can ls-remote and fetch from a bundle at the end, and mention that the remote configuration can be defined to facilitate repeated sneakernet operation. But we could reorganize the example this way (the ones with asterisk are already in our example section, the ones with plus are additions): * you first create a full bundle without basis $ git bundle create mybundle master * you make note of the current tip to optimize later bundles $ git tag -f lastR2bundle master + sneakernet it and clone it to prime the recipient ... sneakernet mybundle to /home/me/tmp/mybundle $ git clone /home/me/tmp/mybundle mine.git + after working more in the original, create an incremental bundle $ git bundle create mybundle lastR2bundle..master $ git tag -f lastR2bundle master + sneakernet it again, and use it to update the recipient ... sneakernet the new mybundle to /home/me/tmp/mybundle $ git pull /home/me/tmp/mybundle mine.git to show the simplest "full cycle" of sneakernet workflow. And then show various variations we already have in the existing examples. Something like: In addition, if you know up to what commit the intended recipient repository should have the necessary objects for, you can use that knowledge to specify the basis, giving a cut-off point to limit the revisions and objects that go in to the resulting bundle. Here are the examples: * using a tag present in both to optimize the bundle $ git bundle create mybundle master ^v1.0.0 * using a basis based on time to optimize the bundle $ git bundle create mybundle master --since=10.days * using the number of commits to optimize the bundle $ git bundle create mybundle master -n 10 A bundle from a recipient repository's point of view is just like a regular repository it fetches/pulls from. You can for example map refs, like this example, when fetching. $ git fetch mybundle master:localRef Or see what refs it offers $ git ls-remote mybundle -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html