2012-08-15 19 views

cevap

5

ben DULWICH kullanmadıysanız, ancak these doc's gelen muhtemelen gibi bir şey: Bu noktada

from dulwich.repo import Repo 
from dulwich.client import HttpGitClient 
local = Repo.init("local", mkdir=True) 
client = HttpGitClient('http://github.com/adammorris/') 
remote_refs = client.fetch("history.js.git",local) 
local["HEAD"] = remote_refs["refs/heads/master"] 

, bu dosyaları yüklemek yoktu, ama ben yerel yoldan "git checkout" yapabileceğini ve dosyaları güncelledi.

+0

Evet, getirme işlevi '.git' dizini altındaki bir paket dosyasında çeker. Ve sadece ana dalda nasıl birleştirileceğini bilmiyorum. – Determinant

+0

Fetch(), paketi repo ile aynı şubeye içe aktarmalı gibi geliyor. Master dalına birleştirmek için do_commit() kullanmak mümkün mü? http://stackoverflow.com/questions/6904734/in-dulwich-how-do-i-commit-to-a-branch-instead-of-to-head –

+0

Korkarım ki ... – Determinant

1

Tam örnek:

Ayrıca, bu gördük. Bitbucket ile çalışır.

from dulwich import index 
from dulwich.client import HttpGitClient 
from dulwich.repo import Repo 

local_repo = Repo.init(LOCAL_FOLDER, mkdir=True) 
remote_repo = HttpGitClient(REMOTE_URL, username=USERNAME, password=PASSWORD) 
remote_refs = remote_repo.fetch(REMOTE_URL, local_repo) 
local_repo[b"HEAD"] = remote_refs[b"refs/heads/master"] 

index_file = local_repo.index_path() 
tree = local_repo[b"HEAD"].tree 
index.build_index_from_tree(local_repo.path, index_file, local_repo.object_store, tree) 

veri ile LOCAL_FOLDER, REMOTE_URL, Kullanıcı adı, şifre değiştirin.

İlgili konular