Sync with 1.8.1.5
authorJunio C Hamano <gitster@pobox.com>
Fri, 1 Mar 2013 21:17:18 +0000 (13:17 -0800)
committerJunio C Hamano <gitster@pobox.com>
Fri, 1 Mar 2013 21:17:18 +0000 (13:17 -0800)
1  2 
Documentation/git.txt
Documentation/githooks.txt
attr.c
t/t0003-attributes.sh
diff --combined Documentation/git.txt
index 79aa8cd1491993f3651488b63bd7c5ab67897d1e,608fa3963dd0652329ce5a2c4b97acd66533d877..9d29ed55042432bb976836347203b2d83dc27056
@@@ -27,11 -27,11 +27,11 @@@ commands.  The link:user-manual.html[Gi
  in-depth introduction.
  
  After you mastered the basic concepts, you can come back to this
 -page to learn what commands git offers.  You can learn more about
 -individual git commands with "git help command".  linkgit:gitcli[7]
 +page to learn what commands Git offers.  You can learn more about
 +individual Git commands with "git help command".  linkgit:gitcli[7]
  manual page gives you an overview of the command line command syntax.
  
 -Formatted and hyperlinked version of the latest git documentation
 +Formatted and hyperlinked version of the latest Git documentation
  can be viewed at `http://git-htmldocs.googlecode.com/git/git.html`.
  
  ifdef::stalenotes[]
  ============
  
  You are reading the documentation for the latest (possibly
 -unreleased) version of git, that is available from 'master'
 +unreleased) version of Git, that is available from 'master'
  branch of the `git.git` repository.
  Documentation for older releases are available here:
  
- * link:v1.8.1.4/git.html[documentation for release 1.8.1.4]
+ * link:v1.8.1.5/git.html[documentation for release 1.8.1.5]
  
  * release notes for
+   link:RelNotes/1.8.1.5.txt[1.8.1.5],
    link:RelNotes/1.8.1.4.txt[1.8.1.4],
    link:RelNotes/1.8.1.3.txt[1.8.1.3],
    link:RelNotes/1.8.1.2.txt[1.8.1.2],
@@@ -358,12 -359,12 +359,12 @@@ endif::stalenotes[
  OPTIONS
  -------
  --version::
 -      Prints the git suite version that the 'git' program came from.
 +      Prints the Git suite version that the 'git' program came from.
  
  --help::
        Prints the synopsis and a list of the most commonly used
        commands. If the option '--all' or '-a' is given then all
 -      available commands are printed. If a git command is named this
 +      available commands are printed. If a Git command is named this
        option will bring up the manual page for that command.
  +
  Other options are available to control how the manual page is
@@@ -378,22 -379,22 +379,22 @@@ help ...`
        'git config' (subkeys separated by dots).
  
  --exec-path[=<path>]::
 -      Path to wherever your core git programs are installed.
 +      Path to wherever your core Git programs are installed.
        This can also be controlled by setting the GIT_EXEC_PATH
        environment variable. If no path is given, 'git' will print
        the current setting and then exit.
  
  --html-path::
 -      Print the path, without trailing slash, where git's HTML
 +      Print the path, without trailing slash, where Git's HTML
        documentation is installed and exit.
  
  --man-path::
        Print the manpath (see `man(1)`) for the man pages for
 -      this version of git and exit.
 +      this version of Git and exit.
  
  --info-path::
        Print the path where the Info files documenting this
 -      version of git are installed and exit.
 +      version of Git are installed and exit.
  
  -p::
  --paginate::
        below).
  
  --no-pager::
 -      Do not pipe git output into a pager.
 +      Do not pipe Git output into a pager.
  
  --git-dir=<path>::
        Set the path to the repository. This can also be controlled by
        more detailed discussion).
  
  --namespace=<path>::
 -      Set the git namespace.  See linkgit:gitnamespaces[7] for more
 +      Set the Git namespace.  See linkgit:gitnamespaces[7] for more
        details.  Equivalent to setting the `GIT_NAMESPACE` environment
        variable.
  
        directory.
  
  --no-replace-objects::
 -      Do not use replacement refs to replace git objects. See
 +      Do not use replacement refs to replace Git objects. See
        linkgit:git-replace[1] for more information.
  
 +--literal-pathspecs::
 +      Treat pathspecs literally, rather than as glob patterns. This is
 +      equivalent to setting the `GIT_LITERAL_PATHSPECS` environment
 +      variable to `1`.
 +
  
  GIT COMMANDS
  ------------
  
 -We divide git into high level ("porcelain") commands and low level
 +We divide Git into high level ("porcelain") commands and low level
  ("plumbing") commands.
  
  High-level commands (porcelain)
@@@ -478,7 -474,7 +479,7 @@@ include::cmds-foreignscminterface.txt[
  Low-level commands (plumbing)
  -----------------------------
  
 -Although git includes its
 +Although Git includes its
  own porcelain layer, its low-level commands are sufficient to support
  development of alternative porcelains.  Developers of such porcelains
  might start by reading about linkgit:git-update-index[1] and
@@@ -598,7 -594,7 +599,7 @@@ Identifier Terminolog
  
  Symbolic Identifiers
  --------------------
 -Any git command accepting any <object> can also use the following
 +Any Git command accepting any <object> can also use the following
  symbolic notation:
  
  HEAD::
@@@ -634,13 -630,13 +635,13 @@@ Please see linkgit:gitglossary[7]
  
  Environment Variables
  ---------------------
 -Various git commands use the following environment variables:
 +Various Git commands use the following environment variables:
  
 -The git Repository
 +The Git Repository
  ~~~~~~~~~~~~~~~~~~
 -These environment variables apply to 'all' core git commands. Nb: it
 +These environment variables apply to 'all' core Git commands. Nb: it
  is worth noting that they may be used/overridden by SCMS sitting above
 -git so take care if using Cogito etc.
 +Git so take care if using Cogito etc.
  
  'GIT_INDEX_FILE'::
        This environment allows the specification of an alternate
        directory is used.
  
  'GIT_ALTERNATE_OBJECT_DIRECTORIES'::
 -      Due to the immutable nature of git objects, old objects can be
 +      Due to the immutable nature of Git objects, old objects can be
        archived into shared, read-only directories. This variable
        specifies a ":" separated (on Windows ";" separated) list
 -      of git object directories which can be used to search for git
 +      of Git object directories which can be used to search for Git
        objects. New objects will not be written to these directories.
  
  'GIT_DIR'::
        option and the core.worktree configuration variable.
  
  'GIT_NAMESPACE'::
 -      Set the git namespace; see linkgit:gitnamespaces[7] for details.
 +      Set the Git namespace; see linkgit:gitnamespaces[7] for details.
        The '--namespace' command-line option also sets this value.
  
  'GIT_CEILING_DIRECTORIES'::
 -      This should be a colon-separated list of absolute paths.
 -      If set, it is a list of directories that git should not chdir
 -      up into while looking for a repository directory.
 -      It will not exclude the current working directory or
 -      a GIT_DIR set on the command line or in the environment.
 -      (Useful for excluding slow-loading network directories.)
 +      This should be a colon-separated list of absolute paths.  If
 +      set, it is a list of directories that Git should not chdir up
 +      into while looking for a repository directory (useful for
 +      excluding slow-loading network directories).  It will not
 +      exclude the current working directory or a GIT_DIR set on the
 +      command line or in the environment.  Normally, Git has to read
 +      the entries in this list and resolve any symlink that
 +      might be present in order to compare them with the current
 +      directory.  However, if even this access is slow, you
 +      can add an empty entry to the list to tell Git that the
 +      subsequent entries are not symlinks and needn't be resolved;
 +      e.g.,
 +      'GIT_CEILING_DIRECTORIES=/maybe/symlink::/very/slow/non/symlink'.
  
  'GIT_DISCOVERY_ACROSS_FILESYSTEM'::
        When run in a directory that does not have ".git" repository
 -      directory, git tries to find such a directory in the parent
 +      directory, Git tries to find such a directory in the parent
        directories to find the top of the working tree, but by default it
        does not cross filesystem boundaries.  This environment variable
 -      can be set to true to tell git not to stop at filesystem
 +      can be set to true to tell Git not to stop at filesystem
        boundaries.  Like 'GIT_CEILING_DIRECTORIES', this will not affect
        an explicit repository directory set via 'GIT_DIR' or on the
        command line.
  
 -git Commits
 +Git Commits
  ~~~~~~~~~~~
  'GIT_AUTHOR_NAME'::
  'GIT_AUTHOR_EMAIL'::
  'EMAIL'::
        see linkgit:git-commit-tree[1]
  
 -git Diffs
 +Git Diffs
  ~~~~~~~~~
  'GIT_DIFF_OPTS'::
        Only valid setting is "--unified=??" or "-u??" to set the
        number of context lines shown when a unified diff is created.
        This takes precedence over any "-U" or "--unified" option
 -      value passed on the git diff command line.
 +      value passed on the Git diff command line.
  
  'GIT_EXTERNAL_DIFF'::
        When the environment variable 'GIT_EXTERNAL_DIFF' is set, the
@@@ -754,13 -743,13 +755,13 @@@ othe
  
  'GIT_PAGER'::
        This environment variable overrides `$PAGER`. If it is set
 -      to an empty string or to the value "cat", git will not launch
 +      to an empty string or to the value "cat", Git will not launch
        a pager.  See also the `core.pager` option in
        linkgit:git-config[1].
  
  'GIT_EDITOR'::
        This environment variable overrides `$EDITOR` and `$VISUAL`.
 -      It is used by several git commands when, on interactive mode,
 +      It is used by several Git commands when, on interactive mode,
        an editor is to be launched. See also linkgit:git-var[1]
        and the `core.editor` option in linkgit:git-config[1].
  
@@@ -781,7 -770,7 +782,7 @@@ personal `.ssh/config` file.  Please co
  for further details.
  
  'GIT_ASKPASS'::
 -      If this environment variable is set, then git commands which need to
 +      If this environment variable is set, then Git commands which need to
        acquire passwords or passphrases (e.g. for HTTP or IMAP authentication)
        will call this program with a suitable prompt as command line argument
        and read the password from its STDOUT. See also the 'core.askpass'
        after each commit-oriented record have been flushed.   If this
        variable is set to "0", the output of these commands will be done
        using completely buffered I/O.   If this environment variable is
 -      not set, git will choose buffered or record-oriented flushing
 +      not set, Git will choose buffered or record-oriented flushing
        based on whether stdout appears to be redirected to a file or not.
  
  'GIT_TRACE'::
        If this variable is set to "1", "2" or "true" (comparison
 -      is case insensitive), git will print `trace:` messages on
 +      is case insensitive), Git will print `trace:` messages on
        stderr telling about alias expansion, built-in command
        execution and external command execution.
        If this variable is set to an integer value greater than 1
 -      and lower than 10 (strictly) then git will interpret this
 +      and lower than 10 (strictly) then Git will interpret this
        value as an open file descriptor and will try to write the
        trace messages into this file descriptor.
        Alternatively, if this variable is set to an absolute path
 -      (starting with a '/' character), git will interpret this
 +      (starting with a '/' character), Git will interpret this
        as a file path and will try to write the trace messages
        into it.
  
 +GIT_LITERAL_PATHSPECS::
 +      Setting this variable to `1` will cause Git to treat all
 +      pathspecs literally, rather than as glob patterns. For example,
 +      running `GIT_LITERAL_PATHSPECS=1 git log -- '*.c'` will search
 +      for commits that touch the path `*.c`, not any paths that the
 +      glob `*.c` matches. You might want this if you are feeding
 +      literal paths to Git (e.g., paths previously given to you by
 +      `git ls-tree`, `--raw` diff output, etc).
 +
 +
  Discussion[[Discussion]]
  ------------------------
  
  More detail on the following is available from the
 -link:user-manual.html#git-concepts[git concepts chapter of the
 +link:user-manual.html#git-concepts[Git concepts chapter of the
  user-manual] and linkgit:gitcore-tutorial[7].
  
 -A git project normally consists of a working directory with a ".git"
 +A Git project normally consists of a working directory with a ".git"
  subdirectory at the top level.  The .git directory contains, among other
  things, a compressed object database representing the complete history
  of the project, an "index" file which links that history to the current
@@@ -886,12 -865,12 +887,12 @@@ FURTHER DOCUMENTATIO
  ---------------------
  
  See the references in the "description" section to get started
 -using git.  The following is probably more detail than necessary
 +using Git.  The following is probably more detail than necessary
  for a first-time user.
  
 -The link:user-manual.html#git-concepts[git concepts chapter of the
 +The link:user-manual.html#git-concepts[Git concepts chapter of the
  user-manual] and linkgit:gitcore-tutorial[7] both provide
 -introductions to the underlying git architecture.
 +introductions to the underlying Git architecture.
  
  See linkgit:gitworkflows[7] for an overview of recommended workflows.
  
@@@ -899,7 -878,7 +900,7 @@@ See also the link:howto-index.html[howt
  examples.
  
  The internals are documented in the
 -link:technical/api-index.html[GIT API documentation].
 +link:technical/api-index.html[Git API documentation].
  
  Users migrating from CVS may also want to
  read linkgit:gitcvs-migration[7].
  Authors
  -------
  Git was started by Linus Torvalds, and is currently maintained by Junio
 -C Hamano. Numerous contributions have come from the git mailing list
 +C Hamano. Numerous contributions have come from the Git mailing list
  <git@vger.kernel.org>.  http://www.ohloh.net/p/git/contributors/summary
  gives you a more complete list of contributors.
  
index 8181e4ed2ad815e5cdc3fe840c9bcdad33ffdd2d,4e0d2a08a11a2dd0af3bd77c5fd0041ea7e1d97e..eab9b356cd67cff9221aec16b34204622f15116f
@@@ -3,7 -3,7 +3,7 @@@ githooks(5
  
  NAME
  ----
 -githooks - Hooks used by git
 +githooks - Hooks used by Git
  
  SYNOPSIS
  --------
@@@ -108,7 -108,7 +108,7 @@@ it is not suppressed by the `--no-verif
  means a failure of the hook and aborts the commit.  It should not
  be used as replacement for pre-commit hook.
  
 -The sample `prepare-commit-msg` hook that comes with git comments
 +The sample `prepare-commit-msg` hook that comes with Git comments
  out the `Conflicts:` part of a merge's commit message.
  
  commit-msg
@@@ -176,35 -176,6 +176,35 @@@ save and restore any form of metadata a
  (eg: permissions/ownership, ACLS, etc).  See contrib/hooks/setgitperms.perl
  for an example of how to do this.
  
 +pre-push
 +~~~~~~~~
 +
 +This hook is called by 'git push' and can be used to prevent a push from taking
 +place.  The hook is called with two parameters which provide the name and
 +location of the destination remote, if a named remote is not being used both
 +values will be the same.
 +
 +Information about what is to be pushed is provided on the hook's standard
 +input with lines of the form:
 +
 +  <local ref> SP <local sha1> SP <remote ref> SP <remote sha1> LF
 +
 +For instance, if the command +git push origin master:foreign+ were run the
 +hook would receive a line like the following:
 +
 +  refs/heads/master 67890 refs/heads/foreign 12345
 +
 +although the full, 40-character SHA1s would be supplied.  If the foreign ref
 +does not yet exist the `<remote SHA1>` will be 40 `0`.  If a ref is to be
 +deleted, the `<local ref>` will be supplied as `(delete)` and the `<local
 +SHA1>` will be 40 `0`.  If the local commit was specified by something other
 +than a name which could be expanded (such as `HEAD~`, or a SHA1) it will be
 +supplied as it was originally given.
 +
 +If this hook exits with a non-zero status, 'git push' will abort without
 +pushing anything.  Information about why the push is rejected may be sent
 +to the user by writing to standard error.
 +
  [[pre-receive]]
  pre-receive
  ~~~~~~~~~~~
@@@ -304,7 -275,7 +304,7 @@@ for the user
  
  The default 'post-receive' hook is empty, but there is
  a sample script `post-receive-email` provided in the `contrib/hooks`
 -directory in git distribution, which implements sending commit
 +directory in Git distribution, which implements sending commit
  emails.
  
  [[post-update]]
@@@ -332,7 -303,7 +332,7 @@@ them
  When enabled, the default 'post-update' hook runs
  'git update-server-info' to keep the information used by dumb
  transports (e.g., HTTP) up-to-date.  If you are publishing
 -a git repository that is accessible via HTTP, you should
 +a Git repository that is accessible via HTTP, you should
  probably enable this hook.
  
  Both standard output and standard error output are forwarded to
@@@ -365,7 -336,7 +365,7 @@@ preceding SP is also omitted.  Currentl
  'extra-info'.
  
  The hook always runs after the automatic note copying (see
- "notes.rewrite.<command>" in linkgit:git-config.txt) has happened, and
+ "notes.rewrite.<command>" in linkgit:git-config.txt[1]) has happened, and
  thus has access to these notes.
  
  The following command-specific comments apply:
diff --combined attr.c
index 4657cc233c4aa7cff90e745a58ac7ad0a5fa8cd2,d181d98b0e12959bff2074720c77daea661429dd..e2f9377891a7f6e0d56803016726e3cd3137fdc2
--- 1/attr.c
--- 2/attr.c
+++ b/attr.c
@@@ -255,9 -255,11 +255,11 @@@ static struct match_attr *parse_attr_li
                                      &res->u.pat.patternlen,
                                      &res->u.pat.flags,
                                      &res->u.pat.nowildcardlen);
-               if (res->u.pat.flags & EXC_FLAG_NEGATIVE)
-                       die(_("Negative patterns are forbidden in git attributes\n"
-                             "Use '\\!' for literal leading exclamation."));
+               if (res->u.pat.flags & EXC_FLAG_NEGATIVE) {
+                       warning(_("Negative patterns are ignored in git attributes\n"
+                                 "Use '\\!' for literal leading exclamation."));
+                       return NULL;
+               }
        }
        res->is_macro = is_macro;
        res->num_attr = num_attr;
   * (reading the file from top to bottom), .gitattribute of the root
   * directory (again, reading the file from top to bottom) down to the
   * current directory, and then scan the list backwards to find the first match.
 - * This is exactly the same as what excluded() does in dir.c to deal with
 + * This is exactly the same as what is_excluded() does in dir.c to deal with
   * .gitignore
   */
  
diff --combined t/t0003-attributes.sh
index 43b25137e9878e41557fd7d095cc991c27efdfc7,1035a14b37203202a5476f65d07f9bc505bfb52c..0b98b6f8d090ecc3dfb48fe6fda5889dfbc5e018
@@@ -198,7 -198,8 +198,8 @@@ test_expect_success 'root subdir attrib
  
  test_expect_success 'negative patterns' '
        echo "!f test=bar" >.gitattributes &&
-       test_must_fail git check-attr test -- f
+       git check-attr test -- '"'"'!f'"'"' 2>errors &&
+       test_i18ngrep "Negative patterns are ignored" errors
  '
  
  test_expect_success 'patterns starting with exclamation' '
        attr_check "!f" foo
  '
  
 +test_expect_success '"**" test' '
 +      echo "**/f foo=bar" >.gitattributes &&
 +      cat <<\EOF >expect &&
 +f: foo: bar
 +a/f: foo: bar
 +a/b/f: foo: bar
 +a/b/c/f: foo: bar
 +EOF
 +      git check-attr foo -- "f" >actual 2>err &&
 +      git check-attr foo -- "a/f" >>actual 2>>err &&
 +      git check-attr foo -- "a/b/f" >>actual 2>>err &&
 +      git check-attr foo -- "a/b/c/f" >>actual 2>>err &&
 +      test_cmp expect actual &&
 +      test_line_count = 0 err
 +'
 +
 +test_expect_success '"**" with no slashes test' '
 +      echo "a**f foo=bar" >.gitattributes &&
 +      git check-attr foo -- "f" >actual &&
 +      cat <<\EOF >expect &&
 +f: foo: unspecified
 +af: foo: bar
 +axf: foo: bar
 +a/f: foo: unspecified
 +a/b/f: foo: unspecified
 +a/b/c/f: foo: unspecified
 +EOF
 +      git check-attr foo -- "f" >actual 2>err &&
 +      git check-attr foo -- "af" >>actual 2>err &&
 +      git check-attr foo -- "axf" >>actual 2>err &&
 +      git check-attr foo -- "a/f" >>actual 2>>err &&
 +      git check-attr foo -- "a/b/f" >>actual 2>>err &&
 +      git check-attr foo -- "a/b/c/f" >>actual 2>>err &&
 +      test_cmp expect actual &&
 +      test_line_count = 0 err
 +'
 +
  test_expect_success 'setup bare' '
        git clone --bare . bare.git &&
        cd bare.git