mirror of
https://github.com/RGBCube/serenity
synced 2025-10-24 13:22:07 +00:00

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;
|
|
};
|
|
|
|
}
|