X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=src%2Flib%2Fdevices%2FCECDeviceMap.cpp;h=3c70603a541092ce56eadde795b899fbf3d84e75;hb=6b567d1fa9db2009bbeaf6d355bdd0438a4eeca0;hp=2603e33d2de82fb22b37a71bcb880fc2f8754da9;hpb=004b83822a351e1fb6e982a9183a12a430b0b769;p=deb_libcec.git diff --git a/src/lib/devices/CECDeviceMap.cpp b/src/lib/devices/CECDeviceMap.cpp index 2603e33..3c70603 100644 --- a/src/lib/devices/CECDeviceMap.cpp +++ b/src/lib/devices/CECDeviceMap.cpp @@ -36,7 +36,7 @@ #include "CECRecordingDevice.h" #include "CECTuner.h" #include "CECTV.h" -#include "CECProcessor.h" +#include "../CECProcessor.h" using namespace std; using namespace CEC; @@ -185,7 +185,7 @@ void CCECDeviceMap::GetPowerOffDevices(const libcec_configuration &configuration { for (CECDEVICEMAP::const_iterator it = m_busDevices.begin(); it != m_busDevices.end(); it++) { - if (configuration.powerOffDevices[it->first]) + if (configuration.powerOffDevices[(uint8_t)it->first]) devices.push_back(it->second); } } @@ -194,7 +194,7 @@ void CCECDeviceMap::GetWakeDevices(const libcec_configuration &configuration, CE { for (CECDEVICEMAP::const_iterator it = m_busDevices.begin(); it != m_busDevices.end(); it++) { - if (configuration.wakeDevices[it->first]) + if (configuration.wakeDevices[(uint8_t)it->first]) devices.push_back(it->second); } } @@ -235,10 +235,11 @@ void CCECDeviceMap::FilterActive(CECDEVICEVEC &devices) void CCECDeviceMap::FilterTypes(const cec_device_type_list &types, CECDEVICEVEC &devices) { + cec_device_type_list t(types);//silly, but needed to retain abi CECDEVICEVEC newDevices; for (CECDEVICEVEC::const_iterator it = devices.begin(); it != devices.end(); it++) { - if (types.IsSet((*it)->GetType())) + if (t.IsSet((*it)->GetType())) newDevices.push_back(*it); } devices = newDevices; @@ -258,6 +259,7 @@ void CCECDeviceMap::FilterType(const cec_device_type type, CECDEVICEVEC &devices cec_logical_addresses CCECDeviceMap::ToLogicalAddresses(const CECDEVICEVEC &devices) { cec_logical_addresses addresses; + addresses.Clear(); for (CECDEVICEVEC::const_iterator it = devices.begin(); it != devices.end(); it++) addresses.Set((*it)->GetLogicalAddress()); return addresses;