/* * This file was generated by the CommonAPI Generators. * Used org.genivi.commonapi.core 3.1.2.v201506150834. * Used org.franca.core 0.9.1.201412191134. * * This Source Code Form is subject to the terms of the Mozilla Public License, v. 2.0. * If a copy of the MPL was not distributed with this file, You can obtain one at * http://mozilla.org/MPL/2.0/. */ #ifndef COMMONAPI_TESTS_Extended_Interface_PROXY_HPP_ #define COMMONAPI_TESTS_Extended_Interface_PROXY_HPP_ #include #include "v1_0/commonapi/tests/TestInterfaceProxy.hpp" #if !defined (COMMONAPI_INTERNAL_COMPILATION) #define COMMONAPI_INTERNAL_COMPILATION #endif #undef COMMONAPI_INTERNAL_COMPILATION namespace v1_0 { namespace commonapi { namespace tests { template class ExtendedInterfaceProxy : virtual public ExtendedInterface, virtual public ExtendedInterfaceProxyBase, virtual public TestInterfaceProxy<_AttributeExtensions...>, public _AttributeExtensions... { public: ExtendedInterfaceProxy(std::shared_ptr delegate); ~ExtendedInterfaceProxy(); typedef ExtendedInterface InterfaceType; inline static const char* getInterface() { return(ExtendedInterface::getInterface()); } /** * Calls TestIntMethodExtended with synchronous semantics. * * All const parameters are input parameters to this method. * The CallStatus will be filled when the method returns and indicate either * "SUCCESS" or which type of error has occurred. In case of an error, ONLY the CallStatus * will be set. */ virtual void TestIntMethodExtended(const uint32_t &_inInt, CommonAPI::CallStatus &_status, const CommonAPI::CallInfo *_info = nullptr); /** * Calls TestIntMethodExtended with asynchronous semantics. * * The provided callback will be called when the reply to this call arrives or * an error occurs during the call. The CallStatus will indicate either "SUCCESS" * or which type of error has occurred. In case of any error, ONLY the CallStatus * will have a defined value. * The std::future returned by this method will be fulfilled at arrival of the reply. * It will provide the same value for CallStatus as will be handed to the callback. */ virtual std::future TestIntMethodExtendedAsync(const uint32_t &_inInt, TestIntMethodExtendedAsyncCallback _callback, const CommonAPI::CallInfo *_info = nullptr); /** * Returns the CommonAPI address of the remote partner this proxy communicates with. */ virtual const CommonAPI::Address &getAddress() const; /** * Returns true if the remote partner for this proxy is currently known to be available. */ virtual bool isAvailable() const; /** * Returns true if the remote partner for this proxy is available. */ virtual bool isAvailableBlocking() const; /** * Returns the wrapper class that is used to (de-)register for notifications about * the availability of the remote partner of this proxy. */ virtual CommonAPI::ProxyStatusEvent& getProxyStatusEvent(); /** * Returns the wrapper class that is used to access version information of the remote * partner of this proxy. */ virtual CommonAPI::InterfaceVersionAttribute& getInterfaceVersionAttribute(); private: std::shared_ptr delegate_; }; typedef ExtendedInterfaceProxy<> ExtendedInterfaceProxyDefault; // // ExtendedInterfaceProxy Implementation // template ExtendedInterfaceProxy<_AttributeExtensions...>::ExtendedInterfaceProxy(std::shared_ptr delegate): TestInterfaceProxy<_AttributeExtensions...>(delegate), _AttributeExtensions(*(std::dynamic_pointer_cast(delegate)))..., delegate_(std::dynamic_pointer_cast(delegate)) { } template ExtendedInterfaceProxy<_AttributeExtensions...>::~ExtendedInterfaceProxy() { } template void ExtendedInterfaceProxy<_AttributeExtensions...>::TestIntMethodExtended(const uint32_t &_inInt, CommonAPI::CallStatus &_status, const CommonAPI::CallInfo *_info) { delegate_->TestIntMethodExtended(_inInt, _status, _info); } template std::future ExtendedInterfaceProxy<_AttributeExtensions...>::TestIntMethodExtendedAsync(const uint32_t &_inInt, TestIntMethodExtendedAsyncCallback _callback, const CommonAPI::CallInfo *_info) { return delegate_->TestIntMethodExtendedAsync(_inInt, _callback, _info); } template const CommonAPI::Address &ExtendedInterfaceProxy<_AttributeExtensions...>::getAddress() const { return delegate_->getAddress(); } template bool ExtendedInterfaceProxy<_AttributeExtensions...>::isAvailable() const { return delegate_->isAvailable(); } template bool ExtendedInterfaceProxy<_AttributeExtensions...>::isAvailableBlocking() const { return delegate_->isAvailableBlocking(); } template CommonAPI::ProxyStatusEvent& ExtendedInterfaceProxy<_AttributeExtensions...>::getProxyStatusEvent() { return delegate_->getProxyStatusEvent(); } template CommonAPI::InterfaceVersionAttribute& ExtendedInterfaceProxy<_AttributeExtensions...>::getInterfaceVersionAttribute() { return delegate_->getInterfaceVersionAttribute(); } } // namespace tests } // namespace commonapi } // namespace v1_0 #endif // COMMONAPI_TESTS_Extended_Interface_PROXY_HPP_