commit | 506436080896847ddd211fcc8c2f55e110f07b12 | [log] [tgz] |
---|---|---|
author | Igor Murashkin <[email protected]> | Fri Aug 10 17:28:38 2018 -0700 |
committer | android-build-merger <[email protected]> | Fri Aug 10 17:28:38 2018 -0700 |
tree | ac247a0b1136b7b3544f69996c15b6181dd8a2c7 | |
parent | 1ef7e7e5215a5d995f8604ffd0c07ec797dc91bd [diff] | |
parent | a81f29220e3d0850efe190f394bd90e2c1cbff89 [diff] |
android: Add build targets librxcpp and librxcpp-tests am: 122c10b47a am: a81f29220e Change-Id: Ie04b861d7eb2f67e80b6fa3339ac95b8527ed9c1
The Reactive Extensions for C++ (RxCpp) is a library of algorithms for values-distributed-in-time. The Range-v3 library does the same for values-distributed-in-space.
Platform | Status | ----------- | :------------ | Windows | Linux & OSX |
Source | Badges |
---|---|
Github | |
Gitter.im | |
Packages | |
Documentation | |
Add Rx/v2/src
to the include paths
#include "rxcpp/rx.hpp" namespace Rx { using namespace rxcpp; using namespace rxcpp::sources; using namespace rxcpp::operators; using namespace rxcpp::util; } using namespace Rx; #include <regex> #include <random> using namespace std; using namespace std::chrono; int main() { random_device rd; // non-deterministic generator mt19937 gen(rd()); uniform_int_distribution<> dist(4, 18); // for testing purposes, produce byte stream that from lines of text auto bytes = range(0, 10) | flat_map([&](int i){ auto body = from((uint8_t)('A' + i)) | repeat(dist(gen)) | as_dynamic(); auto delim = from((uint8_t)'\r'); return from(body, delim) | concat(); }) | window(17) | flat_map([](observable<uint8_t> w){ return w | reduce( vector<uint8_t>(), [](vector<uint8_t> v, uint8_t b){ v.push_back(b); return v; }) | as_dynamic(); }) | tap([](vector<uint8_t>& v){ // print input packet of bytes copy(v.begin(), v.end(), ostream_iterator<long>(cout, " ")); cout << endl; }); // // recover lines of text from byte stream // auto removespaces = [](string s){ s.erase(remove_if(s.begin(), s.end(), ::isspace), s.end()); return s; }; // create strings split on \r auto strings = bytes | concat_map([](vector<uint8_t> v){ string s(v.begin(), v.end()); regex delim(R"/(\r)/"); cregex_token_iterator cursor(&s[0], &s[0] + s.size(), delim, {-1, 0}); cregex_token_iterator end; vector<string> splits(cursor, end); return iterate(move(splits)); }) | filter([](const string& s){ return !s.empty(); }) | publish() | ref_count(); // filter to last string in each line auto closes = strings | filter( [](const string& s){ return s.back() == '\r'; }) | Rx::map([](const string&){return 0;}); // group strings by line auto linewindows = strings | window_toggle(closes | start_with(0), [=](int){return closes;}); // reduce the strings for a line into one string auto lines = linewindows | flat_map([&](observable<string> w) { return w | start_with<string>("") | sum() | Rx::map(removespaces); }); // print result lines | subscribe<string>(println(cout)); return 0; }
The ReactiveX Observable model allows you to treat streams of asynchronous events with the same sort of simple, composable operations that you use for collections of data items like arrays. It frees you from tangled webs of callbacks, and thereby makes your code more readable and less prone to bugs.
Credit ReactiveX.io
RxCpp uses a git submodule (in ext/catch
) for the excellent Catch library. The easiest way to ensure that the submodules are included in the clone is to add --recursive
in the clone command.
git clone --recursive https://github.com/Reactive-Extensions/RxCpp.git cd RxCpp
RxCpp uses CMake to create build files for several platforms and IDE's
mkdir projects/build cd projects/build cmake -G"Xcode" ../CMake -B.
mkdir projects\build cd projects\build cmake -G"Visual Studio 14" ..\CMake -B. msbuild rxcpp.sln
mkdir projects/build cd projects/build cmake -G"Unix Makefiles" -DCMAKE_BUILD_TYPE=RelWithDebInfo -B. ../CMake make
mkdir projects/build cd projects/build cmake -G"Unix Makefiles" -DCMAKE_C_COMPILER=clang -DCMAKE_CXX_COMPILER=clang++ -DCMAKE_BUILD_TYPE=RelWithDebInfo -B. ../CMake make
mkdir projects/build cd projects/build cmake -G"Unix Makefiles" -DCMAKE_C_COMPILER=gcc -DCMAKE_CXX_COMPILER=g++ -DCMAKE_BUILD_TYPE=RelWithDebInfo -B. ../CMake make
mkdir projects\build cd projects\build cmake -G"NMake Makefiles" -DCMAKE_BUILD_TYPE=RelWithDebInfo -B. ..\CMake nmake
The build only produces test and example binaries.
ctest
rxcpp_test_*
rxcpp_test_subscription [perf]
RxCpp uses Doxygen to generate project documentation.
When Doxygen+Graphviz is installed, CMake creates a special build task named doc
. It creates actual documentation and puts it to projects/doxygen/html/
folder, which can be published to the gh-pages
branch. Each merged pull request will build the docs and publish them.
Before submitting a feature or substantial code contribution please discuss it with the team and ensure it follows the product roadmap. Note that all code submissions will be rigorously reviewed and tested by the Rx Team, and only those that meet an extremely high bar for both quality and design/roadmap appropriateness will be merged into the source.
You will be prompted to submit a Contributor License Agreement form after submitting your pull request. This needs to only be done once for any Microsoft OSS project. Fill in the Contributor License Agreement (CLA).
This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact [email protected] with any additional questions or comments.