X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=src%2Flib%2FCECProcessor.h;h=a9c1065b918dd8a9d357998d5ccdec23fa9f3bed;hb=2e8207ce0d15b3c25d97eba8740f3ca80364d03c;hp=2bebc5c05a27d4b5e245082aa6be0ee3c35ca1a2;hpb=ee7a58ce82eb01a99ce2aae5b0e534bfb1c97a43;p=deb_libcec.git diff --git a/src/lib/CECProcessor.h b/src/lib/CECProcessor.h index 2bebc5c..a9c1065 100644 --- a/src/lib/CECProcessor.h +++ b/src/lib/CECProcessor.h @@ -32,10 +32,11 @@ */ #include -#include "../../include/CECExports.h" -#include "../../include/CECTypes.h" +#include +#include "AdapterCommunication.h" #include "platform/threads.h" #include "util/buffer.h" +#include "util/StdString.h" class CSerialPort; @@ -43,49 +44,70 @@ namespace CEC { class CLibCEC; class CAdapterCommunication; + class CCECBusDevice; class CCECProcessor : public CThread { 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); - void *Process(void); + virtual void *Process(void); + + virtual cec_version GetDeviceCecVersion(cec_logical_address iAddress); + virtual bool GetDeviceMenuLanguage(cec_logical_address iAddress, cec_menu_language *language); + 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_logicalAddresses.primary; } + virtual bool HasLogicalAddress(cec_logical_address address) const { return m_logicalAddresses.isset(address); } + virtual uint16_t GetPhysicalAddress(void) const; - virtual bool PowerOnDevices(cec_logical_address address = CECDEVICE_TV); - virtual bool StandbyDevices(cec_logical_address address = CECDEVICE_BROADCAST); virtual bool SetActiveView(void); virtual bool SetInactiveView(void); - virtual bool Transmit(const cec_command &data, bool bWaitForAck = true); virtual bool SetLogicalAddress(cec_logical_address iLogicalAddress); - protected: - virtual bool TransmitFormatted(const cec_adapter_message &data, bool bWaitForAck = true); + 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(CCECAdapterMessage *output); virtual void TransmitAbort(cec_logical_address address, cec_opcode opcode, ECecAbortReason reason = CEC_ABORT_REASON_UNRECOGNIZED_OPCODE); - virtual void ReportCECVersion(cec_logical_address address = CECDEVICE_TV); - virtual void ReportPowerState(cec_logical_address address = CECDEVICE_TV, bool bOn = true); - virtual void ReportMenuState(cec_logical_address address = CECDEVICE_TV, bool bActive = true); - virtual void ReportVendorID(cec_logical_address address = CECDEVICE_TV); - virtual void ReportOSDName(cec_logical_address address = CECDEVICE_TV); - virtual void ReportPhysicalAddress(void); - virtual void BroadcastActiveSource(void); - private: + 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 WaitForAck(bool *bError, uint32_t iTimeout = 1000); - bool ParseMessage(cec_adapter_message &msg); + bool WaitForTransmitSucceeded(uint8_t iLength, uint32_t iTimeout = 1000); + bool ParseMessage(const CCECAdapterMessage &msg); void ParseCommand(cec_command &command); - void ParseVendorId(cec_logical_address device, const cec_datapacket &data); - cec_command m_currentframe; - uint16_t m_physicaladdress; - cec_logical_address m_iLogicalAddress; - CecBuffer m_frameBuffer; - std::string m_strDeviceName; - CMutex m_mutex; - CAdapterCommunication *m_communication; - CLibCEC *m_controller; - uint64_t m_vendorIds[16]; - uint8_t m_vendorClasses[16]; + bool m_bStarted; + cec_command m_currentframe; + 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; + bool m_bMonitor; }; };