Merge branch 'da/git-prefix-everywhere' into next

* da/git-prefix-everywhere:
  t/t7503-pre-commit-hook.sh: Add GIT_PREFIX tests
  git-mergetool--lib: Make vimdiff retain the current directory
  git: Remove handling for GIT_PREFIX
  setup: Provide GIT_PREFIX to built-ins
This commit is contained in:
Junio C Hamano 2011-06-29 17:09:27 -07:00
commit 4ed54610e5
5 changed files with 62 additions and 9 deletions

View File

@ -86,6 +86,11 @@ get_merge_tool_cmd () {
} }
run_merge_tool () { run_merge_tool () {
# If GIT_PREFIX is empty then we cannot use it in tools
# that expect to be able to chdir() to its value.
GIT_PREFIX=${GIT_PREFIX:-.}
export GIT_PREFIX
merge_tool_path="$(get_merge_tool_path "$1")" || exit merge_tool_path="$(get_merge_tool_path "$1")" || exit
base_present="$2" base_present="$2"
status=0 status=0
@ -188,6 +193,7 @@ run_merge_tool () {
check_unchanged check_unchanged
else else
"$merge_tool_path" -R -f -d -c "wincmd l" \ "$merge_tool_path" -R -f -d -c "wincmd l" \
-c 'cd $GIT_PREFIX' \
"$LOCAL" "$REMOTE" "$LOCAL" "$REMOTE"
fi fi
;; ;;
@ -199,6 +205,7 @@ run_merge_tool () {
check_unchanged check_unchanged
else else
"$merge_tool_path" -R -f -d -c "wincmd l" \ "$merge_tool_path" -R -f -d -c "wincmd l" \
-c 'cd $GIT_PREFIX' \
"$LOCAL" "$REMOTE" "$LOCAL" "$REMOTE"
fi fi
;; ;;

10
git.c
View File

@ -183,8 +183,6 @@ static int handle_alias(int *argcp, const char ***argv)
if (alias_string[0] == '!') { if (alias_string[0] == '!') {
const char **alias_argv; const char **alias_argv;
int argc = *argcp, i; int argc = *argcp, i;
struct strbuf sb = STRBUF_INIT;
const char *env[2];
commit_pager_choice(); commit_pager_choice();
@ -195,13 +193,7 @@ static int handle_alias(int *argcp, const char ***argv)
alias_argv[i] = (*argv)[i]; alias_argv[i] = (*argv)[i];
alias_argv[argc] = NULL; alias_argv[argc] = NULL;
strbuf_addstr(&sb, "GIT_PREFIX="); ret = run_command_v_opt(alias_argv, RUN_USING_SHELL);
if (subdir)
strbuf_addstr(&sb, subdir);
env[0] = sb.buf;
env[1] = NULL;
ret = run_command_v_opt_cd_env(alias_argv, RUN_USING_SHELL, NULL, env);
strbuf_release(&sb);
if (ret >= 0) /* normal exit */ if (ret >= 0) /* normal exit */
exit(ret); exit(ret);

View File

@ -710,6 +710,11 @@ const char *setup_git_directory_gently(int *nongit_ok)
const char *prefix; const char *prefix;
prefix = setup_git_directory_gently_1(nongit_ok); prefix = setup_git_directory_gently_1(nongit_ok);
if (prefix)
setenv("GIT_PREFIX", prefix, 1);
else
setenv("GIT_PREFIX", "", 1);
if (startup_info) { if (startup_info) {
startup_info->have_repository = !nongit_ok || !*nongit_ok; startup_info->have_repository = !nongit_ok || !*nongit_ok;
startup_info->prefix = prefix; startup_info->prefix = prefix;

View File

@ -140,6 +140,22 @@ test_expect_success 'GIT_PREFIX for !alias' '
test_cmp expect actual test_cmp expect actual
' '
test_expect_success 'GIT_PREFIX for built-ins' '
# Use GIT_EXTERNAL_DIFF to test that the "diff" built-in
# receives the GIT_PREFIX variable.
printf "dir/" >expect &&
printf "#!/bin/sh\n" >diff &&
printf "printf \"\$GIT_PREFIX\"" >>diff &&
chmod +x diff &&
(
cd dir &&
printf "change" >two &&
env GIT_EXTERNAL_DIFF=./diff git diff >../actual
git checkout -- two
) &&
test_cmp expect actual
'
test_expect_success 'no file/rev ambiguity check inside .git' ' test_expect_success 'no file/rev ambiguity check inside .git' '
git commit -a -m 1 && git commit -a -m 1 &&
( (

View File

@ -84,5 +84,38 @@ test_expect_success POSIXPERM '--no-verify with non-executable hook' '
git commit --no-verify -m "more content" git commit --no-verify -m "more content"
' '
chmod +x "$HOOK"
# a hook that checks $GIT_PREFIX and succeeds inside the
# success/ subdirectory only
cat > "$HOOK" <<EOF
#!/bin/sh
test \$GIT_PREFIX = success/
EOF
test_expect_success 'with hook requiring GIT_PREFIX' '
echo "more content" >> file &&
git add file &&
mkdir success &&
(
cd success &&
git commit -m "hook requires GIT_PREFIX = success/"
) &&
rmdir success
'
test_expect_success 'with failing hook requiring GIT_PREFIX' '
echo "more content" >> file &&
git add file &&
mkdir fail &&
(
cd fail &&
test_must_fail git commit -m "hook must fail"
) &&
rmdir fail &&
git checkout -- file
'
test_done test_done