mirror of
https://github.com/boostorg/redis.git
synced 2026-01-19 04:42:09 +00:00
56 lines
1.7 KiB
C++
56 lines
1.7 KiB
C++
/* Copyright (c) 2018-2022 Marcelo Zimbres Silva (mzimbres@gmail.com)
|
|
*
|
|
* Distributed under the Boost Software License, Version 1.0. (See
|
|
* accompanying file LICENSE.txt)
|
|
*/
|
|
|
|
#include <boost/redis/adapter/adapt.hpp>
|
|
#include <boost/redis/detail/read.hpp>
|
|
#include <boost/redis/detail/write.hpp>
|
|
#include <boost/asio/use_awaitable.hpp>
|
|
#include <boost/asio/connect.hpp>
|
|
#include <boost/asio/ip/tcp.hpp>
|
|
#include <string>
|
|
#include <iostream>
|
|
#if defined(BOOST_ASIO_HAS_CO_AWAIT)
|
|
|
|
namespace net = boost::asio;
|
|
namespace redis = boost::redis;
|
|
using resolver = net::use_awaitable_t<>::as_default_on_t<net::ip::tcp::resolver>;
|
|
using tcp_socket = net::use_awaitable_t<>::as_default_on_t<net::ip::tcp::socket>;
|
|
using boost::redis::adapter::adapt2;
|
|
using net::ip::tcp;
|
|
using boost::redis::request;
|
|
using boost::redis::adapter::result;
|
|
|
|
auto co_main(std::string host, std::string port) -> net::awaitable<void>
|
|
{
|
|
auto ex = co_await net::this_coro::executor;
|
|
|
|
resolver resv{ex};
|
|
auto const addrs = co_await resv.async_resolve(host, port);
|
|
tcp_socket socket{ex};
|
|
co_await net::async_connect(socket, addrs);
|
|
|
|
// Creates the request and writes to the socket.
|
|
request req;
|
|
req.push("HELLO", 3);
|
|
req.push("PING", "Hello world");
|
|
req.push("QUIT");
|
|
co_await redis::detail::async_write(socket, req);
|
|
|
|
// Responses
|
|
std::string buffer;
|
|
result<std::string> resp;
|
|
|
|
// Reads the responses to all commands in the request.
|
|
auto dbuffer = net::dynamic_buffer(buffer);
|
|
co_await redis::detail::async_read(socket, dbuffer);
|
|
co_await redis::detail::async_read(socket, dbuffer, adapt2(resp));
|
|
co_await redis::detail::async_read(socket, dbuffer);
|
|
|
|
std::cout << "Ping: " << resp.value() << std::endl;
|
|
}
|
|
|
|
#endif // defined(BOOST_ASIO_HAS_CO_AWAIT)
|