Влияет ли sparse-checkout на отслеживаемый файл? - PullRequest
0 голосов
/ 14 апреля 2020

Мой локальный и удаленный сервер имеют Centos 7.
Я отслеживал README.md в локальном репо с git версией 1.8.3.1. Когда я пересмотрел README.md и pu sh в удаленном репо без не хочу, чтобы README.md был извлечен.
В удаленном репо, git версия 2.16.6, я установил post-receive, как показано ниже:

while read oldrev newrev ref
do
     if [[ $ref = refs/heads/"$BRANCH" ]];
        then
        git --work-tree="$DEPLOY_DIR"  --git-dir="$GIT_DIR" checkout -f
     fi
done

В удаленном репо, я установите sparse-checkout как показано ниже:

/*
!/README.md

Я обнаружил, что README.md все еще там, и не изменен.

Затем я изменил sparse-checkout, как показано ниже:

!/README.md
/*

Я получил remote: error: Entry 'README.md' not uptodate. Cannot merge.

, что sparse-checkout является правильным? В чем проблема?

1 Ответ

0 голосов
/ 14 апреля 2020

Пришло время поиграть на месте. Вот моя тестовая настройка, она показывает, что разреженная проверка работает правильно, когда я doit. Это прямая кривая из моих терминальных буферов, скопируйте определение функции и скажите doit.

$ doit () { 
set -x
git init testlocal; cd $_
git commit --allow-empty -m-
git clone --bare . ../testremote; cd $_
git config core.sparsecheckout true
mkdir -p hooks info worktree
printf %s\\n /\* \!/README.md >info/sparse-checkout
tee hooks/post-receive <<'EOD'; chmod +x $_
while read oldrev newrev ref; do
        if [[ $ref = refs/heads/master ]]; then
                git --work-tree="$GIT_DIR/worktree" checkout -f
        fi
done
EOD
cd -
touch notREADME.md README.md
git add .; git commit -m-
git push ../testremote master
ls ../testremote/worktree
set +x
}
$ doit
+ git init testlocal
Initialized empty Git repository in /home/jthill/src/snips/testlocal/.git/
+ cd testlocal
/home/jthill/src/snips/testlocal
+ git commit --allow-empty -m-
[master (root-commit) 6ed44ec] -
+ git clone --bare . ../testremote
Cloning into bare repository '../testremote'...
done.
+ cd ../testremote
+ git config core.sparsecheckout true
+ mkdir -p hooks info worktree
+ printf '%s\n' '/*' '!/README.md'
+ tee hooks/post-receive
while read oldrev newrev ref
do
     if [[ $ref = refs/heads/master ]];
        then
        git --work-tree="$GIT_DIR/worktree" checkout -f
     fi
done
+ chmod +x hooks/post-receive
+ cd -
/home/jthill/src/snips/testlocal
+ touch notREADME.md README.md
+ git add .
+ git commit -m-
[master 64f5358] -
 2 files changed, 0 insertions(+), 0 deletions(-)
 create mode 100644 README.md
 create mode 100644 notREADME.md
+ git push ../testremote master
Enumerating objects: 4, done.
Counting objects: 100% (4/4), done.
Delta compression using up to 4 threads
Compressing objects: 100% (2/2), done.
Writing objects: 100% (3/3), 240 bytes | 240.00 KiB/s, done.
Total 3 (delta 0), reused 0 (delta 0), pack-reused 0
To ../testremote
   6ed44ec..64f5358  master -> master
+ ls --color=auto ../testremote/worktree
notREADME.md
+ set +x
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...