Hyprland/src/protocols/OutputPower.cpp

74 lines
3.1 KiB
C++
Raw Permalink Normal View History

2024-04-29 01:28:26 +01:00
#include "OutputPower.hpp"
#include "core/Output.hpp"
#include "../helpers/Monitor.hpp"
2024-04-29 01:28:26 +01:00
COutputPower::COutputPower(SP<CZwlrOutputPowerV1> resource_, PHLMONITOR pMonitor_) : m_resource(resource_), m_monitor(pMonitor_) {
if UNLIKELY (!m_resource->resource())
2024-04-29 01:28:26 +01:00
return;
m_resource->setDestroy([this](CZwlrOutputPowerV1* r) { PROTO::outputPower->destroyOutputPower(this); });
m_resource->setOnDestroy([this](CZwlrOutputPowerV1* r) { PROTO::outputPower->destroyOutputPower(this); });
2024-04-29 01:28:26 +01:00
m_resource->setSetMode([this](CZwlrOutputPowerV1* r, zwlrOutputPowerV1Mode mode) {
if (!m_monitor)
2024-04-29 01:28:26 +01:00
return;
m_monitor->setDPMS(mode == ZWLR_OUTPUT_POWER_V1_MODE_ON);
2024-04-29 01:28:26 +01:00
});
m_resource->sendMode(m_monitor->m_dpmsStatus ? ZWLR_OUTPUT_POWER_V1_MODE_ON : ZWLR_OUTPUT_POWER_V1_MODE_OFF);
2024-04-29 01:28:26 +01:00
m_listeners.monitorDestroy = m_monitor->m_events.destroy.listen([this] {
m_monitor.reset();
m_resource->sendFailed();
2024-04-29 01:28:26 +01:00
});
m_listeners.monitorDpms =
m_monitor->m_events.dpmsChanged.listen([this] { m_resource->sendMode(m_monitor->m_dpmsStatus ? ZWLR_OUTPUT_POWER_V1_MODE_ON : ZWLR_OUTPUT_POWER_V1_MODE_OFF); });
m_listeners.monitorState =
m_monitor->m_events.modeChanged.listen([this] { m_resource->sendMode(m_monitor->m_dpmsStatus ? ZWLR_OUTPUT_POWER_V1_MODE_ON : ZWLR_OUTPUT_POWER_V1_MODE_OFF); });
2024-04-29 01:28:26 +01:00
}
bool COutputPower::good() {
return m_resource->resource();
2024-04-29 01:28:26 +01:00
}
COutputPowerProtocol::COutputPowerProtocol(const wl_interface* iface, const int& ver, const std::string& name) : IWaylandProtocol(iface, ver, name) {
;
}
void COutputPowerProtocol::bindManager(wl_client* client, void* data, uint32_t ver, uint32_t id) {
const auto RESOURCE = m_managers.emplace_back(makeUnique<CZwlrOutputPowerManagerV1>(client, ver, id)).get();
2024-04-29 01:28:26 +01:00
RESOURCE->setOnDestroy([this](CZwlrOutputPowerManagerV1* p) { this->onManagerResourceDestroy(p->resource()); });
RESOURCE->setDestroy([this](CZwlrOutputPowerManagerV1* pMgr) { this->onManagerResourceDestroy(pMgr->resource()); });
RESOURCE->setGetOutputPower([this](CZwlrOutputPowerManagerV1* hiThereFriend, uint32_t id, wl_resource* output) { this->onGetOutputPower(hiThereFriend, id, output); });
}
void COutputPowerProtocol::onManagerResourceDestroy(wl_resource* res) {
std::erase_if(m_managers, [&](const auto& other) { return other->resource() == res; });
2024-04-29 01:28:26 +01:00
}
void COutputPowerProtocol::destroyOutputPower(COutputPower* power) {
std::erase_if(m_outputPowers, [&](const auto& other) { return other.get() == power; });
2024-04-29 01:28:26 +01:00
}
void COutputPowerProtocol::onGetOutputPower(CZwlrOutputPowerManagerV1* pMgr, uint32_t id, wl_resource* output) {
const auto OUTPUT = CWLOutputResource::fromResource(output);
2024-04-29 01:28:26 +01:00
if UNLIKELY (!OUTPUT) {
pMgr->error(0, "Invalid output resource");
2024-04-29 01:28:26 +01:00
return;
}
const auto CLIENT = pMgr->client();
const auto RESOURCE = m_outputPowers.emplace_back(makeUnique<COutputPower>(makeShared<CZwlrOutputPowerV1>(CLIENT, pMgr->version(), id), OUTPUT->m_monitor.lock())).get();
2024-04-29 01:28:26 +01:00
if UNLIKELY (!RESOURCE->good()) {
pMgr->noMemory();
m_outputPowers.pop_back();
2024-04-29 01:28:26 +01:00
return;
}
}