diff --git a/tdecore/tdehw/tdehardwaredevices.cpp b/tdecore/tdehw/tdehardwaredevices.cpp index 697048dbf..8ee62ca8f 100644 --- a/tdecore/tdehw/tdehardwaredevices.cpp +++ b/tdecore/tdehw/tdehardwaredevices.cpp @@ -3432,13 +3432,19 @@ void TDEHardwareDevices::updateExistingDeviceInformation(TDEGenericDevice* exist if (device->type() == TDEGenericDeviceType::Event) { // Try to obtain as much type information about this event device as possible TDEEventDevice* edevice = dynamic_cast(device); - if (edevice->systemPath().contains("PNP0C0D")) { + TDESwitchType::TDESwitchType edevice_switches = edevice->providedSwitches(); + if (edevice->systemPath().contains("PNP0C0D") + || (edevice_switches & TDESwitchType::Lid)) { edevice->internalSetEventType(TDEEventDeviceType::ACPILidSwitch); } - else if (edevice->systemPath().contains("PNP0C0E") || edevice->systemPath().contains("/LNXSLPBN")) { + else if (edevice->systemPath().contains("PNP0C0E") + || edevice->systemPath().contains("/LNXSLPBN") + || (edevice_switches & TDESwitchType::SleepButton)) { edevice->internalSetEventType(TDEEventDeviceType::ACPISleepButton); } - else if (edevice->systemPath().contains("PNP0C0C") || edevice->systemPath().contains("/LNXPWRBN")) { + else if (edevice->systemPath().contains("PNP0C0C") + || edevice->systemPath().contains("/LNXPWRBN") + || (edevice_switches & TDESwitchType::PowerButton)) { edevice->internalSetEventType(TDEEventDeviceType::ACPIPowerButton); } else if (edevice->systemPath().contains("_acpi")) {