summaryrefslogtreecommitdiff
path: root/Rx/v2/examples/doxygen/timeout.cpp
blob: c61d5190c76f670cc913948a82d94608255687f7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
#include "rxcpp/rx.hpp"

#include "rxcpp/rx-test.hpp"
#include "catch.hpp"

SCENARIO("timeout sample"){
    printf("//! [timeout sample]\n");

    using namespace std::chrono;
    auto values = rxcpp::observable<>::interval(milliseconds(100))
            .take(3)
            .concat(rxcpp::observable<>::interval(milliseconds(500)))
            .timeout(milliseconds(200));
    values.
        subscribe(
            [](long v) { printf("OnNext: %ld\n", v); },
            [](std::exception_ptr ep) {
                try {
                    std::rethrow_exception(ep);
                } catch (const rxcpp::timeout_error& ex) {
                    printf("OnError: %s\n", ex.what());
                }
            },
            []() { printf("OnCompleted\n"); });
    printf("//! [timeout sample]\n");
}