mirror of
https://github.com/RGBCube/serenity
synced 2025-05-14 04:14:58 +00:00

This causes a behavior change in which the read FD is now non-blocking. This is intentional, as this change avoids a deadlock between RS and WebContent, where WC could block while reading from the request FD, while RS is blocked sending a message to WC.
42 lines
957 B
C++
42 lines
957 B
C++
/*
|
|
* Copyright (c) 2018-2020, Andreas Kling <kling@serenityos.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#include <AK/HashMap.h>
|
|
#include <AK/NonnullOwnPtr.h>
|
|
#include <LibCore/System.h>
|
|
#include <RequestServer/Protocol.h>
|
|
|
|
namespace RequestServer {
|
|
|
|
static HashMap<ByteString, NonnullOwnPtr<Protocol>>& all_protocols()
|
|
{
|
|
static HashMap<ByteString, NonnullOwnPtr<Protocol>> map;
|
|
return map;
|
|
}
|
|
|
|
Protocol* Protocol::find_by_name(ByteString const& name)
|
|
{
|
|
return all_protocols().get(name).map([](auto& p) -> Protocol* { return p; }).value_or(nullptr);
|
|
}
|
|
|
|
Protocol::Protocol(ByteString const& name)
|
|
: m_name(name)
|
|
{
|
|
}
|
|
|
|
ErrorOr<Protocol::Pipe> Protocol::get_pipe_for_request()
|
|
{
|
|
auto fd_pair = TRY(Core::System::pipe2(O_NONBLOCK));
|
|
return Pipe { fd_pair[0], fd_pair[1] };
|
|
}
|
|
|
|
void Protocol::install(NonnullOwnPtr<Protocol> protocol)
|
|
{
|
|
auto name = protocol->name();
|
|
all_protocols().set(move(name), move(protocol));
|
|
}
|
|
|
|
}
|