X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=src%2Flib%2FLibCECC.cpp;h=4a7e0be9b8260f8d0a491929be7a9db930f18922;hb=5daed059e1d5bca3ddfa0787679ef4e7b349e382;hp=91ab395eca5fa61e30657bbede26abb8c4d2757e;hpb=547b390d1c90e922b7c2191393ba12ec388750ca;p=deb_libcec.git diff --git a/src/lib/LibCECC.cpp b/src/lib/LibCECC.cpp index 91ab395..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; } @@ -371,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; +} + //@}