# This shell scriplet is meant to be included by other shell scripts # to set up some variables pointing at the normal git directories and # a few helper shell functions. # Having this variable in your environment would break scripts because # you would cause "cd" to be taken to unexpected places. If you # like CDPATH, define it for your interactive shell sessions without # exporting it. # But we protect ourselves from such a user mistake nevertheless. unset CDPATH # Similarly for IFS, but some shells (e.g. FreeBSD 7.2) are buggy and # do not equate an unset IFS with IFS with the default, so here is # an explicit SP HT LF. IFS=' ' git_broken_path_fix () { case ":$PATH:" in *:$1:*) : ok ;; *) PATH=$( SANE_TOOL_PATH="$1" IFS=: path= sep= set x $PATH shift for elem do case "$SANE_TOOL_PATH:$elem" in (?*:/bin | ?*:/usr/bin) path="$path$sep$SANE_TOOL_PATH" sep=: SANE_TOOL_PATH= esac path="$path$sep$elem" sep=: done echo "$path" ) ;; esac } # Source git-sh-i18n for gettext support. . "$(git --exec-path)/git-sh-i18n" die () { die_with_status 1 "$@" } die_with_status () { status=$1 shift printf >&2 '%s\n' "$*" exit "$status" } if test -n "$OPTIONS_SPEC"; then usage() { "$0" -h exit 1 } parseopt_extra= [ -n "$OPTIONS_KEEPDASHDASH" ] && parseopt_extra="--keep-dashdash" [ -n "$OPTIONS_STUCKLONG" ] && parseopt_extra="$parseopt_extra --stuck-long" eval "$( echo "$OPTIONS_SPEC" | git rev-parse --parseopt $parseopt_extra -- "$@" || echo exit $? )" else dashless=$(basename -- "$0" | sed -e 's/-/ /') usage() { die "$(eval_gettext "usage: \$dashless \$USAGE")" } if [ -z "$LONG_USAGE" ] then LONG_USAGE="$(eval_gettext "usage: \$dashless \$USAGE")" else LONG_USAGE="$(eval_gettext "usage: \$dashless \$USAGE $LONG_USAGE")" fi case "$1" in -h) echo "$LONG_USAGE" exit esac fi # Set the name of the end-user facing command in the reflog when the # script may update refs. When GIT_REFLOG_ACTION is already set, this # will not overwrite it, so that a scripted Porcelain (e.g. "git # rebase") can set it to its own name (e.g. "rebase") and then call # another scripted Porcelain (e.g. "git am") and a call to this # function in the latter will keep the name of the end-user facing # program (e.g. "rebase") in GIT_REFLOG_ACTION, ensuring whatever it # does will be record as actions done as part of the end-user facing # operation (e.g. "rebase"). # # NOTE NOTE NOTE: consequently, after assigning a specific message to # GIT_REFLOG_ACTION when calling a "git" command to record a custom # reflog message, do not leave that custom value in GIT_REFLOG_ACTION, # after you are done. Other callers of "git" commands that rely on # writing the default "program name" in reflog expect the variable to # contain the value set by this function. # # To use a custom reflog message, do either one of these three: # # (a) use a single-shot export form: # GIT_REFLOG_ACTION="$GIT_REFLOG_ACTION: preparing frotz" \ # git command-that-updates-a-ref # # (b) save the original away and restore: # SAVED_ACTION=$GIT_REFLOG_ACTION # GIT_REFLOG_ACTION="$GIT_REFLOG_ACTION: preparing frotz" # git command-that-updates-a-ref # GIT_REFLOG_ACITON=$SAVED_ACTION # # (c) assign the variable in a subshell: # ( # GIT_REFLOG_ACTION="$GIT_REFLOG_ACTION: preparing frotz" # git command-that-updates-a-ref # ) set_reflog_action() { if [ -z "${GIT_REFLOG_ACTION:+set}" ] then GIT_REFLOG_ACTION="$*" export GIT_REFLOG_ACTION fi } git_editor() { if test -z "${GIT_EDITOR:+set}" then GIT_EDITOR="$(git var GIT_EDITOR)" || return $? fi eval "$GIT_EDITOR" '"$@"' } git_pager() { if test -t 1 then GIT_PAGER=$(git var GIT_PAGER) else GIT_PAGER=cat fi for vardef in LESS=FRX LV=-c do var=${vardef%%=*} eval ": \"\${$vardef}\" && export $var" done eval "$GIT_PAGER" '"$@"' } is_bare_repository () { git rev-parse --is-bare-repository } cd_to_toplevel () { cdup=$(git rev-parse --show-toplevel) && cd "$cdup" || { gettextln "Cannot chdir to \$cdup, the toplevel of the working tree" >&2 exit 1 } } require_work_tree_exists () { if test "z$(git rev-parse --is-bare-repository)" != zfalse then program_name=$0 die "$(eval_gettext "fatal: \$program_name cannot be used without a working tree.")" fi } require_work_tree () { test "$(git rev-parse --is-inside-work-tree 2>/dev/null)" = true || { program_name=$0 die "$(eval_gettext "fatal: \$program_name cannot be used without a working tree.")" } } require_clean_work_tree () { git rev-parse --verify HEAD >/dev/null || exit 1 git update-index -q --ignore-submodules --refresh err=0 if ! git diff-files --quiet --ignore-submodules then action=$1 case "$action" in "rewrite branches") gettextln "Cannot rewrite branches: You have unstaged changes." >&2 ;; *) eval_gettextln "Cannot \$action: You have unstaged changes." >&2 ;; esac err=1 fi if ! git diff-index --cached --quiet --ignore-submodules HEAD -- then if test $err = 0 then action=$1 eval_gettextln "Cannot \$action: Your index contains uncommitted changes." >&2 else gettextln "Additionally, your index contains uncommitted changes." >&2 fi err=1 fi if test $err = 1 then test -n "$2" && echo "$2" >&2 exit 1 fi } # Generate a sed script to parse identities from a commit. # # Reads the commit from stdin, which should be in raw format (e.g., from # cat-file or "--pretty=raw"). # # The first argument specifies the ident line to parse (e.g., "author"), and # the second specifies the environment variable to put it in (e.g., "AUTHOR" # for "GIT_AUTHOR_*"). Multiple pairs can be given to parse author and # committer. pick_ident_script () { while test $# -gt 0 do lid=$1; shift uid=$1; shift printf '%s' " /^$lid /{ s/'/'\\\\''/g h s/^$lid "'\([^<]*\) <[^>]*> .*$/\1/'" s/.*/GIT_${uid}_NAME='&'/p g s/^$lid "'[^<]* <\([^>]*\)> .*$/\1/'" s/.*/GIT_${uid}_EMAIL='&'/p g s/^$lid "'[^<]* <[^>]*> \(.*\)$/@\1/'" s/.*/GIT_${uid}_DATE='&'/p } " done echo '/^$/q' } # Create a pick-script as above and feed it to sed. Stdout is suitable for # feeding to eval. parse_ident_from_commit () { LANG=C LC_ALL=C sed -ne "$(pick_ident_script "$@")" } # Parse the author from a commit given as an argument. Stdout is suitable for # feeding to eval to set the usual GIT_* ident variables. get_author_ident_from_commit () { encoding=$(git config i18n.commitencoding || echo UTF-8) git show -s --pretty=raw --encoding="$encoding" "$1" -- | parse_ident_from_commit author AUTHOR } # Generate a virtual base file for a two-file merge. Uses git apply to # remove lines from $1 that are not in $2, leaving only common lines. create_virtual_base() { sz0=$(wc -c <"$1") diff -u -La/"$1" -Lb/"$1" "$1" "$2" | git apply --no-add sz1=$(wc -c <"$1") # If we do not have enough common material, it is not # worth trying two-file merge using common subsections. expr $sz0 \< $sz1 \* 2 >/dev/null || : >"$1" } # Platform specific tweaks to work around some commands case $(uname -s) in *MINGW*) # Windows has its own (incompatible) sort and find sort () { /usr/bin/sort "$@" } find () { /usr/bin/find "$@" } # git sees Windows-style pwd pwd () { builtin pwd -W } is_absolute_path () { case "$1" in [/\\]* | [A-Za-z]:*) return 0 ;; esac return 1 } ;; *) is_absolute_path () { case "$1" in /*) return 0 ;; esac return 1 } esac # Make sure we are in a valid repository of a vintage we understand, # if we require to be in a git repository. git_dir_init () { GIT_DIR=$(git rev-parse --git-dir) || exit if [ -z "$SUBDIRECTORY_OK" ] then test -z "$(git rev-parse --show-cdup)" || { exit=$? gettextln "You need to run this command from the toplevel of the working tree." >&2 exit $exit } fi test -n "$GIT_DIR" && GIT_DIR=$(cd "$GIT_DIR" && pwd) || { gettextln "Unable to determine absolute path of git directory" >&2 exit 1 } : "${GIT_OBJECT_DIRECTORY="$(git rev-parse --git-path objects)"}" } if test -z "$NONGIT_OK" then git_dir_init fi peel_committish () { case "$1" in :/*) peeltmp=$(git rev-parse --verify "$1") && git rev-parse --verify "${peeltmp}^0" ;; *) git rev-parse --verify "${1}^0" ;; esac }
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
mergetools | Folder | 0755 |
|
|
git | File | 3.67 MB | 0755 |
|
git-add | File | 3.67 MB | 0755 |
|
git-am | File | 3.67 MB | 0755 |
|
git-annotate | File | 3.67 MB | 0755 |
|
git-apply | File | 3.67 MB | 0755 |
|
git-archive | File | 3.67 MB | 0755 |
|
git-bisect | File | 3.67 MB | 0755 |
|
git-blame | File | 3.67 MB | 0755 |
|
git-branch | File | 3.67 MB | 0755 |
|
git-bugreport | File | 3.67 MB | 0755 |
|
git-bundle | File | 3.67 MB | 0755 |
|
git-cat-file | File | 3.67 MB | 0755 |
|
git-check-attr | File | 3.67 MB | 0755 |
|
git-check-ignore | File | 3.67 MB | 0755 |
|
git-check-mailmap | File | 3.67 MB | 0755 |
|
git-check-ref-format | File | 3.67 MB | 0755 |
|
git-checkout | File | 3.67 MB | 0755 |
|
git-checkout--worker | File | 3.67 MB | 0755 |
|
git-checkout-index | File | 3.67 MB | 0755 |
|
git-cherry | File | 3.67 MB | 0755 |
|
git-cherry-pick | File | 3.67 MB | 0755 |
|
git-clean | File | 3.67 MB | 0755 |
|
git-clone | File | 3.67 MB | 0755 |
|
git-column | File | 3.67 MB | 0755 |
|
git-commit | File | 3.67 MB | 0755 |
|
git-commit-graph | File | 3.67 MB | 0755 |
|
git-commit-tree | File | 3.67 MB | 0755 |
|
git-config | File | 3.67 MB | 0755 |
|
git-contacts | File | 4.4 KB | 0755 |
|
git-count-objects | File | 3.67 MB | 0755 |
|
git-credential | File | 3.67 MB | 0755 |
|
git-credential-cache | File | 3.67 MB | 0755 |
|
git-credential-cache--daemon | File | 3.67 MB | 0755 |
|
git-credential-netrc | File | 10.69 KB | 0755 |
|
git-credential-store | File | 3.67 MB | 0755 |
|
git-describe | File | 3.67 MB | 0755 |
|
git-diagnose | File | 3.67 MB | 0755 |
|
git-diff | File | 3.67 MB | 0755 |
|
git-diff-files | File | 3.67 MB | 0755 |
|
git-diff-index | File | 3.67 MB | 0755 |
|
git-diff-tree | File | 3.67 MB | 0755 |
|
git-difftool | File | 3.67 MB | 0755 |
|
git-difftool--helper | File | 2.55 KB | 0755 |
|
git-fast-export | File | 3.67 MB | 0755 |
|
git-fast-import | File | 3.67 MB | 0755 |
|
git-fetch | File | 3.67 MB | 0755 |
|
git-fetch-pack | File | 3.67 MB | 0755 |
|
git-filter-branch | File | 15.49 KB | 0755 |
|
git-fmt-merge-msg | File | 3.67 MB | 0755 |
|
git-for-each-ref | File | 3.67 MB | 0755 |
|
git-for-each-repo | File | 3.67 MB | 0755 |
|
git-format-patch | File | 3.67 MB | 0755 |
|
git-fsck | File | 3.67 MB | 0755 |
|
git-fsck-objects | File | 3.67 MB | 0755 |
|
git-fsmonitor--daemon | File | 3.67 MB | 0755 |
|
git-gc | File | 3.67 MB | 0755 |
|
git-get-tar-commit-id | File | 3.67 MB | 0755 |
|
git-grep | File | 3.67 MB | 0755 |
|
git-hash-object | File | 3.67 MB | 0755 |
|
git-help | File | 3.67 MB | 0755 |
|
git-hook | File | 3.67 MB | 0755 |
|
git-http-backend | File | 2.14 MB | 0755 |
|
git-http-fetch | File | 2.17 MB | 0755 |
|
git-http-push | File | 2.19 MB | 0755 |
|
git-imap-send | File | 2.19 MB | 0755 |
|
git-index-pack | File | 3.67 MB | 0755 |
|
git-init | File | 3.67 MB | 0755 |
|
git-init-db | File | 3.67 MB | 0755 |
|
git-interpret-trailers | File | 3.67 MB | 0755 |
|
git-log | File | 3.67 MB | 0755 |
|
git-ls-files | File | 3.67 MB | 0755 |
|
git-ls-remote | File | 3.67 MB | 0755 |
|
git-ls-tree | File | 3.67 MB | 0755 |
|
git-mailinfo | File | 3.67 MB | 0755 |
|
git-mailsplit | File | 3.67 MB | 0755 |
|
git-maintenance | File | 3.67 MB | 0755 |
|
git-merge | File | 3.67 MB | 0755 |
|
git-merge-base | File | 3.67 MB | 0755 |
|
git-merge-file | File | 3.67 MB | 0755 |
|
git-merge-index | File | 3.67 MB | 0755 |
|
git-merge-octopus | File | 2.42 KB | 0755 |
|
git-merge-one-file | File | 3.61 KB | 0755 |
|
git-merge-ours | File | 3.67 MB | 0755 |
|
git-merge-recursive | File | 3.67 MB | 0755 |
|
git-merge-resolve | File | 1.2 KB | 0755 |
|
git-merge-subtree | File | 3.67 MB | 0755 |
|
git-merge-tree | File | 3.67 MB | 0755 |
|
git-mergetool | File | 11.42 KB | 0755 |
|
git-mergetool--lib | File | 10.48 KB | 0644 |
|
git-mktag | File | 3.67 MB | 0755 |
|
git-mktree | File | 3.67 MB | 0755 |
|
git-multi-pack-index | File | 3.67 MB | 0755 |
|
git-mv | File | 3.67 MB | 0755 |
|
git-name-rev | File | 3.67 MB | 0755 |
|
git-notes | File | 3.67 MB | 0755 |
|
git-pack-objects | File | 3.67 MB | 0755 |
|
git-pack-redundant | File | 3.67 MB | 0755 |
|
git-pack-refs | File | 3.67 MB | 0755 |
|
git-patch-id | File | 3.67 MB | 0755 |
|
git-prune | File | 3.67 MB | 0755 |
|
git-prune-packed | File | 3.67 MB | 0755 |
|
git-pull | File | 3.67 MB | 0755 |
|
git-push | File | 3.67 MB | 0755 |
|
git-quiltimport | File | 3.61 KB | 0755 |
|
git-range-diff | File | 3.67 MB | 0755 |
|
git-read-tree | File | 3.67 MB | 0755 |
|
git-rebase | File | 3.67 MB | 0755 |
|
git-receive-pack | File | 3.67 MB | 0755 |
|
git-reflog | File | 3.67 MB | 0755 |
|
git-remote | File | 3.67 MB | 0755 |
|
git-remote-ext | File | 3.67 MB | 0755 |
|
git-remote-fd | File | 3.67 MB | 0755 |
|
git-remote-ftp | File | 2.19 MB | 0755 |
|
git-remote-ftps | File | 2.19 MB | 0755 |
|
git-remote-http | File | 2.19 MB | 0755 |
|
git-remote-https | File | 2.19 MB | 0755 |
|
git-repack | File | 3.67 MB | 0755 |
|
git-replace | File | 3.67 MB | 0755 |
|
git-request-pull | File | 4.05 KB | 0755 |
|
git-rerere | File | 3.67 MB | 0755 |
|
git-reset | File | 3.67 MB | 0755 |
|
git-restore | File | 3.67 MB | 0755 |
|
git-rev-list | File | 3.67 MB | 0755 |
|
git-rev-parse | File | 3.67 MB | 0755 |
|
git-revert | File | 3.67 MB | 0755 |
|
git-rm | File | 3.67 MB | 0755 |
|
git-send-pack | File | 3.67 MB | 0755 |
|
git-sh-i18n | File | 1.64 KB | 0644 |
|
git-sh-i18n--envsubst | File | 2.13 MB | 0755 |
|
git-sh-setup | File | 8.2 KB | 0644 |
|
git-shell | File | 2.13 MB | 0755 |
|
git-shortlog | File | 3.67 MB | 0755 |
|
git-show | File | 3.67 MB | 0755 |
|
git-show-branch | File | 3.67 MB | 0755 |
|
git-show-index | File | 3.67 MB | 0755 |
|
git-show-ref | File | 3.67 MB | 0755 |
|
git-sparse-checkout | File | 3.67 MB | 0755 |
|
git-stage | File | 3.67 MB | 0755 |
|
git-stash | File | 3.67 MB | 0755 |
|
git-status | File | 3.67 MB | 0755 |
|
git-stripspace | File | 3.67 MB | 0755 |
|
git-submodule | File | 10.26 KB | 0755 |
|
git-submodule--helper | File | 3.67 MB | 0755 |
|
git-switch | File | 3.67 MB | 0755 |
|
git-symbolic-ref | File | 3.67 MB | 0755 |
|
git-tag | File | 3.67 MB | 0755 |
|
git-unpack-file | File | 3.67 MB | 0755 |
|
git-unpack-objects | File | 3.67 MB | 0755 |
|
git-update-index | File | 3.67 MB | 0755 |
|
git-update-ref | File | 3.67 MB | 0755 |
|
git-update-server-info | File | 3.67 MB | 0755 |
|
git-upload-archive | File | 3.67 MB | 0755 |
|
git-upload-pack | File | 3.67 MB | 0755 |
|
git-var | File | 3.67 MB | 0755 |
|
git-verify-commit | File | 3.67 MB | 0755 |
|
git-verify-pack | File | 3.67 MB | 0755 |
|
git-verify-tag | File | 3.67 MB | 0755 |
|
git-version | File | 3.67 MB | 0755 |
|
git-web--browse | File | 4.3 KB | 0755 |
|
git-whatchanged | File | 3.67 MB | 0755 |
|
git-worktree | File | 3.67 MB | 0755 |
|
git-write-tree | File | 3.67 MB | 0755 |
|
scalar | File | 2.18 MB | 0755 |
|