Merge branch 'mg/maint-doc-sparse-checkout'
authorJunio C Hamano <gitster@pobox.com>
Wed, 5 Oct 2011 19:36:25 +0000 (12:36 -0700)
committerJunio C Hamano <gitster@pobox.com>
Wed, 5 Oct 2011 19:36:25 +0000 (12:36 -0700)
* mg/maint-doc-sparse-checkout:
git-read-tree.txt: correct sparse-checkout and skip-worktree description
git-read-tree.txt: language and typography fixes
unpack-trees: print "Aborting" to stderr

1  2 
Documentation/git-read-tree.txt
unpack-trees.c
index c45d53c6e150479bd01bf3d643354348d8ce9273,c7fc1ceb5ef5d841e3b99a1b9d8787e3436eacc0..1bd0317a42e587a28ae39b26da38889275bfd058
@@@ -8,7 -8,6 +8,7 @@@ git-read-tree - Reads tree information 
  
  SYNOPSIS
  --------
 +[verse]
  'git read-tree' [[-m [--trivial] [--aggressive] | --reset | --prefix=<prefix>]
                [-u [--exclude-per-directory=<gitignore>] | -i]]
                [--index-output=<file>] [--no-sparse-checkout]
@@@ -47,7 -46,7 +47,7 @@@ OPTION
  
  -i::
        Usually a merge requires the index file as well as the
-       files in the working tree are up to date with the
+       files in the working tree to be up to date with the
        current head commit, in order not to lose local
        changes.  This flag disables the check with the working
        tree and is meant to be used when creating a merge of
  --aggressive::
        Usually a three-way merge by 'git read-tree' resolves
        the merge for really trivial cases and leaves other
-       cases unresolved in the index, so that Porcelains can
+       cases unresolved in the index, so that porcelains can
        implement different merge policies.  This flag makes the
-       command to resolve a few more cases internally:
+       command resolve a few more cases internally:
  +
  * when one side removes a path and the other side leaves the path
    unmodified.  The resolution is to remove that path.
  * when both sides remove a path.  The resolution is to remove that path.
- * when both sides adds a path identically.  The resolution
+ * when both sides add a path identically.  The resolution
    is to add that path.
  
  --prefix=<prefix>/::
        Keep the current index contents, and read the contents
-       of named tree-ish under directory at `<prefix>`.  The
+       of the named tree-ish under the directory at `<prefix>`. The
        original index file cannot have anything at the path
-       `<prefix>` itself, and have nothing in `<prefix>/`
+       `<prefix>` itself, nor anything in the `<prefix>/`
        directory.  Note that the `<prefix>/` value must end
        with a slash.
  
@@@ -379,36 -378,36 +379,36 @@@ have finished your work-in-progress), a
  Sparse checkout
  ---------------
  
- "Sparse checkout" allows to sparsely populate working directory.
- It uses skip-worktree bit (see linkgit:git-update-index[1]) to tell
- Git whether a file on working directory is worth looking at.
+ "Sparse checkout" allows populating the working directory sparsely.
+ It uses the skip-worktree bit (see linkgit:git-update-index[1]) to tell
+ Git whether a file in the working directory is worth looking at.
  
"git read-tree" and other merge-based commands ("git merge", "git
- checkout"...) can help maintaining skip-worktree bitmap and working
'git read-tree' and other merge-based commands ('git merge', 'git
+ checkout'...) can help maintaining the skip-worktree bitmap and working
  directory update. `$GIT_DIR/info/sparse-checkout` is used to
- define the skip-worktree reference bitmap. When "git read-tree" needs
- to update working directory, it will reset skip-worktree bit in index
+ define the skip-worktree reference bitmap. When 'git read-tree' needs
+ to update the working directory, it resets the skip-worktree bit in the index
  based on this file, which uses the same syntax as .gitignore files.
- If an entry matches a pattern in this file, skip-worktree will be
- set on that entry. Otherwise, skip-worktree will be unset.
+ If an entry matches a pattern in this file, skip-worktree will not be
+ set on that entry. Otherwise, skip-worktree will be set.
  
  Then it compares the new skip-worktree value with the previous one. If
- skip-worktree turns from unset to set, it will add the corresponding
- file back. If it turns from set to unset, that file will be removed.
+ skip-worktree turns from set to unset, it will add the corresponding
+ file back. If it turns from unset to set, that file will be removed.
  
  While `$GIT_DIR/info/sparse-checkout` is usually used to specify what
- files are in. You can also specify what files are _not_ in, using
- negate patterns. For example, to remove file "unwanted":
+ files are in, you can also specify what files are _not_ in, using
+ negate patterns. For example, to remove the file `unwanted`:
  
  ----------------
  *
  !unwanted
  ----------------
  
- Another tricky thing is fully repopulating working directory when you
+ Another tricky thing is fully repopulating the working directory when you
  no longer want sparse checkout. You cannot just disable "sparse
- checkout" because skip-worktree are still in the index and you working
- directory is still sparsely populated. You should re-populate working
+ checkout" because skip-worktree bits are still in the index and your working
+ directory is still sparsely populated. You should re-populate the working
  directory with the `$GIT_DIR/info/sparse-checkout` file content as
  follows:
  
  *
  ----------------
  
- Then you can disable sparse checkout. Sparse checkout support in "git
- read-tree" and similar commands is disabled by default. You need to
+ Then you can disable sparse checkout. Sparse checkout support in 'git
+ read-tree' and similar commands is disabled by default. You need to
  turn `core.sparseCheckout` on in order to have sparse checkout
  support.
  
diff --combined unpack-trees.c
index 670b46473883505c39c5353c65e0eeb93aec21c3,cad8870720eca6c4a94b95e0bde2e7e5d9eacedd..237aed8c766638c55d8d6b870c86ef2ad13a74d3
@@@ -159,7 -159,7 +159,7 @@@ static void display_error_msgs(struct u
                string_list_clear(rejects, 0);
        }
        if (something_displayed)
-               printf("Aborting\n");
+               fprintf(stderr, "Aborting\n");
  }
  
  /*
@@@ -444,7 -444,6 +444,7 @@@ static int traverse_trees_recursive(in
  
        newinfo = *info;
        newinfo.prev = info;
 +      newinfo.pathspec = info->pathspec;
        newinfo.name = *p;
        newinfo.pathlen += tree_entry_len(p->path, p->sha1) + 1;
        newinfo.conflicts |= df_conflicts;
@@@ -594,7 -593,7 +594,7 @@@ static int unpack_nondirectories(int n
  static int unpack_failed(struct unpack_trees_options *o, const char *message)
  {
        discard_index(&o->result);
 -      if (!o->gently) {
 +      if (!o->gently && !o->exiting_early) {
                if (message)
                        return error("%s", message);
                return -1;
@@@ -1041,7 -1040,6 +1041,7 @@@ int unpack_trees(unsigned len, struct t
                info.fn = unpack_callback;
                info.data = o;
                info.show_all_errors = o->show_all_errors;
 +              info.pathspec = o->pathspec;
  
                if (o->prefix) {
                        /*
@@@ -1135,8 -1133,6 +1135,8 @@@ return_failed
                display_error_msgs(o);
        mark_all_ce_unused(o->src_index);
        ret = unpack_failed(o, NULL);
 +      if (o->exiting_early)
 +              ret = 0;
        goto done;
  }
  
@@@ -1170,22 -1166,11 +1170,22 @@@ static int verify_uptodate_1(struct cac
  {
        struct stat st;
  
 -      if (o->index_only || (!((ce->ce_flags & CE_VALID) || ce_skip_worktree(ce)) && (o->reset || ce_uptodate(ce))))
 +      if (o->index_only)
 +              return 0;
 +
 +      /*
 +       * CE_VALID and CE_SKIP_WORKTREE cheat, we better check again
 +       * if this entry is truly up-to-date because this file may be
 +       * overwritten.
 +       */
 +      if ((ce->ce_flags & CE_VALID) || ce_skip_worktree(ce))
 +              ; /* keep checking */
 +      else if (o->reset || ce_uptodate(ce))
                return 0;
  
        if (!lstat(ce->name, &st)) {
 -              unsigned changed = ie_match_stat(o->src_index, ce, &st, CE_MATCH_IGNORE_VALID|CE_MATCH_IGNORE_SKIP_WORKTREE);
 +              int flags = CE_MATCH_IGNORE_VALID|CE_MATCH_IGNORE_SKIP_WORKTREE;
 +              unsigned changed = ie_match_stat(o->src_index, ce, &st, flags);
                if (!changed)
                        return 0;
                /*