OutputDevice: inline update methods

This commit is contained in:
Xaver Hugl 2021-11-12 10:27:38 +01:00
parent d166db12b6
commit 357b5c1923

View file

@ -28,16 +28,6 @@ public:
~OutputDeviceV2InterfacePrivate() override;
void updateGeometry();
void updateUuid();
void updateEdid();
void updateEnabled();
void updateScale();
void updateEisaId();
void updateSerialNumber();
void updateCapabilities();
void updateOverscan();
void updateVrrPolicy();
void updateRgbRange();
void sendGeometry(Resource *resource);
wl_resource *sendNewMode(Resource *resource, OutputDeviceModeV2Interface *mode);
@ -355,21 +345,12 @@ void OutputDeviceV2InterfacePrivate::sendDone(Resource *resource)
void OutputDeviceV2InterfacePrivate::updateGeometry()
{
const auto clientResources = resourceMap();
for (auto resource : clientResources) {
for (const auto &resource : clientResources) {
sendGeometry(resource);
sendDone(resource);
}
}
void OutputDeviceV2InterfacePrivate::updateScale()
{
const auto clientResources = resourceMap();
for (auto resource : clientResources) {
sendScale(resource);
sendDone(resource);
}
}
void OutputDeviceV2Interface::setPhysicalSize(const QSize &arg)
{
if (d->physicalSize == arg) {
@ -451,7 +432,11 @@ void OutputDeviceV2Interface::setScale(qreal scale)
return;
}
d->scale = scale;
d->updateScale();
const auto clientResources = d->resourceMap();
for (const auto &resource : clientResources) {
d->sendScale(resource);
d->sendDone(resource);
}
}
QSize OutputDeviceV2Interface::physicalSize() const
@ -515,8 +500,6 @@ void OutputDeviceV2Interface::setModes(const QList<OutputDeviceModeV2Interface *
const auto oldModes = d->modes;
d->modes.clear();
const auto oldCurrentMode = d->currentMode;
d->currentMode = nullptr;
for (OutputDeviceModeV2Interface *outputDeviceMode : modes) {
@ -551,7 +534,11 @@ void OutputDeviceV2Interface::setModes(const QList<OutputDeviceModeV2Interface *
void OutputDeviceV2Interface::setEdid(const QByteArray &edid)
{
d->edid = edid;
d->updateEdid();
const auto clientResources = d->resourceMap();
for (const auto &resource : clientResources) {
d->sendEdid(resource);
d->sendDone(resource);
}
}
QByteArray OutputDeviceV2Interface::edid() const
@ -563,7 +550,11 @@ void OutputDeviceV2Interface::setEnabled(bool enabled)
{
if (d->enabled != enabled) {
d->enabled = enabled;
d->updateEnabled();
const auto clientResources = d->resourceMap();
for (const auto &resource : clientResources) {
d->sendEnabled(resource);
d->sendDone(resource);
}
}
}
@ -576,7 +567,11 @@ void OutputDeviceV2Interface::setUuid(const QUuid &uuid)
{
if (d->uuid != uuid) {
d->uuid = uuid;
d->updateUuid();
const auto clientResources = d->resourceMap();
for (const auto &resource : clientResources) {
d->sendUuid(resource);
d->sendDone(resource);
}
}
}
@ -600,42 +595,6 @@ void OutputDeviceV2InterfacePrivate::sendUuid(Resource *resource)
send_uuid(resource->handle, uuid.toString(QUuid::WithoutBraces));
}
void OutputDeviceV2InterfacePrivate::updateEnabled()
{
const auto clientResources = resourceMap();
for (auto resource : clientResources) {
sendEnabled(resource);
sendDone(resource);
}
}
void OutputDeviceV2InterfacePrivate::updateEdid()
{
const auto clientResources = resourceMap();
for (auto resource : clientResources) {
sendEdid(resource);
sendDone(resource);
}
}
void OutputDeviceV2InterfacePrivate::updateUuid()
{
const auto clientResources = resourceMap();
for (auto resource : clientResources) {
sendUuid(resource);
sendDone(resource);
}
}
void OutputDeviceV2InterfacePrivate::updateEisaId()
{
const auto clientResources = resourceMap();
for (auto resource : clientResources) {
sendEisaId(resource);
sendDone(resource);
}
}
uint32_t OutputDeviceV2Interface::overscan() const
{
return d->overscan;
@ -650,7 +609,11 @@ void OutputDeviceV2Interface::setCapabilities(Capabilities cap)
{
if (d->capabilities != cap) {
d->capabilities = cap;
d->updateCapabilities();
const auto clientResources = d->resourceMap();
for (const auto &resource : clientResources) {
d->sendCapabilities(resource);
d->sendDone(resource);
}
}
}
@ -659,20 +622,15 @@ void OutputDeviceV2InterfacePrivate::sendCapabilities(Resource *resource)
send_capabilities(resource->handle, static_cast<uint32_t>(capabilities));
}
void OutputDeviceV2InterfacePrivate::updateCapabilities()
{
const auto clientResources = resourceMap();
for (const auto &resource : clientResources) {
sendCapabilities(resource);
sendDone(resource);
}
}
void OutputDeviceV2Interface::setOverscan(uint32_t overscan)
{
if (d->overscan != overscan) {
d->overscan = overscan;
d->updateOverscan();
const auto clientResources = d->resourceMap();
for (const auto &resource : clientResources) {
d->sendOverscan(resource);
d->sendDone(resource);
}
}
}
@ -681,15 +639,6 @@ void OutputDeviceV2InterfacePrivate::sendOverscan(Resource *resource)
send_overscan(resource->handle, static_cast<uint32_t>(overscan));
}
void OutputDeviceV2InterfacePrivate::updateOverscan()
{
const auto clientResources = resourceMap();
for (const auto &resource : clientResources) {
sendOverscan(resource);
sendDone(resource);
}
}
void OutputDeviceV2InterfacePrivate::sendVrrPolicy(Resource *resource)
{
send_vrr_policy(resource->handle, static_cast<uint32_t>(vrrPolicy));
@ -704,16 +653,11 @@ void OutputDeviceV2Interface::setVrrPolicy(VrrPolicy policy)
{
if (d->vrrPolicy != policy) {
d->vrrPolicy = policy;
d->updateVrrPolicy();
}
}
void OutputDeviceV2InterfacePrivate::updateVrrPolicy()
{
const auto clientResources = resourceMap();
const auto clientResources = d->resourceMap();
for (const auto &resource : clientResources) {
sendVrrPolicy(resource);
sendDone(resource);
d->sendVrrPolicy(resource);
d->sendDone(resource);
}
}
}
@ -726,7 +670,11 @@ void OutputDeviceV2Interface::setRgbRange(RgbRange rgbRange)
{
if (d->rgbRange != rgbRange) {
d->rgbRange = rgbRange;
d->updateRgbRange();
const auto clientResources = d->resourceMap();
for (const auto &resource : clientResources) {
d->sendRgbRange(resource);
d->sendDone(resource);
}
}
}
@ -735,15 +683,6 @@ void OutputDeviceV2InterfacePrivate::sendRgbRange(Resource *resource)
send_rgb_range(resource->handle, static_cast<uint32_t>(rgbRange));
}
void OutputDeviceV2InterfacePrivate::updateRgbRange()
{
const auto clientResources = resourceMap();
for (const auto &resource : clientResources) {
sendRgbRange(resource);
sendDone(resource);
}
}
wl_resource *OutputDeviceV2Interface::resource() const
{
return d->resource()->handle;