summaryrefslogtreecommitdiff
path: root/Rx/v2/examples/doxygen/combine_latest.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'Rx/v2/examples/doxygen/combine_latest.cpp')
-rw-r--r--Rx/v2/examples/doxygen/combine_latest.cpp85
1 files changed, 0 insertions, 85 deletions
diff --git a/Rx/v2/examples/doxygen/combine_latest.cpp b/Rx/v2/examples/doxygen/combine_latest.cpp
deleted file mode 100644
index 5f2168b..0000000
--- a/Rx/v2/examples/doxygen/combine_latest.cpp
+++ /dev/null
@@ -1,85 +0,0 @@
-#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");
-}
-
-#include "main.hpp"
-
-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");
-}