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

templates.KMFQLSelectorByQuery.vm Maven / Gradle / Ivy

#* @vtlvariable name="optionalRelationShipNameGen" type="java.lang.Boolean" *#
#* @vtlvariable name="relationShipOptionalName" type="java.lang.String" *#
#* @vtlvariable name="eRefs" type="org.eclipse.emf.common.util.EList" *#
#* @vtlvariable name="eSub" type="org.eclipse.emf.common.util.EList" *#
#* @vtlvariable name="ctx" type="org.kevoree.modeling.kotlin.generator.GenerationContext" *#
#* @vtlvariable name="FQNHelper" type="org.kevoree.modeling.kotlin.generator.ProcessorHelper" *#
#* @vtlvariable name="formatedFactoryName" type="java.lang.String" *#

override fun selectByQuery(query : String) : MutableList {
    val collected = java.util.ArrayList()
    try {
        val firstSepIndex = query.indexOf('[')
        var queryID = ""
        var extraReadChar = 2
        #if($optionalRelationShipNameGen)
        val relationName = ${FQNHelper.fqn($ctx, $ctx.basePackageForUtilitiesGeneration)}.util.Constants.Ref_${relationShipOptionalName}
        val optionalDetected = ( firstSepIndex != ${relationShipOptionalName.length()} )
        if(optionalDetected){ extraReadChar = extraReadChar - 2 }
        if(query.indexOf('{') == 0){
        #else
        val relationName = query.substring(0,query.indexOf('['))
        if(query.indexOf('{') == firstSepIndex +1){
        #end
            queryID = query.substring(query.indexOf('{')+1,query.indexOf('}'))
            extraReadChar = extraReadChar + 2
        } else {
        #if($optionalRelationShipNameGen)
            if(optionalDetected){
                if(query.indexOf('/') != - 1){
                    queryID = query.substring(0,query.indexOf('/'))
                } else {
                    queryID = query.substring(0,query.size)
                }
            } else {
                queryID = query.substring(query.indexOf('[')+1,query.indexOf(']'))
            }
        #else
            queryID = query.substring(query.indexOf('[')+1,query.indexOf(']'))
        #end
        }
        #if($optionalRelationShipNameGen)
        var subquery = query.substring((if(optionalDetected){0} else {relationName.size})+queryID.size+extraReadChar,query.size)
        #else
        var subquery = query.substring(relationName.size+queryID.size+extraReadChar,query.size)
        #end
        if (subquery.indexOf('/') != -1){
            subquery = subquery.substring(subquery.indexOf('/')+1,subquery.size)
        }
        when(relationName) {
            #foreach( $ref in $eRefs )
                ${FQNHelper.fqn($ctx, $ctx.basePackageForUtilitiesGeneration)}.util.Constants.Ref_${ref.getName()} -> {
                #if(!$ref.isMany())
                    var subResult = ${ctx.kevoreeCacheResolver}.filter(queryID,java.util.Collections.singleton(${FQNHelper.protectReservedWords($ref.getName())})!!)
                    collected.add(subResult)
                #else
                    var subResult : MutableCollection? = null
                    #if(${ref.getEReferenceType().getEIDAttribute()})
                        #if($ref.isMany())
                            val tempObj = find${ref.getName().substring(0, 1).toUpperCase()}${ref.getName().substring(1)}ByID(queryID)
                            if(tempObj!=null){
                                subResult = java.util.ArrayList()
                                subResult!!.add(tempObj)
                            }
                        #end
                    #end
                    if(subResult == null){
                    #if(${ref.getEReferenceType().getEIDAttribute()})
                        subResult = ${ctx.kevoreeCacheResolver}.filter(queryID,_${ref.getName()}.values()) as MutableCollection
                    #else
                        subResult = ${ctx.kevoreeCacheResolver}.filter(queryID,_${ref.getName()}) as MutableCollection
                    #end
                    }
                    if(subquery != ""){
                        for(subObj in subResult!!){
                            collected.addAll( (subObj as ${FQNHelper.fqn($ctx, $ref.getEReferenceType())}).selectByQuery(subquery))
                        }
                    } else {
                        collected.addAll(subResult!!)
                    }
                #end
                    return collected
                }
            #end
                ${FQNHelper.fqn($ctx, $ctx.basePackageForUtilitiesGeneration)}.util.Constants.KMFQL_CONTAINED -> {
                    var subResult : MutableCollection = java.util.ArrayList()
                    #foreach( $subRef in $eSub )
                        #if(!$subRef.isMany())
                            if(${FQNHelper.protectReservedWords($subRef.getName())}!=null){
                                subResult.addAll(${ctx.kevoreeCacheResolver}.filter(queryID,java.util.Collections.singleton(${FQNHelper.protectReservedWords($subRef.getName())})!!)!!)
                            }
                        #else
                            subResult.addAll(${ctx.kevoreeCacheResolver}.filter(queryID,${FQNHelper.protectReservedWords($subRef.getName())})!!)
                        #end

                    #end
                    if(subquery != ""){
                        for(subObj in subResult!!){
                            collected.addAll( (subObj as ${formatedFactoryName}).selectByQuery(subquery))
                        }
                    } else {
                        collected.addAll(subResult!!)
                    }
                    return collected
                }
            else -> {return collected}
        }
    } catch(e:Exception){
        return collected
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy