X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=src%2Flib%2Fdevices%2FCECBusDevice.h;h=80576b4b003b81a8c416653d0ff47e20d5fda89d;hb=f4b7b1dc99d0741aa5cbba94a60775ddf1552422;hp=d7f4e27460b4b2f1cc8e4c14e1f386bafef49c1b;hpb=f8ae32954754d261552c2c11a6a9055f02d61bba;p=deb_libcec.git diff --git a/src/lib/devices/CECBusDevice.h b/src/lib/devices/CECBusDevice.h index d7f4e27..80576b4 100644 --- a/src/lib/devices/CECBusDevice.h +++ b/src/lib/devices/CECBusDevice.h @@ -39,10 +39,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); @@ -50,52 +52,64 @@ namespace CEC virtual void AddLog(cec_log_level level, const CStdString &strMessage); virtual bool HandleCommand(const cec_command &command); - virtual void PollVendorId(void); 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 GetCommandSent(void) const { return m_iLastCommandSent; } 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 uint16_t GetPhysicalAddress(void) const { return m_iPhysicalAddress; } - 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(void); + virtual cec_bus_device_status GetStatus(bool bForcePoll = false); virtual void SetInactiveDevice(void); virtual void SetActiveDevice(void); + virtual bool TryLogicalAddress(void); + virtual void SetDeviceStatus(const cec_bus_device_status newStatus); virtual void SetPhysicalAddress(uint16_t iNewAddress); virtual void SetStreamPath(uint16_t iNewAddress, uint16_t iOldAddress = 0); virtual void SetCecVersion(const cec_version newVersion); virtual void SetMenuLanguage(const cec_menu_language &menuLanguage); virtual void SetOSDName(CStdString strName); virtual void SetMenuState(const cec_menu_state state); - virtual void SetVendorId(uint64_t iVendorId); + virtual bool SetVendorId(uint64_t iVendorId, bool bInitHandler = true); virtual void SetPowerStatus(const cec_power_status powerStatus); virtual bool TransmitActiveSource(void); virtual bool TransmitCECVersion(cec_logical_address dest); - virtual bool TransmitInactiveView(void); + virtual bool TransmitInactiveSource(void); virtual bool TransmitMenuState(cec_logical_address dest); virtual bool TransmitOSDName(cec_logical_address dest); virtual bool TransmitOSDString(cec_logical_address dest, cec_display_control duration, const char *strMessage); 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 TransmitVendorID(cec_logical_address dest, bool bSendAbort = true); + virtual bool TransmitKeypress(cec_user_control_code key); + virtual bool TransmitKeyRelease(void); protected: + 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; CStdString m_strDeviceName; uint16_t m_iPhysicalAddress; @@ -108,12 +122,10 @@ namespace CEC cec_vendor_id m_vendor; 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_transmitMutex; + CMutex m_writeMutex; CMutex m_mutex; - CCondition m_condition; }; };