All Downloads are FREE. Search and download functionalities are using the official Maven repository.
Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
io.joynr.generator.cpp.proxy.InterfaceAsyncProxyCppTemplate.xtend Maven / Gradle / Ivy
package io.joynr.generator.cpp.proxy
/*
* !!!
*
* Copyright (C) 2011 - 2017 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.CppInterfaceUtil
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.templates.InterfaceTemplate
import io.joynr.generator.templates.util.AttributeUtil
import io.joynr.generator.templates.util.MethodUtil
import io.joynr.generator.templates.util.NamingUtil
class InterfaceAsyncProxyCppTemplate extends InterfaceTemplate {
@Inject extension JoynrCppGeneratorExtensions
@Inject extension TemplateBase
@Inject extension CppStdTypeUtil
@Inject extension NamingUtil
@Inject extension AttributeUtil
@Inject extension MethodUtil
@Inject extension CppInterfaceUtil
override generate(boolean generateVersion)
'''
«val interfaceName = francaIntf.joynrName»
«val className = interfaceName + "Proxy"»
«val asyncClassName = interfaceName + "AsyncProxy"»
«warning()»
#include "«getPackagePathWithJoynrPrefix(francaIntf, "/", generateVersion)»/«asyncClassName».h"
«FOR parameterType: getDataTypeIncludesFor(francaIntf, generateVersion).addElements(includeForString)»
#include «parameterType»
«ENDFOR»
#include "joynr/Future.h"
#include "joynr/exceptions/JoynrException.h"
«getNamespaceStarter(francaIntf, generateVersion)»
«asyncClassName»::«asyncClassName»(
std::weak_ptr runtime,
std::shared_ptr connectorFactory,
const std::string &domain,
const joynr::MessagingQos &qosSettings
) :
joynr::ProxyBase(runtime, connectorFactory, domain, qosSettings),
«className»Base(runtime, connectorFactory, domain, qosSettings)«IF hasFireAndForgetMethods(francaIntf)»,
«interfaceName»FireAndForgetProxy(runtime, connectorFactory, domain, qosSettings)«ENDIF»
{
}
«FOR attribute: getAttributes(francaIntf)»
«var attributeName = attribute.joynrName»
«var attributeType = attribute.getTypeName(generateVersion)»
«IF attribute.readable»
«var getAttribute = "get" + attributeName.toFirstUpper»
/*
* «getAttribute»
*/
«produceAsyncGetterSignature(attribute, asyncClassName, generateVersion)»
{
auto runtimeSharedPtr = _runtime.lock();
if (!runtimeSharedPtr || (connector==nullptr)) {
std::string errorText;
if (!runtimeSharedPtr) {
«val errorMsgRuntime = "proxy cannot invoke " + getAttribute + " because the required runtime has been already destroyed."»
errorText = "«errorMsgRuntime»";
}
else {
«val errorMsg = "proxy cannot invoke " + getAttribute + ", because the communication end partner is not (yet) known"»
errorText = "«errorMsg»";
}
JOYNR_LOG_WARN(logger(), errorText);
auto error = std::make_shared(errorText);
if (onError) {
onError(*error);
}
auto future = std::make_shared>();
future->onError(error);
return future;
}
else{
return connector->«getAttribute»Async(std::move(onSuccess), std::move(onError), std::move(qos));
}
}
«ENDIF»
«IF attribute.writable»
«var setAttribute = "set" + attributeName.toFirstUpper»
/*
* «setAttribute»
*/
«produceAsyncSetterSignature(attribute, asyncClassName, generateVersion)»
{
auto runtimeSharedPtr = _runtime.lock();
if (!runtimeSharedPtr || (connector==nullptr)) {
std::string errorText;
if (!runtimeSharedPtr) {
«val errorMsgRuntime = "proxy cannot invoke " + setAttribute + " because the required runtime has been already destroyed."»
errorText = "«errorMsgRuntime»";
}
else {
«val errorMsg = "proxy cannot invoke " + setAttribute + ", because the communication end partner is not (yet) known"»
errorText = "«errorMsg»";
}
JOYNR_LOG_WARN(logger(), errorText);
auto error = std::make_shared(errorText);
if (onError) {
onError(*error);
}
auto future = std::make_shared>();
future->onError(error);
return future;
}
else {
return connector->«setAttribute»Async(«attributeName», std::move(onSuccess), std::move(onError), std::move(qos));
}
}
«ENDIF»
«ENDFOR»
«FOR method: getMethods(francaIntf)»
«IF !method.fireAndForget»
«var methodName = method.joynrName»
«var outputParameters = method.getCommaSeparatedOutputParameterTypes(generateVersion)»
«var inputParamList = getCommaSeperatedUntypedInputParameterList(method)»
/*
* «methodName»
*/
«produceAsyncMethodSignature(francaIntf, method, asyncClassName, generateVersion)»
{
auto runtimeSharedPtr = _runtime.lock();
if (!runtimeSharedPtr || (connector==nullptr)) {
std::string errorText;
if (!runtimeSharedPtr) {
«val errorMsgRuntime = "proxy cannot invoke " + methodName + " because the required runtime has been already destroyed."»
errorText = "«errorMsgRuntime»";
}
else {
«val errorMsg = "proxy cannot invoke " + methodName + ", because the communication end partner is not (yet) known"»
errorText = "«errorMsg»";
}
JOYNR_LOG_WARN(logger(), errorText);
auto error = std::make_shared(errorText);
if (onRuntimeError) {
onRuntimeError(*error);
}
auto future = std::make_shared>();
future->onError(error);
return future;
}
else{
return connector->«methodName»Async(«inputParamList»«IF !method.inputParameters.empty», «ENDIF»std::move(onSuccess), «IF method.hasErrorEnum»std::move(onApplicationError), «ENDIF»std::move(onRuntimeError), std::move(qos));
}
}
«ENDIF»
«ENDFOR»
«getNamespaceEnder(francaIntf, generateVersion)»
'''
}