Bez popisu

Jelmer Vernooij 8e21c04e08 Implement Tree.__contains__. před 16 roky
bin 714631cfc2 Don't close file twice. před 16 roky
docs 5f84a7b055 Move performance doc to docs/ and rst format. před 16 roky
dulwich 8e21c04e08 Implement Tree.__contains__. před 16 roky
.bzrignore 7b387b0d58 Add manifest file to include some more docs. před 16 roky
AUTHORS a5391292cc Add simple AUTHORS file. před 16 roky
COPYING c4c19475f3 Make it more like a real project. před 18 roky
HACKING dd65c0b6b5 Add simple hacking doc. před 16 roky
MANIFEST.in 7b387b0d58 Add manifest file to include some more docs. před 16 roky
Makefile f2c2516fed Fix C implementation of parse_tree to return a dictionary. před 16 roky
NEWS e62cb12a42 Support activity reporting. před 16 roky
README 10a45c0536 Mention that John and I maintain Dulwich these days. před 16 roky
setup.py 5ba33545fa Add apply_delta C implementation. před 16 roky

README

This is the dulwich project.

It aims to give an interface to git repos that doesn't call out to git
directly but instead uses pure Python.

Currently can read blobs, trees and commits from the files. It reads both
legacy and new headers. It can write out new indexes as well.

Can also understand a little about the repository format.

Open up a repo by passing it the path to the .git dir. You can then ask for
HEAD with repo.head() or a ref with repo.ref(name). Both return the SHA id
they currently point to. You can then grab this object with
repo.get_object(sha).

For the actual objects the ShaFile.from_file(filename) will return the object
stored in the file whatever it is. To ensure you get the correct type then
call {Blob,Tree,Commit}.from_file(filename). I will add repo methods to do
this for you with file lookup soon.

There is also support for creating blobs. Blob.from_string(string) will create
a blob object from the string. You can then call blob.sha() to get the sha
object for this blob, and hexdigest() on that will get its ID. There is
currently no method that allows you to write it out though.

Everything is currently done with assertions, where much of it should probably
be exceptions. This was merely done for expediency. If you hit an assertion,
it either means you have done something wrong, there is corruption, or
you are trying an unsupported operation.

The project is named after the part of London that Mr. and Mrs. Git live in
in the particular Monty Python sketch. It is based on the Python-Git module
that James Westby released in 2007 and now
maintained by Jelmer Vernooij and John Carr.