io.joynr.generator.cpp.proxy.InterfaceProxyHTemplate.xtend Maven / Gradle / Ivy
package io.joynr.generator.cpp.proxy
/*
* !!!
*
* Copyright (C) 2011 - 2015 BMW Car IT GmbH
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import com.google.inject.Inject
import io.joynr.generator.cpp.util.CppStdTypeUtil
import io.joynr.generator.cpp.util.JoynrCppGeneratorExtensions
import io.joynr.generator.cpp.util.TemplateBase
import io.joynr.generator.util.InterfaceTemplate
import org.franca.core.franca.FInterface
class InterfaceProxyHTemplate implements InterfaceTemplate{
@Inject extension JoynrCppGeneratorExtensions
@Inject extension TemplateBase
@Inject extension CppStdTypeUtil
override generate(FInterface serviceInterface)
'''
«val interfaceName = serviceInterface.joynrName»
«val className = interfaceName + "Proxy"»
«val asyncClassName = interfaceName + "AsyncProxy"»
«val syncClassName = interfaceName + "SyncProxy"»
«val headerGuard = ("GENERATED_INTERFACE_"+getPackagePathWithJoynrPrefix(serviceInterface, "_")+
"_"+interfaceName+"Proxy_h").toUpperCase»
«warning()»
#ifndef «headerGuard»
#define «headerGuard»
#include "joynr/PrivateCopyAssign.h"
«FOR parameterType: getRequiredIncludesFor(serviceInterface).addElements(includeForString)»
#include «parameterType»
«ENDFOR»
#include
«getDllExportIncludeStatement()»
#include "«getPackagePathWithJoynrPrefix(serviceInterface, "/")»/«syncClassName».h"
#include "«getPackagePathWithJoynrPrefix(serviceInterface, "/")»/«asyncClassName».h"
#include "«getPackagePathWithJoynrPrefix(serviceInterface, "/")»/I«interfaceName».h"
#ifdef _MSC_VER
// Visual C++ gives a warning which is caused by diamond inheritance, but this is
// not relevant when using pure virtual methods:
// http://msdn.microsoft.com/en-us/library/6b3sy7ae(v=vs.80).aspx
#pragma warning( disable : 4250 )
#endif
«getNamespaceStarter(serviceInterface)»
/** @brief Proxy class for interface «interfaceName» */
class «getDllExportMacro()» «className» : virtual public I«interfaceName», virtual public «syncClassName», virtual public «asyncClassName» {
public:
/**
* @brief Parameterized constructor
* @param messagingAddress The address
* @param connectorFactory The connector factory
* @param cache The client cache
* @param domain The provider domain
* @param qosSettings The quality of service settings
* @param cached True, if cached, false otherwise
*/
«className»(
QSharedPointer messagingAddress,
joynr::ConnectorFactory* connectorFactory,
joynr::IClientCache* cache,
const std::string& domain,
const joynr::MessagingQos& qosSettings,
bool cached
);
«FOR attribute: getAttributes(serviceInterface).filter[attribute | attribute.notifiable]»
«var attributeName = attribute.joynrName»
«val returnType = attribute.typeName»
/**
* @brief unsubscribes from attribute «attributeName.toFirstUpper»
* @param subscriptionId The subscription id returned earlier on creation of the subscription
*/
void unsubscribeFrom«attributeName.toFirstUpper»(std::string &subscriptionId) {
«className»Base::unsubscribeFrom«attributeName.toFirstUpper»(subscriptionId);
}
/**
* @brief creates a new subscription to attribute «attributeName.toFirstUpper»
* @param subscriptionListener The listener callback providing methods to call on publication and failure
* @param subscriptionQos The subscription quality of service settings
* @return the subscription id as string
*/
std::string subscribeTo«attributeName.toFirstUpper»(
std::shared_ptr > subscriptionListener,
const joynr::SubscriptionQos& subscriptionQos){
return «className»Base::subscribeTo«attributeName.toFirstUpper»(
subscriptionListener,
subscriptionQos);
}
/**
* @brief updates an existing subscription to attribute «attributeName.toFirstUpper»
* @param subscriptionListener The listener callback providing methods to call on publication and failure
* @param subscriptionQos The subscription quality of service settings
* @param subscriptionId The subscription id returned earlier on creation of the subscription
* @return the subscription id as string
*/
std::string subscribeTo«attributeName.toFirstUpper»(
std::shared_ptr > subscriptionListener,
const joynr::SubscriptionQos& subscriptionQos,
std::string& subscriptionId){
return «className»Base::subscribeTo«attributeName.toFirstUpper»(
subscriptionListener,
subscriptionQos,
subscriptionId);
}
«ENDFOR»
«FOR broadcast: serviceInterface.broadcasts»
«var broadcastName = broadcast.joynrName»
«val returnTypes = broadcast.commaSeparatedOutputParameterTypes»
/**
* @brief unsubscribes from broadcast «broadcastName.toFirstUpper»
* @param subscriptionId The subscription id returned earlier on creation of the subscription
*/
void unsubscribeFrom«broadcastName.toFirstUpper»Broadcast(std::string &subscriptionId) {
«className»Base::unsubscribeFrom«broadcastName.toFirstUpper»Broadcast(subscriptionId);
}
«IF isSelective(broadcast)»
/**
* @brief subscribes to selective broadcast «broadcastName.toFirstUpper» with filter parameters
* @param filterParameters The filter parameters for selection of suitable broadcasts
* @param subscriptionListener The listener callback providing methods to call on publication and failure
* @param subscriptionQos The subscription quality of service settings
* @return the subscription id as string
*/
std::string subscribeTo«broadcastName.toFirstUpper»Broadcast(
const «interfaceName.toFirstUpper»«broadcastName.toFirstUpper»BroadcastFilterParameters& filterParameters,
std::shared_ptr > subscriptionListener,
const joynr::OnChangeSubscriptionQos& subscriptionQos){
return «className»Base::subscribeTo«broadcastName.toFirstUpper»Broadcast(
filterParameters,
subscriptionListener,
subscriptionQos);
}
/**
* @brief updates an existing subscription to selective broadcast «broadcastName.toFirstUpper» with filter parameters
* @param filterParameters The filter parameters for selection of suitable broadcasts
* @param subscriptionListener The listener callback providing methods to call on publication and failure
* @param subscriptionQos The subscription quality of service settings
* @param subscriptionId The subscription id returned earlier on creation of the subscription
* @return the subscription id as string
*/
std::string subscribeTo«broadcastName.toFirstUpper»Broadcast(
const «interfaceName.toFirstUpper»«broadcastName.toFirstUpper»BroadcastFilterParameters& filterParameters,
std::shared_ptr > subscriptionListener,
const joynr::OnChangeSubscriptionQos& subscriptionQos,
std::string& subscriptionId){
return «className»Base::subscribeTo«broadcastName.toFirstUpper»Broadcast(
filterParameters,
subscriptionListener,
subscriptionQos,
subscriptionId);
}
«ELSE»
/**
* @brief subscribes to broadcast «broadcastName.toFirstUpper»
* @param subscriptionListener The listener callback providing methods to call on publication and failure
* @param subscriptionQos The subscription quality of service settings
* @return the subscription id as string
*/
std::string subscribeTo«broadcastName.toFirstUpper»Broadcast(
std::shared_ptr > subscriptionListener,
const joynr::OnChangeSubscriptionQos& subscriptionQos){
return «className»Base::subscribeTo«broadcastName.toFirstUpper»Broadcast(
subscriptionListener,
subscriptionQos);
}
/**
* @brief updates an existing subscription to broadcast «broadcastName.toFirstUpper»
* @param filterParameters The filter parameters for selection of suitable broadcasts
* @param subscriptionListener The listener callback providing methods to call on publication and failure
* @param subscriptionQos The subscription quality of service settings
* @param subscriptionId The subscription id returned earlier on creation of the subscription
* @return the subscription id as string
*/
std::string subscribeTo«broadcastName.toFirstUpper»Broadcast(
std::shared_ptr > subscriptionListener,
const joynr::OnChangeSubscriptionQos& subscriptionQos,
std::string& subscriptionId){
return «className»Base::subscribeTo«broadcastName.toFirstUpper»Broadcast(
subscriptionListener,
subscriptionQos,
subscriptionId);
}
«ENDIF»
«ENDFOR»
/** @brief Destructor */
virtual ~«className»();
// attributes
«FOR attribute: getAttributes(serviceInterface)»
«var attributeName = attribute.joynrName»
«IF attribute.readable»
using «asyncClassName»::get«attributeName.toFirstUpper»Async;
using «syncClassName»::get«attributeName.toFirstUpper»;
«ENDIF»
«IF attribute.writable»
using «asyncClassName»::set«attributeName.toFirstUpper»Async;
using «syncClassName»::set«attributeName.toFirstUpper»;
«ENDIF»
«ENDFOR»
// operations
«FOR methodName: getUniqueMethodNames(serviceInterface)»
using «asyncClassName»::«methodName»Async;
using «syncClassName»::«methodName»;
«ENDFOR»
private:
DISALLOW_COPY_AND_ASSIGN(«className»);
};
«getNamespaceEnder(serviceInterface)»
#endif // «headerGuard»
'''
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy