
This hasn't been an issue on Serenity, but on Linux, if a program opens a TCPServer on some port and then exits, that program can't be re-run until the OS makes the port available again. This is usually ~2x the TCP socket's maximum segment lifetime, upwards of a minute. Add an option to TCPServer to allow re-using the port after the program exits.
47 lines
1.1 KiB
C++
47 lines
1.1 KiB
C++
/*
|
|
* Copyright (c) 2018-2020, Andreas Kling <kling@serenityos.org>
|
|
* Copyright (c) 2021, Sam Atkins <atkinssj@serenityos.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <AK/IPv4Address.h>
|
|
#include <LibCore/Notifier.h>
|
|
#include <LibCore/Object.h>
|
|
#include <LibCore/Stream.h>
|
|
|
|
namespace Core {
|
|
|
|
class TCPServer : public Object {
|
|
C_OBJECT_ABSTRACT(TCPServer)
|
|
public:
|
|
static ErrorOr<NonnullRefPtr<TCPServer>> try_create(Object* parent = nullptr);
|
|
virtual ~TCPServer() override;
|
|
|
|
enum class AllowAddressReuse {
|
|
Yes,
|
|
No,
|
|
};
|
|
|
|
bool is_listening() const { return m_listening; }
|
|
ErrorOr<void> listen(IPv4Address const& address, u16 port, AllowAddressReuse = AllowAddressReuse::No);
|
|
ErrorOr<void> set_blocking(bool blocking);
|
|
|
|
ErrorOr<NonnullOwnPtr<Stream::TCPSocket>> accept();
|
|
|
|
Optional<IPv4Address> local_address() const;
|
|
Optional<u16> local_port() const;
|
|
|
|
Function<void()> on_ready_to_accept;
|
|
|
|
private:
|
|
explicit TCPServer(int fd, Object* parent = nullptr);
|
|
|
|
int m_fd { -1 };
|
|
bool m_listening { false };
|
|
RefPtr<Notifier> m_notifier;
|
|
};
|
|
|
|
}
|