*/
virtual void Close(void) = 0;
- /*!
- * @brief Set and enable the callback methods. If this method is not called, the GetNext...() methods will have to be used.
- * @param cbParam Parameter to pass to callback methods.
- * @param callbacks The callbacks to set.
- * @return True when enabled, false otherwise.
- */
- virtual bool EnableCallbacks(void *cbParam, ICECCallbacks *callbacks) = 0;
-
/*!
* @brief Try to find all connected CEC adapters. Only implemented on Linux and Windows at the moment.
* @param deviceList The vector to store device descriptors in.
*/
virtual bool SetPhysicalAddress(uint16_t iPhysicalAddress = CEC_DEFAULT_PHYSICAL_ADDRESS) = 0;
- /*!
- * @deprecated Use libcec_configuration instead.
- * @brief Enable physical address detection (if the connected adapter supports this).
- * @return True when physical address detection was enabled, false otherwise.
- */
- virtual bool EnablePhysicalAddressDetection(void) = 0;
-
- /*!
- * @brief Changes the active HDMI port.
- * @param iBaseDevice The device to which this libcec is connected.
- * @param iPort The new port number.
- * @return True when changed, false otherwise.
- */
- virtual bool SetHDMIPort(cec_logical_address iBaseDevice, uint8_t iPort) = 0;
-
/*!
* @brief Power on the connected CEC capable devices.
* @param address The logical address to power on.
*/
virtual cec_power_status GetDevicePowerStatus(cec_logical_address iLogicalAddress) = 0;
- /*!
- * @brief Get the physical address of the device with the given logical address.
- * @param iLogicalAddress The device to get the vendor id for.
- * @return The physical address or 0 if it wasn't found.
- */
- virtual uint16_t GetDevicePhysicalAddress(cec_logical_address iLogicalAddress) = 0;
-
/*!
* @brief Sends a POLL message to a device.
* @param iLogicalAddress The device to send the message to.
* @return True when the device was found, false otherwise
*/
virtual bool GetDeviceInformation(const char *strPort, libcec_configuration *config, uint32_t iTimeoutMs = 10000) = 0;
+
+ /*!
+ * @brief Set and enable the callback methods. If this method is not called, the GetNext...() methods will have to be used.
+ * @param cbParam Parameter to pass to callback methods.
+ * @param callbacks The callbacks to set.
+ * @return True when enabled, false otherwise.
+ */
+ virtual bool EnableCallbacks(void *cbParam, ICECCallbacks *callbacks) = 0;
+
+ /*!
+ * @deprecated Use libcec_configuration instead.
+ * @brief Enable physical address detection (if the connected adapter supports this).
+ * @return True when physical address detection was enabled, false otherwise.
+ */
+ virtual bool EnablePhysicalAddressDetection(void) = 0;
+
+ /*!
+ * @brief Changes the active HDMI port.
+ * @param iBaseDevice The device to which this libcec is connected.
+ * @param iPort The new port number.
+ * @return True when changed, false otherwise.
+ */
+ virtual bool SetHDMIPort(cec_logical_address iBaseDevice, uint8_t iPort) = 0;
+
+ /*!
+ * @brief Get the physical address of the device with the given logical address.
+ * @param iLogicalAddress The device to get the vendor id for.
+ * @return The physical address or 0 if it wasn't found.
+ */
+ virtual uint16_t GetDevicePhysicalAddress(cec_logical_address iLogicalAddress) = 0;
};
};
* @brief Load the CEC adapter library.
* @param strDeviceName How to present this device to other devices.
* @param deviceTypes The device types to use on the CEC bus.
- * @param iPhysicalAddress The physical address to assume on the bus. If set to 0, libCEC will try to autodetect the address, with the data provided via SetHDMIPort()
* @return An instance of ICECAdapter or NULL on error.
*/
-extern "C" DECLSPEC void * CECInit(const char *strDeviceName, CEC::cec_device_type_list deviceTypes, uint16_t iPhysicalAddress = 0);
+extern "C" DECLSPEC void * CECInit(const char *strDeviceName, CEC::cec_device_type_list deviceTypes);
+
+/*!
+ * @deprecated
+ */
+extern "C" DECLSPEC void * CECCreate(const char *strDeviceName, CEC::cec_logical_address iLogicalAddress = CEC::CECDEVICE_PLAYBACKDEVICE1, uint16_t iPhysicalAddress = CEC_DEFAULT_PHYSICAL_ADDRESS);
+
+/*!
+ * @brief Unload the CEC adapter library.
+ */
+extern "C" DECLSPEC void CECDestroy(CEC::ICECAdapter *instance);
/*!
* @brief Load the CEC adapter library.
*/
extern "C" DECLSPEC bool CECStartBootloader(void);
-/*!
- * @brief Unload the CEC adapter library.
- */
-extern "C" DECLSPEC void CECDestroy(CEC::ICECAdapter *instance);
-
#endif /* CECEXPORTS_H_ */
int32_t transmit_timeout; /**< the timeout to use in ms */
#ifdef __cplusplus
- cec_command(void)
- {
- Clear();
- }
+ // @todo re-add in v2.0 (breaks ABI)
+ //cec_command(void)
+ //{
+ // Clear();
+ //}
cec_command &operator =(const struct cec_command &command)
{
CBCecSourceActivatedType CBCecSourceActivated;
#ifdef __cplusplus
- ICECCallbacks(void) { Clear(); }
- ~ICECCallbacks(void) { Clear(); };
+ // @todo re-add in v2.0 (breaks ABI)
+ // ICECCallbacks(void) { Clear(); }
+ //~ICECCallbacks(void) { Clear(); };
void Clear(void)
{
uint8_t bMonitorOnly; /*!< won't allocate a CCECClient when starting the connection when set (same as monitor mode). added in 1.6.3 */
#ifdef __cplusplus
- libcec_configuration(void) { Clear(); }
- ~libcec_configuration(void) { Clear(); }
+ // @todo re-add in v2.0 (breaks ABI)
+ // libcec_configuration(void) { Clear(); }
+ //~libcec_configuration(void) { Clear(); }
bool operator==(const libcec_configuration &other) const
{
return static_cast< void* > (lib);
}
-void * CECInit(const char *strDeviceName, CEC::cec_device_type_list types, uint16_t UNUSED(iPhysicalAddress) /* = 0 */)
+void * CECInit(const char *strDeviceName, CEC::cec_device_type_list types)
{
- libcec_configuration configuration;
+ libcec_configuration configuration; configuration.Clear();
// client version < 1.5.0
snprintf(configuration.strDeviceName, 13, "%s", strDeviceName);
return CECInitialise(&configuration);
}
+void * CECCreate(const char *strDeviceName, CEC::cec_logical_address iLogicalAddress /* = CEC::CECDEVICE_PLAYBACKDEVICE1 */, uint16_t iPhysicalAddress /* = CEC_DEFAULT_PHYSICAL_ADDRESS */)
+{
+ libcec_configuration configuration; configuration.Clear();
+
+ // client version < 1.5.0
+ snprintf(configuration.strDeviceName, 13, "%s", strDeviceName);
+ configuration.iPhysicalAddress = iPhysicalAddress;
+ configuration.deviceTypes.Add(CEC_DEVICE_TYPE_RECORDING_DEVICE);
+
+ return CECInitialise(&configuration);
+}
+
bool CECStartBootloader(void)
{
bool bReturn(false);