commit | db7895644a3a73dbc863c655a0dacea076e563d0 | [log] [tgz] |
---|---|---|
author | Davide Pesavento <davidepesa@gmail.com> | Sat Dec 19 23:01:08 2020 -0500 |
committer | Davide Pesavento <davidepesa@gmail.com> | Wed Dec 30 18:27:28 2020 -0500 |
tree | 52ad66db56488e7697c86ca22394b68b54d147b7 | |
parent | aafef2bd91b72d215e8da37769041d845f000606 [diff] |
Move non-public classes and functions to psync::detail namespace CompressionScheme, CompressionError, and MissingDataInfo, which are public types, are instead moved to a new header PSync/common.hpp Change-Id: If1b8cb037cb321ff32c080c67df9dc3689223c00
The PSync library implements the PSync protocol. It uses Invertible Bloom Lookup Table (IBLT), also known as Invertible Bloom Filter (IBF), to represent the state of a producer in partial sync mode and the state of a node in full sync mode. An IBF is a compact data structure where difference of two IBFs can be computed efficiently. In partial sync, PSync uses a Bloom Filter to represent the subscription list of the consumer.
PSync uses the ndn-cxx library.
To build PSync from source:
./waf configure ./waf sudo ./waf install
To build on memory constrained platform, please use ./waf -j1
instead of ./waf
. The command will disable parallel compilation.
If configured with tests (./waf configure --with-tests
), the above commands will also generate unit tests that can be run with ./build/unit-tests
.
Please submit any bug reports or feature requests to the PSync issue tracker.
We greatly appreciate contributions to the PSync code base, provided that they are licensed under the LGPL 3.0+ or a compatible license (see below). If you are new to the NDN software community, please read the Contributor's Guide to get started.
PSync is an open source project licensed under the LGPL version 3. See COPYING.md
for more information.