Sem descrição

Jelmer Vernooij c329e989d1 Readme: Python 3.9 is tested and required, not 3.6 (#1454) há 19 horas atrás
.github c6c9c36b21 há 1 semana atrás
bin c0a8e05380 Add SPDX license identifier to Python files and shell scripts há 1 dia atrás
crates 69c1b064e6 use modern APIs há 1 semana atrás
devscripts c0a8e05380 Add SPDX license identifier to Python files and shell scripts há 1 dia atrás
docs 3eaddc6db8 Drop outdated performance.txt file. Fixes #1411 há 3 semanas atrás
dulwich d676c78b9c Add MIT SPDX license identifier for diffstat.py há 22 horas atrás
examples c0a8e05380 Add SPDX license identifier to Python files and shell scripts há 1 dia atrás
fuzzing c0a8e05380 Add SPDX license identifier to Python files and shell scripts há 1 dia atrás
testdata c1738f5fe1 Move testdata out of code directory. há 2 anos atrás
tests c0a8e05380 Add SPDX license identifier to Python files and shell scripts há 1 dia atrás
.codespellrc 2368e6658c Fix codespell issues há 5 meses atrás
.coveragerc 95d44cdfa1 Set source in coveragerc rather than passing on command-line. há 6 anos atrás
.deepsource.toml d6fc2e465e chore: refactor code quality issues há 3 anos atrás
.gitignore 35792cdd46 Initial OSS-Fuzz Integration and First Fuzzing Test há 6 meses atrás
.mailmap 4c5c2752fa Update mailmap. há 6 anos atrás
.readthedocs.yaml 39e1ff4db4 rename .readthedocs.yml -> .readthedocs.yaml há 1 ano atrás
.stestr.conf 245331a60d Move tests to root. Fixes #1024 há 7 meses atrás
.testr.conf 245331a60d Move tests to root. Fixes #1024 há 7 meses atrás
AUTHORS 493658afb1 Update NEWS, AUTHORS. há 3 anos atrás
CODE_OF_CONDUCT.md 2368e6658c Fix codespell issues há 5 meses atrás
CONTRIBUTING.rst 92749cd5a9 Refer to Rust rather than C bindings há 3 meses atrás
COPYING 9861693656 Add SPDX license identifier to COPYING and README.rst há 1 dia atrás
Cargo.lock 0598220dce Bump pyo3 from 0.23.0 to 0.23.1 há 5 dias atrás
Cargo.toml f4fe6b07ca Bump pyo3 version há 1 semana atrás
MANIFEST.in 47faecd764 Ship testdata/ and tests/ in sdist. Fixes #1292 há 7 meses atrás
Makefile 8bb9c9e84d Add more types, courtesy of ruff há 5 dias atrás
NEWS f6c09b16c6 Release 0.22.6 há 1 semana atrás
README.rst a6929ba093 Readme: Python 3.9 is tested and required, not 3.6 há 19 horas atrás
SECURITY.md 940ab2ec78 Update security policy now that 0.21.X is out. há 1 ano atrás
TODO 1282de4286 Update TODO. há 6 anos atrás
disperse.toml 17a1f6f399 Migrate to disperse.toml há 3 semanas atrás
dulwich.cfg 13fced2e1d Change homepage to www.dulwich.io. há 9 anos atrás
pyproject.toml 6433f64c0a ruff: Remove E741 há 5 dias atrás
requirements.txt 5505a96d28 removed urllib3[secure] há 2 anos atrás
setup.py c0a8e05380 Add SPDX license identifier to Python files and shell scripts há 1 dia atrás
status.yaml 11bddcfc87 Prettify md/yaml files há 2 anos atrás
tox.ini 02705b344d Simplify tox setup (#1086) há 2 anos atrás

README.rst

Dulwich
=======

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.

SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later

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

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

By default, Dulwich' setup.py will attempt to build and install the optional Rust
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 Rust bindings, specify the --pure argument to setup.py::

$ python setup.py --pure install

or if you are installing from pip::

$ pip install --no-binary dulwich dulwich --config-settings "--build-option=--pure"

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

dulwich --config-settings "--build-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 built by running ``make
doc``. It can also be found `on the web `_.

Help
----

There is a *#dulwich* IRC channel on the `OFTC `_, and
a `dulwich-discuss `_
mailing list.

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 3.9 and later and
Pypy.