All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.joynr.generator.cpp.proxy.InterfaceAsyncProxyCppTemplate.xtend Maven / Gradle / Ivy

There is a newer version: 0.9.3
Show newest version
package io.joynr.generator.cpp.proxy
/*
 * !!!
 *
 * Copyright (C) 2011 - 2013 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 org.franca.core.franca.FInterface
import io.joynr.generator.cpp.util.TemplateBase
import io.joynr.generator.cpp.util.JoynrCppGeneratorExtensions

class InterfaceAsyncProxyCppTemplate  {
	@Inject	extension JoynrCppGeneratorExtensions
	@Inject extension TemplateBase
	
	def generate(FInterface fInterface) {
		val interfaceName =  fInterface.joynrName
		val className = interfaceName + "Proxy"
		val asyncClassName = interfaceName + "AsyncProxy"
		'''
		«warning()»
		
		#include "«getPackagePathWithJoynrPrefix(fInterface, "/")»/«asyncClassName».h"
		«FOR datatype: getRequiredIncludesFor(fInterface)»
			#include "«datatype»"
		«ENDFOR»
		
		#include "joynr/exceptions.h"
		#include "joynr/Request.h"
		#include "joynr/Reply.h"
		#include 
		
		«getNamespaceStarter(fInterface)» 
		«asyncClassName»::«asyncClassName»(
				QSharedPointer messagingAddress,
				joynr::ConnectorFactory* connectorFactory,
				joynr::IClientCache *cache,
				const QString &domain,
		        const joynr::ProxyQos& proxyQos,
		        const joynr::MessagingQos &qosSettings,
		        bool cached
		) :
		    joynr::ProxyBase(connectorFactory, cache, domain, getInterfaceName(), proxyQos, qosSettings, cached),
		    «className»Base(messagingAddress, connectorFactory, cache, domain, proxyQos, qosSettings, cached)
		{
		}
		
		«FOR attribute: getAttributes(fInterface)»
			«var attributeName = attribute.joynrName»
			«var attributeType = getMappedDatatypeOrList(attribute)» 
            «var getAttribute = "get" + attributeName.toFirstUpper» 
            «var setAttribute = "set" + attributeName.toFirstUpper» 
			/*
			 * «getAttribute»
			 */

			void «asyncClassName»::«getAttribute»(QSharedPointer > future, QSharedPointer< joynr::ICallback< «attributeType» > > callback)
			{
			    assert (!future.isNull());
			    if (connector==NULL){
			        LOG_WARN(logger, "proxy cannot invoke «getAttribute», because the communication end partner is not (yet) known");
			    }
			    else{
			        connector->«getAttribute»(future, callback);
			    }
			}
			
			void «asyncClassName»::«getAttribute»(QSharedPointer > future)
			{
			    assert (!future.isNull());
			    if (connector==NULL){
			        LOG_WARN(logger, "proxy cannot invoke «getAttribute», because the communication end partner is not (yet) known");
			    }
			    else{
			        connector->«getAttribute»(future);
			    }
			}
			
			void «asyncClassName»::«getAttribute»(QSharedPointer > callback)
			{
			    if (connector==NULL){
			        LOG_WARN(logger, "proxy cannot invoke «getAttribute», because the communication end partner is not (yet) known");
			    }
			    else{
			        connector->«getAttribute»(callback);
			    }
			}
			
			/*
			 * «setAttribute»
			 */
			
			void «asyncClassName»::«setAttribute»(QSharedPointer > future, QSharedPointer< joynr::ICallback > callback, «attributeType» attributeValue) {
			    assert (!future.isNull());
			    if (connector==NULL){
			        LOG_WARN(logger, "proxy cannot invoke «setAttribute», because the communication end partner is not (yet) known");
			    }
			    else{
			        connector->«setAttribute»(future, callback, attributeValue);
			    }
			}
			
			void «asyncClassName»::«setAttribute»(QSharedPointer > future, «attributeType» attributeValue) {
			    assert (!future.isNull());
			    if (connector==NULL){
			        LOG_WARN(logger, "proxy cannot invoke «setAttribute», because the communication end partner is not (yet) known");
			    }
			    else{
			        connector->«setAttribute»(future, attributeValue);
			    }
			}
			
			void «asyncClassName»::«setAttribute»(QSharedPointer< joynr::ICallback > callBack, «attributeType» attributeValue) {
			    if (connector==NULL){
			        LOG_WARN(logger, "proxy cannot invoke «setAttribute», because the communication end partner is not (yet) known");
			    }
			    else{
			        connector->«setAttribute»(callBack, attributeValue);
			    }
			}

		«ENDFOR»
		«FOR method: getMethods(fInterface)»
			«var methodName = method.joynrName»
			«var outType = getMappedOutputParameter(method).head»
			«var paramsSignature = prependCommaIfNotEmpty(getCommaSeperatedTypedParameterList(method))»
			«var params = prependCommaIfNotEmpty(getCommaSeperatedUntypedParameterList(method))»
			
			/*
			 * «methodName»
			 */
			
			void «asyncClassName»::«methodName»(QSharedPointer > future, QSharedPointer< joynr::ICallback<«outType»> > callback «paramsSignature»)
			{
			    assert (!future.isNull());
			    if (connector==NULL){
			        LOG_WARN(logger, "proxy cannot invoke «methodName», because the communication end partner is not (yet) known");
			    }
			    else{
			        connector->«methodName»(future, callback «params»);
			    }
			}
			
			void «asyncClassName»::«methodName»(QSharedPointer > future «paramsSignature») {
			    assert (!future.isNull());
			    if (connector==NULL){
			        LOG_WARN(logger, "proxy cannot invoke «methodName», because the communication end partner is not (yet) known");
			    }
			    else{
			        connector->«methodName»(future «params»);
			    }
			}
			
			void «asyncClassName»::«methodName»(QSharedPointer > callback «paramsSignature») { 
			    if (connector==NULL){
			        LOG_WARN(logger, "proxy cannot invoke «methodName», because the communication end partner is not (yet) known");
			    }
			    else{
			        connector->«methodName»(callback «params»);
			    }
			}
			
		«ENDFOR»
		«getNamespaceEnder(fInterface)»
		'''	
	}	
	
			
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy