454 lines
		
	
	
		
			14 KiB
		
	
	
	
		
			Plaintext
		
	
	
			
		
		
	
	
			454 lines
		
	
	
		
			14 KiB
		
	
	
	
		
			Plaintext
		
	
	
| git-rev-parse(1)
 | |
| ================
 | |
| 
 | |
| NAME
 | |
| ----
 | |
| git-rev-parse - Pick out and massage parameters
 | |
| 
 | |
| 
 | |
| SYNOPSIS
 | |
| --------
 | |
| [verse]
 | |
| 'git rev-parse' [ --option ] <args>...
 | |
| 
 | |
| DESCRIPTION
 | |
| -----------
 | |
| 
 | |
| Many Git porcelainish commands take mixture of flags
 | |
| (i.e. parameters that begin with a dash '-') and parameters
 | |
| meant for the underlying 'git rev-list' command they use internally
 | |
| and flags and parameters for the other commands they use
 | |
| downstream of 'git rev-list'.  This command is used to
 | |
| distinguish between them.
 | |
| 
 | |
| 
 | |
| OPTIONS
 | |
| -------
 | |
| 
 | |
| Operation Modes
 | |
| ~~~~~~~~~~~~~~~
 | |
| 
 | |
| Each of these options must appear first on the command line.
 | |
| 
 | |
| --parseopt::
 | |
| 	Use 'git rev-parse' in option parsing mode (see PARSEOPT section below).
 | |
| 
 | |
| --sq-quote::
 | |
| 	Use 'git rev-parse' in shell quoting mode (see SQ-QUOTE
 | |
| 	section below). In contrast to the `--sq` option below, this
 | |
| 	mode does only quoting. Nothing else is done to command input.
 | |
| 
 | |
| Options for --parseopt
 | |
| ~~~~~~~~~~~~~~~~~~~~~~
 | |
| 
 | |
| --keep-dashdash::
 | |
| 	Only meaningful in `--parseopt` mode. Tells the option parser to echo
 | |
| 	out the first `--` met instead of skipping it.
 | |
| 
 | |
| --stop-at-non-option::
 | |
| 	Only meaningful in `--parseopt` mode.  Lets the option parser stop at
 | |
| 	the first non-option argument.  This can be used to parse sub-commands
 | |
| 	that take options themselves.
 | |
| 
 | |
| --stuck-long::
 | |
| 	Only meaningful in `--parseopt` mode. Output the options in their
 | |
| 	long form if available, and with their arguments stuck.
 | |
| 
 | |
| Options for Filtering
 | |
| ~~~~~~~~~~~~~~~~~~~~~
 | |
| 
 | |
| --revs-only::
 | |
| 	Do not output flags and parameters not meant for
 | |
| 	'git rev-list' command.
 | |
| 
 | |
| --no-revs::
 | |
| 	Do not output flags and parameters meant for
 | |
| 	'git rev-list' command.
 | |
| 
 | |
| --flags::
 | |
| 	Do not output non-flag parameters.
 | |
| 
 | |
| --no-flags::
 | |
| 	Do not output flag parameters.
 | |
| 
 | |
| Options for Output
 | |
| ~~~~~~~~~~~~~~~~~~
 | |
| 
 | |
| --default <arg>::
 | |
| 	If there is no parameter given by the user, use `<arg>`
 | |
| 	instead.
 | |
| 
 | |
| --prefix <arg>::
 | |
| 	Behave as if 'git rev-parse' was invoked from the `<arg>`
 | |
| 	subdirectory of the working tree.  Any relative filenames are
 | |
| 	resolved as if they are prefixed by `<arg>` and will be printed
 | |
| 	in that form.
 | |
| +
 | |
| This can be used to convert arguments to a command run in a subdirectory
 | |
| so that they can still be used after moving to the top-level of the
 | |
| repository.  For example:
 | |
| +
 | |
| ----
 | |
| prefix=$(git rev-parse --show-prefix)
 | |
| cd "$(git rev-parse --show-toplevel)"
 | |
| # rev-parse provides the -- needed for 'set'
 | |
| eval "set $(git rev-parse --sq --prefix "$prefix" -- "$@")"
 | |
| ----
 | |
| 
 | |
| --verify::
 | |
| 	Verify that exactly one parameter is provided, and that it
 | |
| 	can be turned into a raw 20-byte SHA-1 that can be used to
 | |
| 	access the object database. If so, emit it to the standard
 | |
| 	output; otherwise, error out.
 | |
| +
 | |
| If you want to make sure that the output actually names an object in
 | |
| your object database and/or can be used as a specific type of object
 | |
| you require, you can add the `^{type}` peeling operator to the parameter.
 | |
| For example, `git rev-parse "$VAR^{commit}"` will make sure `$VAR`
 | |
| names an existing object that is a commit-ish (i.e. a commit, or an
 | |
| annotated tag that points at a commit).  To make sure that `$VAR`
 | |
| names an existing object of any type, `git rev-parse "$VAR^{object}"`
 | |
| can be used.
 | |
| 
 | |
| -q::
 | |
| --quiet::
 | |
| 	Only meaningful in `--verify` mode. Do not output an error
 | |
| 	message if the first argument is not a valid object name;
 | |
| 	instead exit with non-zero status silently.
 | |
| 	SHA-1s for valid object names are printed to stdout on success.
 | |
| 
 | |
| --sq::
 | |
| 	Usually the output is made one line per flag and
 | |
| 	parameter.  This option makes output a single line,
 | |
| 	properly quoted for consumption by shell.  Useful when
 | |
| 	you expect your parameter to contain whitespaces and
 | |
| 	newlines (e.g. when using pickaxe `-S` with
 | |
| 	'git diff-{asterisk}'). In contrast to the `--sq-quote` option,
 | |
| 	the command input is still interpreted as usual.
 | |
| 
 | |
| --short[=length]::
 | |
| 	Same as `--verify` but shortens the object name to a unique
 | |
| 	prefix with at least `length` characters. The minimum length
 | |
| 	is 4, the default is the effective value of the `core.abbrev`
 | |
| 	configuration variable (see linkgit:git-config[1]).
 | |
| 
 | |
| --not::
 | |
| 	When showing object names, prefix them with '{caret}' and
 | |
| 	strip '{caret}' prefix from the object names that already have
 | |
| 	one.
 | |
| 
 | |
| --abbrev-ref[=(strict|loose)]::
 | |
| 	A non-ambiguous short name of the objects name.
 | |
| 	The option core.warnAmbiguousRefs is used to select the strict
 | |
| 	abbreviation mode.
 | |
| 
 | |
| --symbolic::
 | |
| 	Usually the object names are output in SHA-1 form (with
 | |
| 	possible '{caret}' prefix); this option makes them output in a
 | |
| 	form as close to the original input as possible.
 | |
| 
 | |
| --symbolic-full-name::
 | |
| 	This is similar to --symbolic, but it omits input that
 | |
| 	are not refs (i.e. branch or tag names; or more
 | |
| 	explicitly disambiguating "heads/master" form, when you
 | |
| 	want to name the "master" branch when there is an
 | |
| 	unfortunately named tag "master"), and show them as full
 | |
| 	refnames (e.g. "refs/heads/master").
 | |
| 
 | |
| Options for Objects
 | |
| ~~~~~~~~~~~~~~~~~~~
 | |
| 
 | |
| --all::
 | |
| 	Show all refs found in `refs/`.
 | |
| 
 | |
| --branches[=pattern]::
 | |
| --tags[=pattern]::
 | |
| --remotes[=pattern]::
 | |
| 	Show all branches, tags, or remote-tracking branches,
 | |
| 	respectively (i.e., refs found in `refs/heads`,
 | |
| 	`refs/tags`, or `refs/remotes`, respectively).
 | |
| +
 | |
| If a `pattern` is given, only refs matching the given shell glob are
 | |
| shown.  If the pattern does not contain a globbing character (`?`,
 | |
| `*`, or `[`), it is turned into a prefix match by appending `/*`.
 | |
| 
 | |
| --glob=pattern::
 | |
| 	Show all refs matching the shell glob pattern `pattern`. If
 | |
| 	the pattern does not start with `refs/`, this is automatically
 | |
| 	prepended.  If the pattern does not contain a globbing
 | |
| 	character (`?`, `*`, or `[`), it is turned into a prefix
 | |
| 	match by appending `/*`.
 | |
| 
 | |
| --exclude=<glob-pattern>::
 | |
| 	Do not include refs matching '<glob-pattern>' that the next `--all`,
 | |
| 	`--branches`, `--tags`, `--remotes`, or `--glob` would otherwise
 | |
| 	consider. Repetitions of this option accumulate exclusion patterns
 | |
| 	up to the next `--all`, `--branches`, `--tags`, `--remotes`, or
 | |
| 	`--glob` option (other options or arguments do not clear
 | |
| 	accumulated patterns).
 | |
| +
 | |
| The patterns given should not begin with `refs/heads`, `refs/tags`, or
 | |
| `refs/remotes` when applied to `--branches`, `--tags`, or `--remotes`,
 | |
| respectively, and they must begin with `refs/` when applied to `--glob`
 | |
| or `--all`. If a trailing '/{asterisk}' is intended, it must be given
 | |
| explicitly.
 | |
| 
 | |
| --disambiguate=<prefix>::
 | |
| 	Show every object whose name begins with the given prefix.
 | |
| 	The <prefix> must be at least 4 hexadecimal digits long to
 | |
| 	avoid listing each and every object in the repository by
 | |
| 	mistake.
 | |
| 
 | |
| Options for Files
 | |
| ~~~~~~~~~~~~~~~~~
 | |
| 
 | |
| --local-env-vars::
 | |
| 	List the GIT_* environment variables that are local to the
 | |
| 	repository (e.g. GIT_DIR or GIT_WORK_TREE, but not GIT_EDITOR).
 | |
| 	Only the names of the variables are listed, not their value,
 | |
| 	even if they are set.
 | |
| 
 | |
| --git-dir::
 | |
| 	Show `$GIT_DIR` if defined. Otherwise show the path to
 | |
| 	the .git directory. The path shown, when relative, is
 | |
| 	relative to the current working directory.
 | |
| +
 | |
| If `$GIT_DIR` is not defined and the current directory
 | |
| is not detected to lie in a Git repository or work tree
 | |
| print a message to stderr and exit with nonzero status.
 | |
| 
 | |
| --absolute-git-dir::
 | |
| 	Like `--git-dir`, but its output is always the canonicalized
 | |
| 	absolute path.
 | |
| 
 | |
| --git-common-dir::
 | |
| 	Show `$GIT_COMMON_DIR` if defined, else `$GIT_DIR`.
 | |
| 
 | |
| --is-inside-git-dir::
 | |
| 	When the current working directory is below the repository
 | |
| 	directory print "true", otherwise "false".
 | |
| 
 | |
| --is-inside-work-tree::
 | |
| 	When the current working directory is inside the work tree of the
 | |
| 	repository print "true", otherwise "false".
 | |
| 
 | |
| --is-bare-repository::
 | |
| 	When the repository is bare print "true", otherwise "false".
 | |
| 
 | |
| --resolve-git-dir <path>::
 | |
| 	Check if <path> is a valid repository or a gitfile that
 | |
| 	points at a valid repository, and print the location of the
 | |
| 	repository.  If <path> is a gitfile then the resolved path
 | |
| 	to the real repository is printed.
 | |
| 
 | |
| --git-path <path>::
 | |
| 	Resolve "$GIT_DIR/<path>" and takes other path relocation
 | |
| 	variables such as $GIT_OBJECT_DIRECTORY,
 | |
| 	$GIT_INDEX_FILE... into account. For example, if
 | |
| 	$GIT_OBJECT_DIRECTORY is set to /foo/bar then "git rev-parse
 | |
| 	--git-path objects/abc" returns /foo/bar/abc.
 | |
| 
 | |
| --show-cdup::
 | |
| 	When the command is invoked from a subdirectory, show the
 | |
| 	path of the top-level directory relative to the current
 | |
| 	directory (typically a sequence of "../", or an empty string).
 | |
| 
 | |
| --show-prefix::
 | |
| 	When the command is invoked from a subdirectory, show the
 | |
| 	path of the current directory relative to the top-level
 | |
| 	directory.
 | |
| 
 | |
| --show-toplevel::
 | |
| 	Show the absolute path of the top-level directory.
 | |
| 
 | |
| --show-superproject-working-tree
 | |
| 	Show the absolute path of the root of the superproject's
 | |
| 	working tree (if exists) that uses the current repository as
 | |
| 	its submodule.  Outputs nothing if the current repository is
 | |
| 	not used as a submodule by any project.
 | |
| 
 | |
| --shared-index-path::
 | |
| 	Show the path to the shared index file in split index mode, or
 | |
| 	empty if not in split-index mode.
 | |
| 
 | |
| Other Options
 | |
| ~~~~~~~~~~~~~
 | |
| 
 | |
| --since=datestring::
 | |
| --after=datestring::
 | |
| 	Parse the date string, and output the corresponding
 | |
| 	--max-age= parameter for 'git rev-list'.
 | |
| 
 | |
| --until=datestring::
 | |
| --before=datestring::
 | |
| 	Parse the date string, and output the corresponding
 | |
| 	--min-age= parameter for 'git rev-list'.
 | |
| 
 | |
| <args>...::
 | |
| 	Flags and parameters to be parsed.
 | |
| 
 | |
| 
 | |
| include::revisions.txt[]
 | |
| 
 | |
| PARSEOPT
 | |
| --------
 | |
| 
 | |
| In `--parseopt` mode, 'git rev-parse' helps massaging options to bring to shell
 | |
| scripts the same facilities C builtins have. It works as an option normalizer
 | |
| (e.g. splits single switches aggregate values), a bit like `getopt(1)` does.
 | |
| 
 | |
| It takes on the standard input the specification of the options to parse and
 | |
| understand, and echoes on the standard output a string suitable for `sh(1)` `eval`
 | |
| to replace the arguments with normalized ones.  In case of error, it outputs
 | |
| usage on the standard error stream, and exits with code 129.
 | |
| 
 | |
| Note: Make sure you quote the result when passing it to `eval`.  See
 | |
| below for an example.
 | |
| 
 | |
| Input Format
 | |
| ~~~~~~~~~~~~
 | |
| 
 | |
| 'git rev-parse --parseopt' input format is fully text based. It has two parts,
 | |
| separated by a line that contains only `--`. The lines before the separator
 | |
| (should be one or more) are used for the usage.
 | |
| The lines after the separator describe the options.
 | |
| 
 | |
| Each line of options has this format:
 | |
| 
 | |
| ------------
 | |
| <opt-spec><flags>*<arg-hint>? SP+ help LF
 | |
| ------------
 | |
| 
 | |
| `<opt-spec>`::
 | |
| 	its format is the short option character, then the long option name
 | |
| 	separated by a comma. Both parts are not required, though at least one
 | |
| 	is necessary. May not contain any of the `<flags>` characters.
 | |
| 	`h,help`, `dry-run` and `f` are examples of correct `<opt-spec>`.
 | |
| 
 | |
| `<flags>`::
 | |
| 	`<flags>` are of `*`, `=`, `?` or `!`.
 | |
| 	* Use `=` if the option takes an argument.
 | |
| 
 | |
| 	* Use `?` to mean that the option takes an optional argument. You
 | |
| 	  probably want to use the `--stuck-long` mode to be able to
 | |
| 	  unambiguously parse the optional argument.
 | |
| 
 | |
| 	* Use `*` to mean that this option should not be listed in the usage
 | |
| 	  generated for the `-h` argument. It's shown for `--help-all` as
 | |
| 	  documented in linkgit:gitcli[7].
 | |
| 
 | |
| 	* Use `!` to not make the corresponding negated long option available.
 | |
| 
 | |
| `<arg-hint>`::
 | |
| 	`<arg-hint>`, if specified, is used as a name of the argument in the
 | |
| 	help output, for options that take arguments. `<arg-hint>` is
 | |
| 	terminated by the first whitespace.  It is customary to use a
 | |
| 	dash to separate words in a multi-word argument hint.
 | |
| 
 | |
| The remainder of the line, after stripping the spaces, is used
 | |
| as the help associated to the option.
 | |
| 
 | |
| Blank lines are ignored, and lines that don't match this specification are used
 | |
| as option group headers (start the line with a space to create such
 | |
| lines on purpose).
 | |
| 
 | |
| Example
 | |
| ~~~~~~~
 | |
| 
 | |
| ------------
 | |
| OPTS_SPEC="\
 | |
| some-command [options] <args>...
 | |
| 
 | |
| some-command does foo and bar!
 | |
| --
 | |
| h,help    show the help
 | |
| 
 | |
| foo       some nifty option --foo
 | |
| bar=      some cool option --bar with an argument
 | |
| baz=arg   another cool option --baz with a named argument
 | |
| qux?path  qux may take a path argument but has meaning by itself
 | |
| 
 | |
|   An option group Header
 | |
| C?        option C with an optional argument"
 | |
| 
 | |
| eval "$(echo "$OPTS_SPEC" | git rev-parse --parseopt -- "$@" || echo exit $?)"
 | |
| ------------
 | |
| 
 | |
| 
 | |
| Usage text
 | |
| ~~~~~~~~~~
 | |
| 
 | |
| When `"$@"` is `-h` or `--help` in the above example, the following
 | |
| usage text would be shown:
 | |
| 
 | |
| ------------
 | |
| usage: some-command [options] <args>...
 | |
| 
 | |
|     some-command does foo and bar!
 | |
| 
 | |
|     -h, --help            show the help
 | |
|     --foo                 some nifty option --foo
 | |
|     --bar ...             some cool option --bar with an argument
 | |
|     --baz <arg>           another cool option --baz with a named argument
 | |
|     --qux[=<path>]        qux may take a path argument but has meaning by itself
 | |
| 
 | |
| An option group Header
 | |
|     -C[...]               option C with an optional argument
 | |
| ------------
 | |
| 
 | |
| SQ-QUOTE
 | |
| --------
 | |
| 
 | |
| In `--sq-quote` mode, 'git rev-parse' echoes on the standard output a
 | |
| single line suitable for `sh(1)` `eval`. This line is made by
 | |
| normalizing the arguments following `--sq-quote`. Nothing other than
 | |
| quoting the arguments is done.
 | |
| 
 | |
| If you want command input to still be interpreted as usual by
 | |
| 'git rev-parse' before the output is shell quoted, see the `--sq`
 | |
| option.
 | |
| 
 | |
| Example
 | |
| ~~~~~~~
 | |
| 
 | |
| ------------
 | |
| $ cat >your-git-script.sh <<\EOF
 | |
| #!/bin/sh
 | |
| args=$(git rev-parse --sq-quote "$@")   # quote user-supplied arguments
 | |
| command="git frotz -n24 $args"          # and use it inside a handcrafted
 | |
| 					# command line
 | |
| eval "$command"
 | |
| EOF
 | |
| 
 | |
| $ sh your-git-script.sh "a b'c"
 | |
| ------------
 | |
| 
 | |
| EXAMPLES
 | |
| --------
 | |
| 
 | |
| * Print the object name of the current commit:
 | |
| +
 | |
| ------------
 | |
| $ git rev-parse --verify HEAD
 | |
| ------------
 | |
| 
 | |
| * Print the commit object name from the revision in the $REV shell variable:
 | |
| +
 | |
| ------------
 | |
| $ git rev-parse --verify $REV^{commit}
 | |
| ------------
 | |
| +
 | |
| This will error out if $REV is empty or not a valid revision.
 | |
| 
 | |
| * Similar to above:
 | |
| +
 | |
| ------------
 | |
| $ git rev-parse --default master --verify $REV
 | |
| ------------
 | |
| +
 | |
| but if $REV is empty, the commit object name from master will be printed.
 | |
| 
 | |
| GIT
 | |
| ---
 | |
| Part of the linkgit:git[1] suite
 |