Rugged merge commit from origin не обновляет рабочее дерево
Похоже на этот вопрос, но вместо создания нового файла я пытаюсь слить с начала координат. После создания нового индекса с помощью Rugged::Repository
"s merge_commits
и новый коммит слияния, git сообщает о новом файле origin
) как удалено.
Создать индекс слияния,
> origin_target = repo.references['refs/remotes/origin/master'].target
> merge_index = repo.merge_commits(repo.head.target, origin_target)
и новый коммит слияния,
> options = {
update_ref: 'refs/heads/master',
committer: {name: 'user', email: 'user@foo.com', time: Time.now},
author: {name: 'user', email: 'user@foo.com', time: Time.now},
parents: [repo.head.target, origin_target],
message: "merge `origin/master` into `master`"}
и убедитесь, что используете дерево из индекса слияния.
> options[:tree] = merge_index.write_tree(repo)
Создать коммит
> merge_commit = Rugged::Commit.create(repo, options)
Убедитесь, что наш заголовок был обновлен:
> repo.head.target.tree
=> #<Rugged::Tree:16816500 {oid: 16c147f358a095bdca52a462376d7b5730e1978e}>
<"first_file.txt" 9d096847743f97ba44edf00a910f24bac13f36e2>
<"second_file.txt" 8178c76d627cade75005b40711b92f4177bc6cfc>
<"newfile.txt" e69de29bb2d1d6434b8b29ae775ad8c2e48c5391>
Выглядит хорошо. Я вижу новый файл в индексе. Запишите это на диск.
> repo.index.write
=> nil
... но git сообщает, что новый файл удален:
$ git st
## master...origin/master [ahead 2]
D newfile.txt
Как я могу правильно обновить свой индекс и рабочее дерево?
1 ответ
Существует важное различие между хранилищем Git и рабочим каталогом. Хотя большинство обычных командных командных команд git работают как с рабочим каталогом, так и с хранилищем, команды более низкого уровня libgit2 / librugged в основном работают только с хранилищем. Это включает в себя написание индекса, как в вашем примере.
Чтобы обновить рабочий каталог в соответствии с индексом, должна работать следующая команда (после записи индекса):
options = { strategy: force }
repo.checkout_head(options)
Документы для checkout_head: http://www.rubydoc.info/github/libgit2/rugged/Rugged/Repository
Примечание: я проверил с update_ref: 'HEAD'
для совершения. Я не уверен, если update_ref: 'refs/heads/master'
будет иметь тот же эффект.