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

com.eprosima.idl.parser.tree.Interface Maven / Gradle / Ivy

// Copyright 2016 Proyectos y Sistemas de Mantenimiento SL (eProsima).
//
// 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.

package com.eprosima.idl.parser.tree;

import java.util.ArrayList;
import java.util.Map;
import java.util.HashMap;

import org.antlr.v4.runtime.Token;

public class Interface extends ExportContainer implements Definition
{
    public Interface(String scopeFile, boolean isInScope, String scope, String name, Token tk)
    {
        super(scopeFile, isInScope, scope, name, tk);

        m_bases = new HashMap();
    }
    

    public void setParent(Object obj)
    {
        m_parent = obj;
    }
    
    public Object getParent()
    {
        return m_parent;
    }
    
    @Override
    public boolean isIsModule()
    {
        return false;
    }
    
    @Override
    public boolean isIsInterface()
    {
    	return true;
    }
    
    @Override
    public boolean isIsException()
    {
    	return false;
    }
    
    @Override
    public boolean isIsTypeDeclaration()
    {
        return false;
    }

    @Override
    public boolean isIsConstDeclaration()
    {
        return false;
    }
	
	@Override
	public boolean isIsAnnotation()
    {
        return false;
    }

    public boolean addBase(Interface interf)
    {
        Interface prev = m_bases.put(interf.getName(), interf);

        if(prev != null)
            return false;

        return true;
    }

    public ArrayList getBases()
    {
        return new ArrayList(m_bases.values());
    }
    
    /*!
     * @brief This function returns the exception defined inside the interface.
     */
    public Exception getException(String currentScope, String ename)
    {
    	com.eprosima.idl.parser.tree.Exception exception = null;
    	
    	for(int count = 0; exception == null && count < getExports().size(); ++count)
        {
    		int lastIndex = -1;
    		
    		if(getExports().get(count).isIsException())
    		{
                String tmpname = ((com.eprosima.idl.parser.tree.Exception)getExports().get(count)).getScopedname();
                
                if(tmpname.equals(ename))
                {
                	exception = (com.eprosima.idl.parser.tree.Exception)getExports().get(count);
                }
                else
                {
                	// Probar si no tiene scope, con el scope actual.
                    if(exception == null && ((lastIndex = ename.lastIndexOf("::")) == -1) &&
                    		tmpname.equals(currentScope + ename))
                    {
                    	exception = (com.eprosima.idl.parser.tree.Exception)getExports().get(count);
                    }	
                }
    		}
        }
    	
    	return exception;
    }

    /*!
     * @brief This function returns all operations of the interface.
     * This function is used in the string templates.
     */
    public ArrayList getOperations()
    {
        if(m_operations == null)
        {
            m_operations = new ArrayList();
            
            // Get own operations.
            for(int count = 0; count < getExports().size(); ++count)
            {
                if(getExports().get(count).isIsOperation())
                {
                    m_operations.add((Operation)getExports().get(count));
                }
            }
        }
        
        return m_operations;
    }

    public ArrayList getAll_operations()
    {
        if(m_all_operations == null)
        {
            m_all_operations = new ArrayList();

            // Get parent operations.
            for(Interface iface : m_bases.values())
            {
                m_all_operations.addAll(iface.getAll_operations());
            }
            
            // Get own operations.
            for(int count = 0; count < getExports().size(); ++count)
            {
                if(getExports().get(count).isIsOperation())
                {
                    m_all_operations.add((Operation)getExports().get(count));
                }
            }
        }

        return m_all_operations;
    }
    
    /*!
     * @brief This function is used in stringtemplates to not generate module in some cases (Right now in generated RTI idl).
     */
    public boolean isThereAreDeclarations()
    {
        boolean returnedValue = false;
        
        for(int count = 0; !returnedValue && count < getExports().size(); ++count)
        {
            returnedValue = getExports().get(count).isIsTypeDeclaration() ||
                getExports().get(count).isIsConstDeclaration() || getExports().get(count).isIsException();
        }
        
        return returnedValue;
    }

    private Object m_parent = null;
    
    //! Contains all interfaces it inherits from.
    private Map m_bases = null;
    //! Contains all operations.
    private ArrayList m_operations = null;
    private ArrayList m_all_operations = null;
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy