mirror of
https://github.com/boostorg/redis.git
synced 2026-02-08 23:12:14 +00:00
Further progresses with response types.
This commit is contained in:
@@ -1,62 +1,61 @@
|
||||
/* Copyright (c) 2019 - 2020 Marcelo Zimbres Silva (mzimbres at gmail dot com)
|
||||
/* Copyright (c) 2019 - 2021 Marcelo Zimbres Silva (mzimbres at gmail dot com)
|
||||
*
|
||||
* This Source Code Form is subject to the terms of the Mozilla Public
|
||||
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||
* file, You can obtain one at https://mozilla.org/MPL/2.0/.
|
||||
*/
|
||||
|
||||
#include <boost/asio.hpp>
|
||||
#include <aedis/aedis.hpp>
|
||||
#include <aedis/utils.hpp>
|
||||
#include <aedis/receiver_print.hpp>
|
||||
|
||||
#include <stack>
|
||||
|
||||
namespace net = aedis::net;
|
||||
|
||||
namespace net = aedis::net;
|
||||
using tcp = net::ip::tcp;
|
||||
using tcp_socket = net::use_awaitable_t<>::as_default_on_t<tcp::socket>;
|
||||
|
||||
namespace this_coro = net::this_coro;
|
||||
|
||||
using namespace net;
|
||||
using namespace aedis;
|
||||
using tcp = net::ip::tcp;
|
||||
|
||||
void fill(resp::request<resp::event>& req)
|
||||
void fill1(resp::request<resp::event>& req)
|
||||
{
|
||||
req.multi();
|
||||
req.hello();
|
||||
req.ping();
|
||||
//req.multi();
|
||||
req.rpush("list", {1, 2, 3});
|
||||
req.lrange("list");
|
||||
req.exec();
|
||||
req.quit();
|
||||
//req.exec();
|
||||
req.ping();
|
||||
}
|
||||
|
||||
net::awaitable<void> example()
|
||||
{
|
||||
try {
|
||||
auto ex = co_await this_coro::executor;
|
||||
|
||||
auto ex = co_await net::this_coro::executor;
|
||||
tcp::resolver resv(ex);
|
||||
tcp_socket socket {ex};
|
||||
co_await net::async_connect(socket, resv.resolve("127.0.0.1", "6379"));
|
||||
auto const r = resv.resolve("127.0.0.1", "6379");
|
||||
tcp::socket socket {ex};
|
||||
co_await async_connect(socket, r, net::use_awaitable);
|
||||
|
||||
resp::request req;
|
||||
fill(req);
|
||||
co_await net::async_write(socket, net::buffer(req.payload));
|
||||
auto reqs = resp::make_request_queue<resp::event>();
|
||||
resp::response_buffers resps;
|
||||
resp::receiver_print recv{resps};
|
||||
net::steady_timer st{ex};
|
||||
|
||||
co_spawn(ex, resp::async_reader(socket, reqs, resps, recv), net::detached);
|
||||
resp::async_writer(socket, reqs, st, net::detached);
|
||||
queue_writer(reqs, fill1, st);
|
||||
|
||||
net::steady_timer timer(ex, std::chrono::years{1});
|
||||
co_await timer.async_wait(net::use_awaitable);
|
||||
|
||||
std::string buffer;
|
||||
for (;;) {
|
||||
resp::response_array<std::string> hello;
|
||||
co_await resp::async_read(socket, buffer, hello);
|
||||
resp::print(hello.result);
|
||||
}
|
||||
} catch (std::exception const& e) {
|
||||
std::cerr << e.what() << std::endl;
|
||||
std::cout << e.what() << std::endl;
|
||||
}
|
||||
}
|
||||
|
||||
int main()
|
||||
{
|
||||
io_context ioc {1};
|
||||
co_spawn(ioc, example(), detached);
|
||||
net::io_context ioc {1};
|
||||
co_spawn(ioc, example(), net::detached);
|
||||
ioc.run();
|
||||
}
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user