
The C_OBJECT macro now also inserts a static construct(...) helper into the class. Now we can make the constructor(s) private and instead call: auto socket = CTCPSocket::construct(arguments); construct() returns an ObjectPtr<T>, which we'll later switch to being a NonnullRefPtr<T>, once everything else in in place for ref-counting.
46 lines
1.5 KiB
C++
46 lines
1.5 KiB
C++
#pragma once
|
|
|
|
#include <LibCore/CEventLoop.h>
|
|
#include <LibCore/CoreIPCClient.h>
|
|
#include <LibGUI/GEvent.h>
|
|
#include <WindowServer/WSAPITypes.h>
|
|
|
|
class GAction;
|
|
class CObject;
|
|
class CNotifier;
|
|
class GWindow;
|
|
|
|
class GWindowServerConnection : public IPC::Client::Connection<WSAPI_ServerMessage, WSAPI_ClientMessage> {
|
|
C_OBJECT(GWindowServerConnection)
|
|
public:
|
|
GWindowServerConnection()
|
|
: Connection("/tmp/wsportal")
|
|
{}
|
|
|
|
void handshake() override;
|
|
static GWindowServerConnection& the();
|
|
|
|
private:
|
|
void postprocess_bundles(Vector<IncomingMessageBundle>& m_unprocessed_bundles) override;
|
|
void handle_paint_event(const WSAPI_ServerMessage&, GWindow&, const ByteBuffer& extra_data);
|
|
void handle_resize_event(const WSAPI_ServerMessage&, GWindow&);
|
|
void handle_mouse_event(const WSAPI_ServerMessage&, GWindow&);
|
|
void handle_key_event(const WSAPI_ServerMessage&, GWindow&);
|
|
void handle_window_activation_event(const WSAPI_ServerMessage&, GWindow&);
|
|
void handle_window_close_request_event(const WSAPI_ServerMessage&, GWindow&);
|
|
void handle_menu_event(const WSAPI_ServerMessage&);
|
|
void handle_window_entered_or_left_event(const WSAPI_ServerMessage&, GWindow&);
|
|
void handle_wm_event(const WSAPI_ServerMessage&, GWindow&);
|
|
void handle_greeting(WSAPI_ServerMessage&);
|
|
};
|
|
|
|
class GEventLoop final : public CEventLoop {
|
|
public:
|
|
GEventLoop();
|
|
virtual ~GEventLoop() override;
|
|
|
|
static GEventLoop& current() { return static_cast<GEventLoop&>(CEventLoop::current()); }
|
|
|
|
private:
|
|
void process_unprocessed_bundles();
|
|
};
|