WALA/com.ibm.wala.core/src/com/ibm/wala/ipa/callgraph/propagation/InstanceKey.java

52 lines
2.0 KiB
Java

/*******************************************************************************
* Copyright (c) 2002 - 2006 IBM Corporation.
* 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:
* IBM Corporation - initial API and implementation
*******************************************************************************/
package com.ibm.wala.ipa.callgraph.propagation;
import java.util.Iterator;
import com.ibm.wala.classLoader.IClass;
import com.ibm.wala.classLoader.NewSiteReference;
import com.ibm.wala.ipa.callgraph.CGNode;
import com.ibm.wala.ipa.callgraph.CallGraph;
import com.ibm.wala.ipa.callgraph.ContextItem;
import com.ibm.wala.util.collections.Pair;
/**
* An InstanceKey serves as the representative for an equivalence class of
* objects in the heap, that can be pointed to.
*
* For example, for 0-CFA, an InstanceKey would embody an <IClass>... we model
* all instances of a particular class
*
* For 0-1-CFA, an InstanceKey could be <IMethod,statement #>, representing a
* particular allocation statement in a particular method.
*/
public interface InstanceKey extends ContextItem {
/**
* For now, we assert that each InstanceKey represents a set of classes which
* are all of the same concrete type (modulo the fact that all arrays of
* references are considered concrete type []Object;)
*/
IClass getConcreteType();
/**
* Get the creation sites of <code>this</code>, i.e., the statements that may
* allocate objects represented by <code>this</code>. A creation site is a
* pair (n,s), where n is the containing {@link CGNode} in the given
* {@link CallGraph} <code>CG</code> and s is the allocating
* {@link NewSiteReference}.
*
*/
Iterator<Pair<CGNode, NewSiteReference>> getCreationSites(CallGraph CG);
}