diff options
Diffstat (limited to 'Rx/v2/examples/doxygen/combine_latest.cpp')
-rw-r--r-- | Rx/v2/examples/doxygen/combine_latest.cpp | 85 |
1 files changed, 85 insertions, 0 deletions
diff --git a/Rx/v2/examples/doxygen/combine_latest.cpp b/Rx/v2/examples/doxygen/combine_latest.cpp new file mode 100644 index 0000000..b220da4 --- /dev/null +++ b/Rx/v2/examples/doxygen/combine_latest.cpp @@ -0,0 +1,85 @@ +#include "rxcpp/rx.hpp" + +#include "rxcpp/rx-test.hpp" +#include "catch.hpp" + +SCENARIO("combine_latest sample"){ + printf("//! [combine_latest sample]\n"); + auto o1 = rxcpp::observable<>::interval(std::chrono::milliseconds(2)); + auto o2 = rxcpp::observable<>::interval(std::chrono::milliseconds(3)); + auto o3 = rxcpp::observable<>::interval(std::chrono::milliseconds(5)); + auto values = o1.combine_latest(o2, o3); + values. + take(5). + subscribe( + [](std::tuple<int, int, int> v){printf("OnNext: %d, %d, %d\n", std::get<0>(v), std::get<1>(v), std::get<2>(v));}, + [](){printf("OnCompleted\n");}); + printf("//! [combine_latest sample]\n"); +} + +std::string get_pid(); + +SCENARIO("Coordination combine_latest sample"){ + printf("//! [Coordination combine_latest sample]\n"); + printf("[thread %s] Start task\n", get_pid().c_str()); + auto thr = rxcpp::synchronize_event_loop(); + auto o1 = rxcpp::observable<>::interval(std::chrono::milliseconds(2)).map([](int v) { + printf("[thread %s] Source1 OnNext: %d\n", get_pid().c_str(), v); + return v; + }); + auto o2 = rxcpp::observable<>::interval(std::chrono::milliseconds(3)).map([](int v) { + printf("[thread %s] Source2 OnNext: %d\n", get_pid().c_str(), v); + return v; + }); + auto o3 = rxcpp::observable<>::interval(std::chrono::milliseconds(5)).map([](int v) { + printf("[thread %s] Source3 OnNext: %d\n", get_pid().c_str(), v); + return v; + }); + auto values = o1.combine_latest(thr, o2, o3); + values. + take(5). + as_blocking(). + subscribe( + [](std::tuple<int, int, int> v){printf("[thread %s] OnNext: %d, %d, %d\n", get_pid().c_str(), std::get<0>(v), std::get<1>(v), std::get<2>(v));}, + [](){printf("[thread %s] OnCompleted\n", get_pid().c_str());}); + printf("[thread %s] Finish task\n", get_pid().c_str()); + printf("//! [Coordination combine_latest sample]\n"); +} + +SCENARIO("Selector combine_latest sample"){ + printf("//! [Selector combine_latest sample]\n"); + auto o1 = rxcpp::observable<>::interval(std::chrono::milliseconds(2)); + auto o2 = rxcpp::observable<>::interval(std::chrono::milliseconds(3)); + auto o3 = rxcpp::observable<>::interval(std::chrono::milliseconds(5)); + auto values = o1.combine_latest( + [](int v1, int v2, int v3) { + return 100 * v1 + 10 * v2 + v3; + }, + o2, o3); + values. + take(5). + subscribe( + [](int v){printf("OnNext: %d\n", v);}, + [](){printf("OnCompleted\n");}); + printf("//! [Selector combine_latest sample]\n"); +} + +SCENARIO("Coordination+Selector combine_latest sample"){ + printf("//! [Coordination+Selector combine_latest sample]\n"); + auto o1 = rxcpp::observable<>::interval(std::chrono::milliseconds(2)); + auto o2 = rxcpp::observable<>::interval(std::chrono::milliseconds(3)); + auto o3 = rxcpp::observable<>::interval(std::chrono::milliseconds(5)); + auto values = o1.combine_latest( + rxcpp::observe_on_new_thread(), + [](int v1, int v2, int v3) { + return 100 * v1 + 10 * v2 + v3; + }, + o2, o3); + values. + take(5). + as_blocking(). + subscribe( + [](int v){printf("OnNext: %d\n", v);}, + [](){printf("OnCompleted\n");}); + printf("//! [Coordination+Selector combine_latest sample]\n"); +} |