No Description

Jelmer Vernooij 6845c5b853 Import abcs from the new location. 6 years ago
bin 5fd3138ec5 Pass through deepen flag. 6 years ago
devscripts 1b8231acc6 Add script for updating preamble. 8 years ago
docs a2de9c199d Switch to sphinx theme 'agogo'. 6 years ago
dulwich 6845c5b853 Import abcs from the new location. 6 years ago
examples f73261458e Add example for using memoryrepo. 6 years ago
.coveragerc 95d44cdfa1 Set source in coveragerc rather than passing on command-line. 7 years ago
.gitignore fdcff89992 Ignore generated API files. 6 years ago
.mailmap 4c5c2752fa Update mailmap. 7 years ago
.testr.conf e46d3b3a75 testr: Allow id list files (fixes parallel runs). 14 years ago
.travis.yml d6f79401bf Drop support for Python 3 < 3.4. This is because pkg_resources (which get used by setuptools and mock) no longer supports 3.3 and earlier. 6 years ago
AUTHORS 1d1d8a128d Update AUTHORS. 6 years ago
CONTRIBUTING.rst 7da7187c2a Convert CONTRIBUTING and README to rst. 6 years ago
COPYING 7098611ac3 As agreed by all contributors, change the license from: 8 years ago
MANIFEST.in 1c53c47702 More md => rst. 6 years ago
Makefile 8706eed1fc Generate API docs in sphinx. 6 years ago
NEWS af13438fb9 Start on 0.19.10. 6 years ago
README.rst 7da7187c2a Convert CONTRIBUTING and README to rst. 6 years ago
README.swift.rst 1c53c47702 More md => rst. 6 years ago
TODO 1282de4286 Update TODO. 7 years ago
appveyor.yml d6f79401bf Drop support for Python 3 < 3.4. This is because pkg_resources (which get used by setuptools and mock) no longer supports 3.3 and earlier. 6 years ago
build.cmd 91ef7633b0 Attempt to fix 64 bit builds on Windows. 8 years ago
dulwich.cfg 13fced2e1d Change homepage to www.dulwich.io. 9 years ago
requirements.txt 48e2ef8c2f Enable SSL verification for `urllib3` 7 years ago
setup.cfg 9d1182c0fb Move flake8 configuration to setup.cfg. 6 years ago
setup.py 1c53c47702 More md => rst. 6 years ago
tox.ini f4c3a804d4 Run tests on Python3.3. 8 years ago

README.rst

[![Build Status](https://travis-ci.org/dulwich/dulwich.png?branch=master)](https://travis-ci.org/dulwich/dulwich)
[![Windows Build status](https://ci.appveyor.com/api/projects/status/mob7g4vnrfvvoweb?svg=true)](https://ci.appveyor.com/project/jelmer/dulwich/branch/master)

This is the Dulwich project.

It aims to provide an interface to git repos (both local and remote) that
doesn't call out to git directly but instead uses pure Python.

**Main website**:

**License**: Apache License, version 2 or GNU General Public License, version 2 or later.

The project is named after the part of London that Mr. and Mrs. Git live in
in the particular Monty Python sketch.

Installation
------------

By default, Dulwich' setup.py will attempt to build and install the optional C
extensions. The reason for this is that they significantly improve the performance
since some low-level operations that are executed often are much slower in CPython.

If you don't want to install the C bindings, specify the --pure argument to setup.py::

$ python setup.py --pure install

or if you are installing from pip::

$ pip install dulwich --global-option="--pure"

Note that you can also specify --global-option in a
`requirements.txt `_
file, e.g. like this::

dulwich --global-option=--pure

Getting started
---------------

Dulwich comes with both a lower-level API and higher-level plumbing ("porcelain").

For example, to use the lower level API to access the commit message of the
last commit::

>>> from dulwich.repo import Repo
>>> r = Repo('.')
>>> r.head()
'57fbe010446356833a6ad1600059d80b1e731e15'
>>> c = r[r.head()]
>>> c

>>> c.message
'Add note about encoding.\n'

And to print it using porcelain::

>>> from dulwich import porcelain
>>> porcelain.log('.', max_entries=1)
--------------------------------------------------
commit: 57fbe010446356833a6ad1600059d80b1e731e15
Author: Jelmer Vernooij
Date: Sat Apr 29 2017 23:57:34 +0000

Add note about encoding.

Further documentation
---------------------

The dulwich documentation can be found in docs/ and
`on the web `_.

The API reference can be generated using pydoctor, by running "make pydoctor",
or `on the web `_.

Help
----

There is a *#dulwich* IRC channel on the `Freenode `_, and
`dulwich-announce `_
and `dulwich-discuss `_
mailing lists.

Contributing
------------

For a full list of contributors, see the git logs or `AUTHORS `_.

If you'd like to contribute to Dulwich, see the `CONTRIBUTING `_
file and `list of open issues `_.

Supported versions of Python
----------------------------

At the moment, Dulwich supports (and is tested on) CPython 2.7, 3.4, 3.5, 3.6 and Pypy.