aboutsummaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--src/protocols/WaylandProtocol.cpp90
-rw-r--r--src/protocols/WaylandProtocol.hpp28
2 files changed, 0 insertions, 118 deletions
diff --git a/src/protocols/WaylandProtocol.cpp b/src/protocols/WaylandProtocol.cpp
index 76f5eba0..988836db 100644
--- a/src/protocols/WaylandProtocol.cpp
+++ b/src/protocols/WaylandProtocol.cpp
@@ -1,96 +1,6 @@
#include "WaylandProtocol.hpp"
#include "../Compositor.hpp"
-static void resourceDestroyNotify(wl_listener* listener, void* data) {
- CWaylandResource* pResource = wl_container_of(listener, pResource, m_liResourceDestroy);
- pResource->markDefunct();
-}
-
-CWaylandResource::CWaylandResource(wl_client* client, const wl_interface* wlInterface, uint32_t version, uint32_t id) {
- m_pWLResource = wl_resource_create(client, wlInterface, version, id);
-
- if (!m_pWLResource) {
- wl_client_post_no_memory(client);
- return;
- }
-
- wl_resource_set_user_data(m_pWLResource, this);
-
- m_pWLClient = client;
-
- wl_list_init(&m_liResourceDestroy.link);
- m_liResourceDestroy.notify = resourceDestroyNotify;
- wl_resource_add_destroy_listener(m_pWLResource, &m_liResourceDestroy);
-
- Debug::log(TRACE, "[wl res {:x}] created", (uintptr_t)m_pWLResource);
-}
-
-void CWaylandResource::markDefunct() {
- if (m_bDefunct)
- return;
-
- Debug::log(TRACE, "[wl res {:x}] now defunct", (uintptr_t)m_pWLResource);
- m_bDefunct = true;
-
- wl_resource_set_user_data(m_pWLResource, nullptr);
-
- // we call it here because we need defunct to be set to true.
- // if this function destroys us, we can't call wl_resource_set_user_data or
- // destroy the resource.
- if (m_fOnDestroyHandler)
- m_fOnDestroyHandler(this);
-}
-
-CWaylandResource::~CWaylandResource() {
- const bool DESTROY = m_pWLResource && !m_bDefunct;
-
- wl_list_remove(&m_liResourceDestroy.link);
- wl_list_init(&m_liResourceDestroy.link);
-
- Debug::log(TRACE, "[wl res {:x}] destroying (wl_resource_destroy will be {})", (uintptr_t)m_pWLResource, (DESTROY ? "sent" : "not sent"));
-
- if (DESTROY)
- wl_resource_destroy(m_pWLResource);
-}
-
-bool CWaylandResource::good() {
- return m_pWLResource && !m_bDefunct;
-}
-
-wl_resource* CWaylandResource::resource() {
- return m_pWLResource;
-}
-
-uint32_t CWaylandResource::version() {
- RASSERT(good(), "Attempted to call version() on a bad resource");
-
- return wl_resource_get_version(m_pWLResource);
-}
-
-void CWaylandResource::setImplementation(const void* impl, wl_resource_destroy_func_t df) {
- RASSERT(good(), "Attempted to call setImplementation() on a bad resource");
- RASSERT(!m_bImplementationSet, "Wayland Resource {:x} already has an implementation, cannot re-set!", (uintptr_t)m_pWLResource);
-
- wl_resource_set_implementation(m_pWLResource, impl, this, df);
-
- Debug::log(TRACE, "[wl res {:x}] set impl to {:x}", (uintptr_t)m_pWLResource, (uintptr_t)impl);
-
- m_bImplementationSet = true;
-}
-
-void CWaylandResource::setData(void* data) {
- Debug::log(TRACE, "[wl res {:x}] set data to {:x}", (uintptr_t)m_pWLResource, (uintptr_t)data);
- m_pData = data;
-}
-
-void* CWaylandResource::data() {
- return m_pData;
-}
-
-void CWaylandResource::setOnDestroyHandler(std::function<void(CWaylandResource* res)> fn) {
- m_fOnDestroyHandler = fn;
-}
-
static void bindManagerInternal(wl_client* client, void* data, uint32_t ver, uint32_t id) {
((IWaylandProtocol*)data)->bindManager(client, data, ver, id);
}
diff --git a/src/protocols/WaylandProtocol.hpp b/src/protocols/WaylandProtocol.hpp
index cc8a0e53..588a1420 100644
--- a/src/protocols/WaylandProtocol.hpp
+++ b/src/protocols/WaylandProtocol.hpp
@@ -14,34 +14,6 @@
#define PROTO NProtocols
-class CWaylandResource {
- public:
- CWaylandResource(wl_client* client, const wl_interface* wlInterface, uint32_t version, uint32_t id);
- ~CWaylandResource();
-
- bool good();
- wl_resource* resource();
- uint32_t version();
-
- void setImplementation(const void* impl, wl_resource_destroy_func_t df);
-
- wl_listener m_liResourceDestroy; // private but has to be public
- void markDefunct();
-
- void* data();
- void setData(void* data);
-
- void setOnDestroyHandler(std::function<void(CWaylandResource* res)> fn);
-
- private:
- bool m_bImplementationSet = false;
- bool m_bDefunct = false; // m_liResourceDestroy fired
- wl_client* m_pWLClient = nullptr;
- wl_resource* m_pWLResource = nullptr;
- void* m_pData = nullptr;
- std::function<void(CWaylandResource* res)> m_fOnDestroyHandler;
-};
-
class IWaylandProtocol {
public:
IWaylandProtocol(const wl_interface* iface, const int& ver, const std::string& name);