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

org.aspectj.asm.IRelationshipMap Maven / Gradle / Ivy

There is a newer version: 1.9.22.1
Show newest version
/* *******************************************************************
 * Copyright (c) 2003 Contributors.
 * All rights reserved. 
 * This program and the accompanying materials are made available 
 * under the terms of the Eclipse Public License v1.0 
 * which accompanies this distribution and is available at 
 * http://www.eclipse.org/legal/epl-v10.html 
 *  
 * Contributors: 
 *     Mik Kersten     initial implementation 
 * ******************************************************************/

package org.aspectj.asm;

import java.io.Serializable;
import java.util.List;
import java.util.Set;

//import org.aspectj.asm.IRelationship.Kind;

/**
 * Maps from a program element handles to a list of relationships between that element
 * and othe program elements.  Each element in the list or relationships is
 * uniquely identified by a kind and a relationship name.  For example, the advice affecting
 * a particular shadow (e.g. method call) can be retrieved by calling get on 
 * the handle for that method.  Symmetrically the method call shadows that an advice affects 
 * can be retrieved.
 * 
 * The elements can be stored and looked up as IProgramElement(s), in which cases the 
 * element corresponding to the handle is looked up in the containment hierarchy.
 * 
 * put/get methods taking IProgramElement as a parameter are for convenience only.  
 * They work identically to calling their counterparts with IProgramElement.getIdentifierHandle()
 * 
 * @author Mik Kersten
 */
public interface IRelationshipMap extends Serializable {
 
 	/**
 	 * @return	null if the element is not found.
 	 */
	public List/*IRelationship*/ get(IProgramElement source);

	/**
	 * @return	null if the element is not found.
	 */	
	public List/*IRelationship*/ get(String handle);

	/**
	 * Return a relationship matching the kind and name for the given element.  
	 * 
	 * @return	null if the relationship is not found.
	 */
	public IRelationship get(IProgramElement source, IRelationship.Kind kind, 
	                         String relationshipName,boolean runtimeTest,
	                         boolean createIfMissing);

	/**
	 * Return a relationship matching the kind and name for the given element.  
	 * 
	 * @return	null if the relationship is not found.
	 */
    public IRelationship get(IProgramElement source, IRelationship.Kind kind,
      String relationshipName);
      
	/**
	 * Return a relationship matching the kind and name for the given element.
	 * Creates the relationship if not found.
	 * 
	 * @return	null if the relationship is not found.
	 */
	public IRelationship get(String source, IRelationship.Kind kind,
	                         String relationshipName, boolean runtimeTest,
	                         boolean createIfMissing);
	
	public void put(IProgramElement source, IRelationship relationship);

	public void put(String handle, IRelationship relationship);
	
	public boolean remove(String handle, IRelationship relationship);
	
	public void removeAll(String source);
	
	/**
	 * Clear all of the relationships in the map.
	 */
	public void clear();
	
	public Set getEntries();
 
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy