WALA/com.ibm.wala.core/src/com/ibm/wala/ipa/callgraph/MethodTargetSelector.java

43 lines
2.2 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;
import com.ibm.wala.classLoader.CallSiteReference;
import com.ibm.wala.classLoader.IClass;
import com.ibm.wala.classLoader.IMethod;
/**
* This interface represents policies for selecting a method to call at a given invocation site. The most obvious such policy would
* be to look at the relevant class hierarchy and lookup the appropriate method based on the type reference and name and descriptor
* at the call site. However, other policies are possible for purposes such as providing an abstraction of unanalyzed libraries or
* specialized J2EE functionality.
*
* Such policies are consulted by the different analysis mechanisms, both the flow-based and non-flow algorithms. The current
* mechanism is that the policy object are registered with the AnalysisOptions object, and all analyses that need to analyze
* invocations ask that object for the method selector to use.
*
* In general, for specialized selectors, it is good practice to build selectors that handle the special case of interest, and
* otherwise delegate to a child selector. When registering with the AnalysisOptions object, make the child selector be whatever the
* options object had before.
*/
public interface MethodTargetSelector {
/**
* Given a calling node, a call site and (optionally) a dispatch type, return the target method to be called.
*
* @param caller the GCNode in the call graph containing the call
* @param site the call site reference of the call site
* @param receiver the type of the target object or null
* @return the method to be called.
*/
IMethod getCalleeTarget(CGNode caller, CallSiteReference site, IClass receiver);
}