X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=src%2Flib%2Fdevices%2FCECBusDevice.h;h=30d8329c5c8d711f8f4335b9d86f6019d9e9f9c8;hb=fe0cd8aa72091d860ad374abcbc0d8217f25ba69;hp=98e9431aa8adee0487feb120708cd03da0233f50;hpb=8fa354734e6dd2fd2e6fae68f7bbaf7ea84cbdfd;p=deb_libcec.git diff --git a/src/lib/devices/CECBusDevice.h b/src/lib/devices/CECBusDevice.h index 98e9431..30d8329 100644 --- a/src/lib/devices/CECBusDevice.h +++ b/src/lib/devices/CECBusDevice.h @@ -32,6 +32,7 @@ */ #include +#include #include "../platform/threads.h" #include "../util/StdString.h" @@ -39,10 +40,12 @@ namespace CEC { class CCECProcessor; class CCECCommandHandler; + class CSLCommandHandler; class CCECBusDevice { friend class CCECProcessor; + friend class CSLCommandHandler; public: CCECBusDevice(CCECProcessor *processor, cec_logical_address address, uint16_t iPhysicalAddress = 0); @@ -53,35 +56,31 @@ namespace CEC virtual bool PowerOn(void); virtual bool Standby(void); - virtual cec_version GetCecVersion(void); + virtual cec_version GetCecVersion(bool bUpdate = false); virtual CCECCommandHandler * GetHandler(void) const { return m_handler; }; - virtual uint64_t GetLastCommandSent(void) const; virtual uint64_t GetLastActive(void) const { return m_iLastActive; } virtual cec_logical_address GetLogicalAddress(void) const { return m_iLogicalAddress; } virtual const char* GetLogicalAddressName(void) const; - virtual cec_menu_language & GetMenuLanguage(void); + virtual cec_menu_language & GetMenuLanguage(bool bUpdate = false); virtual cec_logical_address GetMyLogicalAddress(void) const; virtual uint16_t GetMyPhysicalAddress(void) const; - virtual CStdString GetOSDName(void); - virtual uint16_t GetPhysicalAddress(bool bRefresh = true); - virtual cec_power_status GetPowerStatus(void); + virtual CStdString GetOSDName(bool bUpdate = false); + virtual uint16_t GetPhysicalAddress(bool bUpdate = false); + virtual cec_power_status GetPowerStatus(bool bUpdate = false); virtual CCECProcessor * GetProcessor(void) const { return m_processor; } virtual cec_device_type GetType(void) const { return m_type; } - virtual cec_vendor_id GetVendorId(void); - virtual const char * GetVendorName(void); + virtual cec_vendor_id GetVendorId(bool bUpdate = false); + virtual const char * GetVendorName(bool bUpdate = false); virtual bool MyLogicalAddressContains(cec_logical_address address) const; virtual cec_bus_device_status GetStatus(bool bForcePoll = false); + virtual bool IsActiveSource(void) const { return m_bActiveSource; } + virtual bool IsUnsupportedFeature(cec_opcode opcode) const; + virtual void SetUnsupportedFeature(cec_opcode opcode); - bool RequestCecVersion(void); - bool RequestMenuLanguage(void); - bool RequestPowerStatus(void); - bool RequestVendorId(void); - bool RequestPhysicalAddress(void); - bool RequestOSDName(void); - - virtual void SetInactiveDevice(void); - virtual void SetActiveDevice(void); + virtual void SetInactiveSource(void); + virtual void SetActiveSource(void); virtual bool TryLogicalAddress(void); + virtual bool InitHandler(void); virtual void SetDeviceStatus(const cec_bus_device_status newStatus); virtual void SetPhysicalAddress(uint16_t iNewAddress); @@ -102,11 +101,20 @@ namespace CEC virtual bool TransmitPhysicalAddress(void); virtual bool TransmitPowerState(cec_logical_address dest); virtual bool TransmitPoll(cec_logical_address dest); - virtual bool TransmitVendorID(cec_logical_address dest); - virtual bool SendKeypress(cec_user_control_code key); - virtual bool SendKeyRelease(void); + virtual bool TransmitVendorID(cec_logical_address dest, bool bSendAbort = true); + virtual bool TransmitKeypress(cec_user_control_code key, bool bWait = true); + virtual bool TransmitKeyRelease(bool bWait = true); protected: + bool ReplaceHandler(bool bInitHandler = true); + + bool RequestCecVersion(void); + bool RequestMenuLanguage(void); + bool RequestPowerStatus(void); + bool RequestVendorId(void); + bool RequestPhysicalAddress(void); + bool RequestOSDName(void); + bool NeedsPoll(void); cec_device_type m_type; @@ -119,13 +127,14 @@ namespace CEC CCECProcessor * m_processor; CCECCommandHandler * m_handler; cec_vendor_id m_vendor; + bool m_bReplaceHandler; cec_menu_state m_menuState; bool m_bActiveSource; - uint64_t m_iLastCommandSent; uint64_t m_iLastActive; cec_version m_cecVersion; cec_bus_device_status m_deviceStatus; - CMutex m_writeMutex; + std::set m_unsupportedFeatures; CMutex m_mutex; + CMutex m_handlerMutex; }; };