X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=src%2Flib%2FLibCECC.cpp;h=4a7e0be9b8260f8d0a491929be7a9db930f18922;hb=99aeafb929fa132a096c236c4ae1eb78c2a595ec;hp=579d796ac6883e13e4e5dbcb70185e21ff060a54;hpb=2ffc8cddcb866da58a4a45923823ad9fb1c296eb;p=deb_libcec.git diff --git a/src/lib/LibCECC.cpp b/src/lib/LibCECC.cpp index 579d796..4a7e0be 100644 --- a/src/lib/LibCECC.cpp +++ b/src/lib/LibCECC.cpp @@ -1,7 +1,7 @@ /* * This file is part of the libCEC(R) library. * - * libCEC(R) is Copyright (C) 2011 Pulse-Eight Limited. All rights reserved. + * libCEC(R) is Copyright (C) 2011-2012 Pulse-Eight Limited. All rights reserved. * libCEC(R) is an original work, containing original code. * * libCEC(R) is a trademark of Pulse-Eight Limited. @@ -30,8 +30,8 @@ * http://www.pulse-eight.net/ */ -#include -#include +#include "../../include/cec.h" +#include "../../include/cecc.h" using namespace CEC; using namespace std; @@ -42,15 +42,15 @@ using namespace std; //@{ ICECAdapter *cec_parser; -int cec_init(const char *strDeviceName, cec_logical_address iLogicalAddress, uint16_t iPhysicalAddress) +int cec_initialise(libcec_configuration *configuration) { - cec_parser = (ICECAdapter *) CECCreate(strDeviceName, iLogicalAddress, iPhysicalAddress); + cec_parser = (ICECAdapter *) CECInitialise(configuration); return (cec_parser != NULL) ? 1 : 0; } -int cec_init_typed(const char *strDeviceName, cec_device_type_list devicesTypes) +int cec_init_typed(const char *strDeviceName, cec_device_type_list deviceTypes) { - cec_parser = (ICECAdapter *) CECInit(strDeviceName, devicesTypes); + cec_parser = (ICECAdapter *) CECInit(strDeviceName, deviceTypes); return (cec_parser != NULL) ? 1 : 0; } @@ -74,6 +74,13 @@ void cec_close(void) cec_parser->Close(); } +int cec_enable_callbacks(void *cbParam, ICECCallbacks *callbacks) +{ + if (cec_parser) + return cec_parser->EnableCallbacks(cbParam, callbacks) ? 1 : 0; + return -1; +} + int8_t cec_find_adapters(cec_adapter *deviceList, uint8_t iBufSize, const char *strDevicePath /* = NULL */) { if (cec_parser) @@ -364,4 +371,59 @@ int cec_enable_physical_address_detection(void) return cec_parser ? (cec_parser->EnablePhysicalAddressDetection() ? 1 : 0) : -1; } +int cec_set_stream_path_logical(CEC::cec_logical_address iAddress) +{ + return cec_parser ? (cec_parser->SetStreamPath(iAddress) ? 1 : 0) : -1; +} + +int cec_set_stream_path_physical(uint16_t iPhysicalAddress) +{ + return cec_parser ? (cec_parser->SetStreamPath(iPhysicalAddress) ? 1 : 0) : -1; +} + +cec_logical_addresses cec_get_logical_addresses(void) +{ + cec_logical_addresses addr; + addr.Clear(); + if (cec_parser) + addr = cec_parser->GetLogicalAddresses(); + return addr; +} + +int cec_get_current_configuration(libcec_configuration *configuration) +{ + return cec_parser ? (cec_parser->GetCurrentConfiguration(configuration) ? 1 : 0) : -1; +} + +int cec_can_persist_configuration(void) +{ + return cec_parser ? (cec_parser->CanPersistConfiguration() ? 1 : 0) : -1; +} + +int cec_persist_configuration(libcec_configuration *configuration) +{ + return cec_parser ? (cec_parser->PersistConfiguration(configuration) ? 1 : 0) : -1; +} + +int cec_set_configuration(libcec_configuration *configuration) +{ + return cec_parser ? (cec_parser->SetConfiguration(configuration) ? 1 : 0) : -1; +} + +void cec_rescan_devices(void) +{ + if (cec_parser) + cec_parser->RescanActiveDevices(); +} + +int cec_is_libcec_active_source(void) +{ + return cec_parser ? (cec_parser->IsLibCECActiveSource() ? 1 : 0) : -1; +} + +int cec_get_device_information(const char *strPort, CEC::libcec_configuration *config, uint32_t iTimeoutMs) +{ + return cec_parser ? (cec_parser->GetDeviceInformation(strPort, config, iTimeoutMs) ? 1 : 0) : -1; +} + //@}