1
0
Fork 0
forked from suyu/suyu

Merge pull request #8435 from liamwhite/lambda-capture

core/debugger: fix crash due to incorrect lambda capture
This commit is contained in:
Mai M 2022-06-06 23:58:34 -04:00 committed by GitHub
commit 31527ccd25
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -20,7 +20,8 @@ template <typename Readable, typename Buffer, typename Callback>
static void AsyncReceiveInto(Readable& r, Buffer& buffer, Callback&& c) { static void AsyncReceiveInto(Readable& r, Buffer& buffer, Callback&& c) {
static_assert(std::is_trivial_v<Buffer>); static_assert(std::is_trivial_v<Buffer>);
auto boost_buffer{boost::asio::buffer(&buffer, sizeof(Buffer))}; auto boost_buffer{boost::asio::buffer(&buffer, sizeof(Buffer))};
r.async_read_some(boost_buffer, [&](const boost::system::error_code& error, size_t bytes_read) { r.async_read_some(
boost_buffer, [&, c](const boost::system::error_code& error, size_t bytes_read) {
if (!error.failed()) { if (!error.failed()) {
const u8* buffer_start = reinterpret_cast<const u8*>(&buffer); const u8* buffer_start = reinterpret_cast<const u8*>(&buffer);
std::span<const u8> received_data{buffer_start, buffer_start + bytes_read}; std::span<const u8> received_data{buffer_start, buffer_start + bytes_read};