Программно `git checkout .` с Далвичем - PullRequest
5 голосов
/ 10 июля 2011

Имея этот код

from dulwich.objects import Blob, Tree, Commit, parse_timezone
from dulwich.repo import Repo
from time import time

repo = Repo.init("myrepo", mkdir=True)
blob = Blob.from_string("my file content\n")
tree = Tree()
tree.add("spam", 0100644, blob.id)
commit = Commit()
commit.tree = tree.id


author = "Flav <foo@bar.com>"
commit.author = commit.committer = author
commit.commit_time = commit.author_time = int(time())
tz = parse_timezone('+0200')[0]
commit.commit_timezone = commit.author_timezone = tz
commit.encoding = "UTF-8"
commit.message = "initial commit"

o_sto = repo.object_store
o_sto.add_object(blob)
o_sto.add_object(tree)
o_sto.add_object(commit)

repo.refs["HEAD"] = commit.id

Я получаю фиксацию в истории, НО созданный файл ожидает удаления (git status говорит об этом).

A git checkout . исправляет это.

У меня вопрос: как сделать git checkout . программно с Далвичем?

Ответы [ 3 ]

8 голосов
/ 10 июля 2011

Состояние Git говорит, что он удален, потому что файл не существует в рабочей копии, поэтому проверка его исправляет состояние.

Похоже, что нет поддержки высокоуровневых классов и функций рабочей копии.в Далвиче еще.Вам придется иметь дело с деревьями, каплями и распаковкой объектов.

ОК, принял вызов: я могу сделать базовую проверку с помощью Dulwich:

#get repository object of current directory
repo = Repo('.')
#get tree corresponding to the head commit
tree_id = repo["HEAD"].tree
#iterate over tree content, giving path and blob sha.
for entry in repo.object_store.iter_tree_contents(tree_id):
  path = entry.in_path(repo.path).path
  dulwich.file.ensure_dir_exists(os.path.split(path)[0])
  with open(path, 'wb') as file:
    #write blob's content to file
    file.write(repo[entry.sha].as_raw_string()) 

Он не удалит файлыкоторые должны быть удалены, не заботятся о вашем индексе и т. д.
См. также Отметьте проект github Mikofski для более полного кода, основанного на этом.

3 голосов
/ 17 сентября 2012

Теперь возможно, начиная с выпуска 0.8.4 , с методом dulwich.index.build_index_from_tree().

Он записывает дерево как в файл индекса, так и в файловую систему (рабочую копию), что является очень простой формой проверки.

см. Примечание

существующий индекс стирается, а содержимое не объединяется в рабочем реж. Подходит только для свежих клонов

Я мог бы заставить его работать со следующим кодом

from dulwich import index, repo
#get repository object of current directory
repo = repo.Repo('.')
indexfile = repo.index_path()
#we want to checkout HEAD
tree = repo["HEAD"].tree

index.build_index_from_tree(repo.path, indexfile, repo.object_store, tree)
0 голосов
/ 10 июля 2011
from dulwich.repo import Repo

repo = Repo.init('myrepo', mkdir=True)
f = open('myrepo/spam', 'w+')
f.write('my file content\n')
f.close()
repo.stage(['spam'])
repo.do_commit('initial commit', 'Flav <foo@bar.com>')

Найден, посмотрев на dulwich/tests/test_repository.py:371. Далвич очень силен, но документов, к сожалению, немного не хватает.

Может также захотеть использовать GitFile .

...