libtorrent with premiere torrent support
Go to file
Steven Siloti 86116caf4c fix assert after a DHT get/put request
If an observer is abandoned due to there being more than 100 results in a
traversal then the traversal may complete while the observer is still
outstanding. When the observer times out or is aborted it calls
traversal_algorithm::failed() which asserts because m_invoke_count has been
cleared to zero by traversal_algorithm::done().

To fix this add a check when abandoning observers to see if they have an
outstanding query. If they do then flag them as done to prevent them from
calling back into the traversal and decrement the invoke count.

Fixes #271
2015-11-16 21:05:32 -08:00
bindings Merge pull request #255 from bit/mutable_python 2015-11-12 20:23:28 -05:00
docs transition from ditaa to aafigure and improve disk cache diagram 2015-10-31 11:15:46 -04:00
ed25519 Fixed to make it compatible with mingw-w64 and generic linux 2015-11-13 07:55:28 -05:00
examples add error_code to torrent_status instead of error string 2015-11-05 20:43:23 -05:00
include/libtorrent Merge pull request #267 from arvidn/storage-fix 2015-11-14 12:54:57 -05:00
m4 merge small unit tests to make running the tests quicker. expand the test framework a bit. add ax_boost_random.m4 script to link against boost.random correctly from makefile. 2015-05-30 04:31:23 +00:00
simulation update libsimulator 2015-11-14 09:11:24 -05:00
src fix assert after a DHT get/put request 2015-11-16 21:05:32 -08:00
test add unit test to check for multiple calls to done() 2015-11-09 20:47:33 -08:00
tools fix bug in set_version and update version hash 2015-11-11 01:25:30 -05:00
.gitignore Ignore more build files in git 2015-10-20 12:09:54 +01:00
.gitmodules add .gitmodules 2015-08-07 23:19:37 -04:00
.travis.yml minor moving around of code 2015-11-06 00:38:42 -05:00
AUTHORS cleanup root of repository 2015-06-05 23:14:53 -04:00
CMakeLists.txt separate out announce_entry and torrent_status into their own headers 2015-09-18 08:08:08 -04:00
COPYING update copyright year 2015-06-03 05:18:48 +00:00
ChangeLog update changelog from RC_1_0 2015-11-12 21:28:50 -05:00
Jamfile Fixed to make it compatible with mingw-w64 and generic linux 2015-11-13 07:55:28 -05:00
Jamroot.jam
LICENSE fix no-deprecated build. extend .travis.yml to build the 3 test configurations too. rename README to README.rst 2015-06-05 02:31:52 -04:00
Makefile.am transition from ditaa to aafigure and improve disk cache diagram 2015-10-31 11:15:46 -04:00
NEWS polishing, update copyright 2014-07-02 07:17:50 +00:00
README.rst extend pull request checklist 2015-09-07 20:18:23 -04:00
appveyor.yml fix appveyor build 2015-11-07 00:22:13 -05:00
autotool.sh merged configure fix from RC_0_16 2012-11-19 05:23:46 +00:00
bootstrap.sh merged bootstrap.sh script from RC_0_16 2013-05-29 02:11:15 +00:00
build_dist.sh merged changes from RC_1_0 2014-11-12 16:57:59 +00:00
configure.ac Added missing dependencies to fix examples build 2015-08-12 11:36:29 +03:00
libtorrent-rasterbar-cmake.pc.in
libtorrent-rasterbar.pc.in merged fixes from RC_0_16 2013-09-07 21:27:07 +00:00
setup.py Add/fix shebang in python scripts, add execute permission (linux), remove whitespace/tabs at end of line 2015-07-12 14:24:01 +08:00

README.rst

libtorrent
----------

.. image:: https://travis-ci.org/arvidn/libtorrent.svg?branch=master
    :target: https://travis-ci.org/arvidn/libtorrent

.. image:: https://ci.appveyor.com/api/projects/status/w7teauvub5813mew/branch/master?svg=true
    :target: https://ci.appveyor.com/project/arvidn/libtorrent/branch/master

.. image:: https://www.openhub.net/p/rasterbar-libtorrent/widgets/project_thin_badge.gif
    :target: https://www.openhub.net/p/rasterbar-libtorrent?ref=sample

libtorrent is an open source C++ library implementing the BitTorrent protocol,
along with most popular extensions, making it suitable for real world
deployment. It is configurable to be able to fit both servers and embedded
devices.

The main goals of libtorrent are to be efficient and easy to use.

See `libtorrent.org`__ for more detailed build and usage instructions.

.. __: http://libtorrent.org

To build with boost-build, make sure boost and boost-build is installed and run:

   b2

In the libtorrent root. To build the examples, run ``b2`` in the ``examples``
directory.

See `building.html`__ for more details on how to build and which configuration
options are available. For python bindings, see `the python docs`__.

.. __: docs/building.rst
.. __: docs/python_binding.rst

pull request checklist
......................

When creating a pull request, please consider the following checklist:

* make sure both travis-CI and appveyor builds are green. Note that on gcc and
  clang warnings are treated as errors. Some tests may be flapping, if so,
  please issue a rebuild of the specific build configuration. (I'm working on
  making all tests deterministic)
* If adding a user-facing feature, please add brief entry to ``ChangeLog``
* Add a unit test to confirm the new behavior or feature. Don't forget negative
  tests (i.e. failure cases) and please pay as much care to tests as you would
  production code.
* rebase on top of master periodically
* if your patch is against the current stable release branch, please also
  forward-poret the patch to master (at the time of this writing, automatic
  merge in git does not work, possibly because the branch was created in svn)
* if your patch adds a new .cpp file, please make sure it's added to the
  appropriate ``Jamfile``, ``Makefile.am`` and ``CMakeList.txt``. If it's adding
  a header file, make sure it's added to ``include/libtorrent/Makefile,am``.