X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=src%2Flib%2FCECProcessor.h;h=0d2446acd065fa57a0b69cfbc6ab1a1cc83c7207;hb=e9654a0e343790159462527352a50f584590d062;hp=133a70b1b00ac12cbca3443aab17a73d5818d70a;hpb=7bb4ed43f15a0fa2be17d2c3f580b181ac7430a7;p=deb_libcec.git diff --git a/src/lib/CECProcessor.h b/src/lib/CECProcessor.h index 133a70b..0d2446a 100644 --- a/src/lib/CECProcessor.h +++ b/src/lib/CECProcessor.h @@ -35,14 +35,15 @@ #include #include "platform/threads/threads.h" #include "platform/util/buffer.h" +#include "adapter/AdapterCommunication.h" namespace CEC { class CLibCEC; - class IAdapterCommunication; + struct IAdapterCommunication; class CCECBusDevice; - class CCECProcessor : public PLATFORM::CThread + class CCECProcessor : public PLATFORM::CThread, public IAdapterCommunicationCallback { public: CCECProcessor(CLibCEC *controller, const char *strDeviceName, cec_logical_address iLogicalAddress = CECDEVICE_PLAYBACKDEVICE1, uint16_t iPhysicalAddress = CEC_DEFAULT_PHYSICAL_ADDRESS); @@ -52,6 +53,8 @@ namespace CEC virtual bool Start(const char *strPort, uint16_t iBaudRate = 38400, uint32_t iTimeoutMs = 10000); virtual void *Process(void); + virtual bool OnCommandReceived(const cec_command &command); + virtual bool IsMonitoring(void) const { return m_bMonitor; } virtual CCECBusDevice * GetDeviceByPhysicalAddress(uint16_t iPhysicalAddress, bool bRefresh = false) const; virtual CCECBusDevice * GetDeviceByType(cec_device_type type) const; @@ -71,10 +74,9 @@ namespace CEC virtual bool IsPresentDeviceType(cec_device_type type); virtual uint16_t GetPhysicalAddress(void) const; virtual uint64_t GetLastTransmission(void) const { return m_iLastTransmission; } - virtual bool IsStarted(void) const { return m_bStarted; } virtual cec_logical_address GetActiveSource(void); virtual bool IsActiveSource(cec_logical_address iAddress); - virtual bool IsInitialised(void) const { return m_bInitialised; } + virtual bool IsInitialised(void); virtual bool SetActiveView(void); virtual bool SetActiveSource(cec_device_type type = CEC_DEVICE_TYPE_RESERVED); @@ -141,9 +143,8 @@ namespace CEC bool FindLogicalAddressAudioSystem(void); void LogOutput(const cec_command &data); - void ParseCommand(cec_command &command); + void ParseCommand(const cec_command &command); - bool m_bStarted; bool m_bInitialised; uint8_t m_iHDMIPort; cec_logical_address m_iBaseDevice; @@ -151,7 +152,6 @@ namespace CEC std::string m_strDeviceName; cec_device_type_list m_types; PLATFORM::CMutex m_mutex; - PLATFORM::CCondition m_startCondition; IAdapterCommunication * m_communication; CLibCEC* m_controller; bool m_bMonitor;