7#include <boost/redis/connection.hpp>
8#include <boost/redis/resp3/serialization.hpp>
9#include <boost/asio/co_spawn.hpp>
10#include <boost/asio/detached.hpp>
11#include <boost/asio/consign.hpp>
12#include <boost/system/errc.hpp>
19#if defined(BOOST_ASIO_HAS_CO_AWAIT)
21namespace asio = boost::asio;
22namespace resp3 = boost::redis::resp3;
32using tutorial::person;
41void boost_redis_to_bulk(std::string& to, person
const& u)
44 if (!u.SerializeToString(&tmp))
47 resp3::boost_redis_to_bulk(to, tmp);
53 node_view
const& node,
54 boost::system::error_code& ec)
56 std::string
const tmp {
node.value};
57 if (!u.ParseFromString(tmp))
63using tutorial::boost_redis_to_bulk;
64using tutorial::boost_redis_from_bulk;
66asio::awaitable<void> co_main(config cfg)
68 auto ex =
co_await asio::this_coro::executor;
69 auto conn = std::make_shared<connection>(ex);
70 conn->async_run(cfg, {}, asio::consign(asio::detached, conn));
75 p.set_email(
"No email yet.");
78 req.push(
"SET",
"protobuf-key", p);
79 req.push(
"GET",
"protobuf-key");
81 response<ignore_t, person> resp;
84 co_await conn->async_exec(req, resp);
88 <<
"Name: " << std::get<1>(resp).value().name() <<
"\n"
89 <<
"Age: " << std::get<1>(resp).value().id() <<
"\n"
90 <<
"Email: " << std::get<1>(resp).value().email() <<
"\n";
A basic_connection that type erases the executor.
std::decay_t< decltype(std::ignore)> ignore_t
Type used to ignore responses.
basic_node< std::string > node
A node in the response tree that owns its data.
operation
Connection operations that can be cancelled.
std::tuple< adapter::result< Ts >... > response
Response with compile-time size.
@ invalid_data_type
Invalid RESP3 type.
Configure parameters used by the connection classes.
A node in the response tree.