mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-31 09:02:43 +00:00 
			
		
		
		
	 b3e9a4e603
			
		
	
	
		b3e9a4e603
		
	
	
	
	
		
			
			Derivatives of Core::Object should be constructed through ClassName::construct(), to avoid handling ref-counted objects with refcount zero. Fixing the visibility means that misuses like this are more difficult.
		
			
				
	
	
		
			61 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			61 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2020, the SerenityOS developers.
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <LibChess/UCICommand.h>
 | |
| #include <LibCore/IODevice.h>
 | |
| #include <LibCore/Notifier.h>
 | |
| #include <LibCore/Object.h>
 | |
| 
 | |
| namespace Chess::UCI {
 | |
| 
 | |
| class Endpoint : public Core::Object {
 | |
|     C_OBJECT(Endpoint)
 | |
| public:
 | |
|     virtual ~Endpoint() override { }
 | |
| 
 | |
|     virtual void handle_uci() { }
 | |
|     virtual void handle_debug(const DebugCommand&) { }
 | |
|     virtual void handle_isready() { }
 | |
|     virtual void handle_setoption(const SetOptionCommand&) { }
 | |
|     virtual void handle_position(const PositionCommand&) { }
 | |
|     virtual void handle_go(const GoCommand&) { }
 | |
|     virtual void handle_stop() { }
 | |
|     virtual void handle_id(const IdCommand&) { }
 | |
|     virtual void handle_uciok() { }
 | |
|     virtual void handle_readyok() { }
 | |
|     virtual void handle_bestmove(const BestMoveCommand&) { }
 | |
|     virtual void handle_info(const InfoCommand&) { }
 | |
| 
 | |
|     void send_command(const Command&);
 | |
| 
 | |
|     virtual void event(Core::Event&) override;
 | |
| 
 | |
|     Core::IODevice& in() { return *m_in; }
 | |
|     Core::IODevice& out() { return *m_out; }
 | |
| 
 | |
|     void set_in(RefPtr<Core::IODevice> in)
 | |
|     {
 | |
|         m_in = in;
 | |
|         set_in_notifier();
 | |
|     }
 | |
|     void set_out(RefPtr<Core::IODevice> out) { m_out = out; }
 | |
| 
 | |
| protected:
 | |
|     Endpoint() { }
 | |
|     Endpoint(NonnullRefPtr<Core::IODevice> in, NonnullRefPtr<Core::IODevice> out);
 | |
| 
 | |
| private:
 | |
|     void set_in_notifier();
 | |
|     NonnullOwnPtr<Command> read_command();
 | |
| 
 | |
|     RefPtr<Core::IODevice> m_in;
 | |
|     RefPtr<Core::IODevice> m_out;
 | |
|     RefPtr<Core::Notifier> m_in_notifier;
 | |
| };
 | |
| 
 | |
| }
 |