X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=src%2Flib%2FCECProcessor.h;h=4e9d1115c475aba934769702b5dc650ce63db0b1;hb=e36035adeeab088655508cf6c2aa492e8eea7cc3;hp=5c8d8ab2651340e8a0a752027e44c2f221b61e60;hpb=25701fa60407a0fc0bc1dfcd4049fc01ad9e4fd1;p=deb_libcec.git diff --git a/src/lib/CECProcessor.h b/src/lib/CECProcessor.h index 5c8d8ab..4e9d111 100644 --- a/src/lib/CECProcessor.h +++ b/src/lib/CECProcessor.h @@ -32,8 +32,7 @@ */ #include -#include "../../include/CECExports.h" -#include "../../include/CECTypes.h" +#include #include "platform/threads.h" #include "util/buffer.h" @@ -57,10 +56,16 @@ namespace CEC virtual bool StandbyDevices(cec_logical_address address = CECDEVICE_BROADCAST); virtual bool SetActiveView(void); virtual bool SetInactiveView(void); - virtual bool Transmit(const cec_frame &data, bool bWaitForAck = true); + virtual bool Transmit(const cec_command &data, bool bWaitForAck = true); virtual bool SetLogicalAddress(cec_logical_address iLogicalAddress); + virtual bool SetPhysicalAddress(uint16_t iPhysicalAddress); + virtual bool SetOSDString(cec_logical_address iLogicalAddress, cec_display_control duration, const char *strMessage); + virtual bool SwitchMonitoring(bool bEnable); + + static const char *CECVendorIdToString(const uint64_t iVendorId); + protected: - virtual bool TransmitFormatted(const cec_frame &data, bool bWaitForAck = true); + virtual bool TransmitFormatted(const cec_adapter_message &data, bool bWaitForAck = true); 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); @@ -69,20 +74,27 @@ namespace CEC virtual void ReportOSDName(cec_logical_address address = CECDEVICE_TV); virtual void ReportPhysicalAddress(void); virtual void BroadcastActiveSource(void); - virtual uint8_t GetSourceDestination(cec_logical_address destination = CECDEVICE_BROADCAST) const; + virtual bool HandleANCommand(cec_command &command); + virtual bool HandleSLCommand(cec_command &command); + virtual bool HandleCecCommand(cec_command &command); private: - bool WaitForAck(uint32_t iTimeout = 1000); - bool ParseMessage(cec_frame &msg); - void ParseCurrentFrame(void); + void LogOutput(const cec_command &data); + bool WaitForAck(bool *bError, uint32_t iTimeout = 1000); + void ParseMessage(cec_adapter_message &msg, bool *bError, bool *bTransmitSucceeded, bool *bEom, bool bProcessMessages = true); + void ParseCommand(cec_command &command); + void ParseVendorId(cec_logical_address device, const cec_datapacket &data); - cec_frame 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; + cec_command m_currentframe; + uint16_t m_iPhysicalAddress; + 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_bMonitor; }; };