mirror of
https://github.com/matrix-construct/construct
synced 2025-01-19 19:11:53 +01:00
ircd::server: Use disassociate() during cancel(); tweak assertions.
This commit is contained in:
parent
b0c687ea0e
commit
c2b2dc8d69
1 changed files with 6 additions and 4 deletions
|
@ -1825,8 +1825,9 @@ noexcept
|
||||||
assert(tag.request == &request);
|
assert(tag.request == &request);
|
||||||
|
|
||||||
// Disassociate the user's request and add our dummy request in its place.
|
// Disassociate the user's request and add our dummy request in its place.
|
||||||
|
disassociate(request, tag);
|
||||||
|
|
||||||
request.tag = nullptr;
|
assert(tag.request == nullptr);
|
||||||
tag.request = new server::request{};
|
tag.request = new server::request{};
|
||||||
tag.request->tag = &tag;
|
tag.request->tag = &tag;
|
||||||
|
|
||||||
|
@ -1989,6 +1990,7 @@ ircd::server::disassociate(request &request,
|
||||||
{
|
{
|
||||||
assert(request.tag == &tag);
|
assert(request.tag == &tag);
|
||||||
assert(tag.request == &request);
|
assert(tag.request == &request);
|
||||||
|
assert(tag.abandoned());
|
||||||
|
|
||||||
request.tag = nullptr;
|
request.tag = nullptr;
|
||||||
tag.request = nullptr;
|
tag.request = nullptr;
|
||||||
|
@ -2353,8 +2355,9 @@ ircd::server::tag::read_content(const const_buffer &buffer,
|
||||||
|
|
||||||
if(state.content_read == size(content) + content_overflow())
|
if(state.content_read == size(content) + content_overflow())
|
||||||
{
|
{
|
||||||
done = true;
|
|
||||||
assert(state.content_read == state.content_length);
|
assert(state.content_read == state.content_length);
|
||||||
|
assert(!done);
|
||||||
|
done = true;
|
||||||
set_value(state.status);
|
set_value(state.status);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2501,6 +2504,7 @@ ircd::server::tag::read_chunk_content(const const_buffer &buffer,
|
||||||
|
|
||||||
if(state.chunk_length == 2)
|
if(state.chunk_length == 2)
|
||||||
{
|
{
|
||||||
|
assert(!done);
|
||||||
done = true;
|
done = true;
|
||||||
req.in.content = mutable_buffer{data(req.in.content), state.content_length};
|
req.in.content = mutable_buffer{data(req.in.content), state.content_length};
|
||||||
set_value(state.status);
|
set_value(state.status);
|
||||||
|
@ -2751,7 +2755,6 @@ ircd::server::tag::set_value(args&&... a)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
assert(p.valid());
|
|
||||||
p.set_value(code);
|
p.set_value(code);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2771,7 +2774,6 @@ ircd::server::tag::set_exception(std::exception_ptr eptr)
|
||||||
if(abandoned())
|
if(abandoned())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
assert(p.valid());
|
|
||||||
p.set_exception(std::move(eptr));
|
p.set_exception(std::move(eptr));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue