mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-25 03:42:06 +00:00 
			
		
		
		
	 dbd25916a3
			
		
	
	
		dbd25916a3
		
	
	
	
	
		
			
			As per previous discussion, it was decided that the Stream classes should be constructed on the heap. While I don't personally agree with this change, it does have the benefit of avoiding Function object reconstructions due to the lambda passed to Notifier pointing to a stale object reference. This also has the benefit of not having to "box" objects for virtual usage, as the objects come pre-boxed. However, it means that we now hit the heap everytime we construct a TCPSocket for instance, which might not be desirable.
		
			
				
	
	
		
			42 lines
		
	
	
	
		
			1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			42 lines
		
	
	
	
		
			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;
 | |
| 
 | |
|     bool is_listening() const { return m_listening; }
 | |
|     ErrorOr<void> listen(IPv4Address const& address, u16 port);
 | |
|     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;
 | |
| };
 | |
| 
 | |
| }
 |