public class AndroidModel
extends java.lang.Object
implements com.ibm.wala.ipa.cha.IClassHierarchyDweller
This method models the lifecycle of an Android Application. By doing so it calls all AndroidEntryPoints set in the AnalysisOptions.
Between the calls to the AndroidEntryPoints special behavior is inserted. You can change that behavior by implementing an AbstractAndroidModel or set one of the existing ones in the AnalysisOptions.
Additionally care of how types are instantiated is taken. You can change this behavior by setting the IInstanciationBehavior in the AnalysisOptions.
Smaller Models exist: * MiniModel calls all components of a specific type (for example all Activities) * MicroModel calls a single specific component * ExternalModel doesn't call anything but fiddles with the data on its own
All these Models are added to a synthetic AndroidModelClass.
| Modifier and Type | Field and Description |
|---|---|
protected com.ibm.wala.ipa.summaries.VolatileMethodSummary |
body |
protected boolean |
built |
protected com.ibm.wala.ipa.callgraph.IAnalysisCacheView |
cache |
protected com.ibm.wala.ipa.cha.IClassHierarchy |
cha |
protected static boolean |
doBoot |
protected com.ibm.wala.classLoader.IClass |
klass |
protected com.ibm.wala.ipa.summaries.SummarizedMethod |
model |
com.ibm.wala.types.MethodReference |
mRef |
protected com.ibm.wala.ipa.callgraph.AnalysisOptions |
options |
protected com.ibm.wala.ipa.callgraph.AnalysisScope |
scope |
| Constructor and Description |
|---|
AndroidModel(com.ibm.wala.ipa.cha.IClassHierarchy cha,
com.ibm.wala.ipa.callgraph.AnalysisOptions options,
com.ibm.wala.ipa.callgraph.IAnalysisCacheView cache) |
| Modifier and Type | Method and Description |
|---|---|
protected void |
build(com.ibm.wala.util.strings.Atom name)
Generates the model on a sub-set of Entrypoints.
|
protected void |
build(com.ibm.wala.util.strings.Atom name,
java.util.Collection<? extends AndroidEntryPoint> entrypoints)
Generate the SummarizedMethod for the model (in this.model).
|
com.ibm.wala.ipa.cha.IClassHierarchy |
getClassHierarchy() |
com.ibm.wala.classLoader.IClass |
getDeclaringClass()
The class the Method representing this Model resides in.
|
com.ibm.wala.types.Descriptor |
getDescriptor() |
com.ibm.wala.ipa.summaries.SummarizedMethod |
getMethod()
Building the SummarizedMethod is delayed upon the first class to this method.
|
com.ibm.wala.ipa.summaries.SummarizedMethod |
getMethodAs(com.ibm.wala.types.MethodReference asMethod,
com.ibm.wala.types.TypeReference caller,
IntentStarters.StartInfo info,
com.ibm.wala.ipa.callgraph.CGNode callerNd)
Get method of the Model in an other Signature.
|
com.ibm.wala.classLoader.IMethod |
getMethodEncap()
Creates an "encapsulated" version of the model.
|
com.ibm.wala.util.strings.Atom |
getName() |
com.ibm.wala.types.TypeName |
getReturnType() |
boolean |
isStatic() |
protected boolean |
selectEntryPoint(AndroidEntryPoint ep)
Overridden by models to restraint Entrypoints.
|
java.lang.String |
toString() |
public com.ibm.wala.types.MethodReference mRef
protected com.ibm.wala.ipa.cha.IClassHierarchy cha
protected com.ibm.wala.ipa.callgraph.AnalysisOptions options
protected com.ibm.wala.ipa.callgraph.IAnalysisCacheView cache
protected final com.ibm.wala.ipa.callgraph.AnalysisScope scope
protected com.ibm.wala.ipa.summaries.VolatileMethodSummary body
protected static boolean doBoot
protected com.ibm.wala.classLoader.IClass klass
protected boolean built
protected com.ibm.wala.ipa.summaries.SummarizedMethod model
public AndroidModel(com.ibm.wala.ipa.cha.IClassHierarchy cha,
com.ibm.wala.ipa.callgraph.AnalysisOptions options,
com.ibm.wala.ipa.callgraph.IAnalysisCacheView cache)
protected void build(com.ibm.wala.util.strings.Atom name)
throws com.ibm.wala.util.CancelException
Asks selectEntryPoint(AndroidEntryPoint) for each EntryPoint known to the
AndroidEntryPointManager, if the EntryPoint should be included in the model. Then calls build(Atom, Collection) on these.
name - The name the generated method will be known ascom.ibm.wala.util.CancelExceptionpublic com.ibm.wala.util.strings.Atom getName()
public boolean isStatic()
public com.ibm.wala.types.TypeName getReturnType()
public com.ibm.wala.types.Descriptor getDescriptor()
throws com.ibm.wala.util.CancelException
com.ibm.wala.util.CancelExceptionprotected void build(com.ibm.wala.util.strings.Atom name,
java.util.Collection<? extends AndroidEntryPoint> entrypoints)
throws com.ibm.wala.util.CancelException
The actual generated model depends on the on the properties of this overloaded class. Most generated methods should reside in the AndroidModelClass and take AndroidComponents as well as some parameters (these marked REUSE) to the EntryPoints of the components.
Use getMethod() to retrieve the method generated here or getMethodAs to get a
version which is wrapped to another signature.
name - The name the generated method will be known asentrypoints - The functions to call additionally to boot-code and XXXcom.ibm.wala.util.CancelExceptionpublic com.ibm.wala.ipa.summaries.SummarizedMethod getMethod()
throws com.ibm.wala.util.CancelException
com.ibm.wala.util.CancelExceptionpublic com.ibm.wala.classLoader.IClass getDeclaringClass()
Most likely the AndroidModelClass.
protected boolean selectEntryPoint(AndroidEntryPoint ep)
For each entrypoint this method is queried if it should be part of the model.
ep - The EntryPoint in questionpublic com.ibm.wala.ipa.summaries.SummarizedMethod getMethodAs(com.ibm.wala.types.MethodReference asMethod,
com.ibm.wala.types.TypeReference caller,
IntentStarters.StartInfo info,
com.ibm.wala.ipa.callgraph.CGNode callerNd)
throws com.ibm.wala.util.CancelException
Generates a new Method that wraps the model so it can be called using the given Signature. Flags control the behavior of that wrapper.
Arguments to the wrapping function are "connected through" to the model based on their type only, so if there are multiple Arguments of the same type this may yield to unexpected connections.
This method is called by the IntentCoentextInterpreter.
asMethod - The signature to generatecaller - The class of the caller; only needed depending on the flagsinfo - The IntentSterter usedcallerNd - CGNoodle of the caller - may be nullcom.ibm.wala.util.CancelExceptionIntentContextInterpreter,
IntentStarterspublic com.ibm.wala.classLoader.IMethod getMethodEncap()
throws com.ibm.wala.util.CancelException
The generated method will take no parameters. New instances for REUSE-Parameters will be created.
This variant is useful for the start of an analysis.
com.ibm.wala.util.CancelExceptionpublic com.ibm.wala.ipa.cha.IClassHierarchy getClassHierarchy()
getClassHierarchy in interface com.ibm.wala.ipa.cha.IClassHierarchyDwellerpublic java.lang.String toString()
toString in class java.lang.Object