X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=src%2Flib%2FCECProcessor.h;h=a9c1065b918dd8a9d357998d5ccdec23fa9f3bed;hb=2e8207ce0d15b3c25d97eba8740f3ca80364d03c;hp=8569949cbf0b3805863421c05f3a45d234568260;hpb=1f0e9e0fb3ddfaf84650867e55e645cda7868e06;p=deb_libcec.git diff --git a/src/lib/CECProcessor.h b/src/lib/CECProcessor.h index 8569949..a9c1065 100644 --- a/src/lib/CECProcessor.h +++ b/src/lib/CECProcessor.h @@ -50,6 +50,7 @@ namespace CEC { public: CCECProcessor(CLibCEC *controller, CAdapterCommunication *serComm, const char *strDeviceName, cec_logical_address iLogicalAddress = CECDEVICE_PLAYBACKDEVICE1, uint16_t iPhysicalAddress = CEC_DEFAULT_PHYSICAL_ADDRESS); + CCECProcessor(CLibCEC *controller, CAdapterCommunication *serComm, const char *strDeviceName, const cec_device_type_list &types); virtual ~CCECProcessor(void); virtual bool Start(void); @@ -60,39 +61,53 @@ namespace CEC virtual const std::string & GetDeviceName(void) { return m_strDeviceName; } virtual uint64_t GetDeviceVendorId(cec_logical_address iAddress); virtual cec_power_status GetDevicePowerStatus(cec_logical_address iAddress); - virtual cec_logical_address GetLogicalAddress(void) const { return m_iLogicalAddress; } + virtual cec_logical_address GetLogicalAddress(void) const { return m_logicalAddresses.primary; } + virtual bool HasLogicalAddress(cec_logical_address address) const { return m_logicalAddresses.isset(address); } virtual uint16_t GetPhysicalAddress(void) const; virtual bool SetActiveView(void); virtual bool SetInactiveView(void); - virtual bool SetLogicalAddress(cec_logical_address iLogicalAddress = CECDEVICE_UNKNOWN); + virtual bool SetLogicalAddress(cec_logical_address iLogicalAddress); virtual bool SetPhysicalAddress(uint16_t iPhysicalAddress); virtual bool SwitchMonitoring(bool bEnable); + virtual bool PollDevice(cec_logical_address iAddress); - virtual bool Transmit(const cec_command &data); + virtual bool Transmit(const cec_command &data); + virtual bool Transmit(CCECAdapterMessage *output); virtual void TransmitAbort(cec_logical_address address, cec_opcode opcode, ECecAbortReason reason = CEC_ABORT_REASON_UNRECOGNIZED_OPCODE); virtual void SetCurrentButton(cec_user_control_code iButtonCode); virtual void AddCommand(const cec_command &command); + virtual void AddKey(cec_keypress &key); virtual void AddKey(void); virtual void AddLog(cec_log_level level, const CStdString &strMessage); + virtual bool FindLogicalAddresses(void); + CCECBusDevice *m_busDevices[16]; private: + bool TryLogicalAddress(cec_logical_address address, const char *strLabel); + bool FindLogicalAddressRecordingDevice(void); + bool FindLogicalAddressTuner(void); + bool FindLogicalAddressPlaybackDevice(void); + bool FindLogicalAddressAudioSystem(void); + + bool SetAckMask(uint16_t iMask); void LogOutput(const cec_command &data); bool WaitForTransmitSucceeded(uint8_t iLength, uint32_t iTimeout = 1000); bool ParseMessage(const CCECAdapterMessage &msg); void ParseCommand(cec_command &command); + bool m_bStarted; cec_command m_currentframe; - cec_logical_address m_iLogicalAddress; + cec_logical_addresses m_logicalAddresses; std::string m_strDeviceName; + cec_device_type_list m_types; CMutex m_mutex; CCondition m_startCondition; - CAdapterCommunication *m_communication; - CLibCEC *m_controller; + CAdapterCommunication* m_communication; + CLibCEC* m_controller; bool m_bMonitor; - bool m_bLogicalAddressSet; }; };