pascal.taie.analysis.pta.plugin.reflection.OthersModel Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of tai-e Show documentation
Show all versions of tai-e Show documentation
An easy-to-learn/use static analysis framework for Java
The newest version!
/*
* Tai-e: A Static Analysis Framework for Java
*
* Copyright (C) 2022 Tian Tan
* Copyright (C) 2022 Yue Li
*
* This file is part of Tai-e.
*
* Tai-e is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License
* as published by the Free Software Foundation, either version 3
* of the License, or (at your option) any later version.
*
* Tai-e is distributed in the hope that it will be useful,but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General
* Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with Tai-e. If not, see .
*/
package pascal.taie.analysis.pta.plugin.reflection;
import pascal.taie.analysis.pta.core.cs.context.Context;
import pascal.taie.analysis.pta.core.cs.element.CSObj;
import pascal.taie.analysis.pta.core.heap.Descriptor;
import pascal.taie.analysis.pta.core.heap.Obj;
import pascal.taie.analysis.pta.core.solver.Solver;
import pascal.taie.analysis.pta.plugin.util.AnalysisModelPlugin;
import pascal.taie.analysis.pta.plugin.util.CSObjs;
import pascal.taie.analysis.pta.plugin.util.InvokeHandler;
import pascal.taie.analysis.pta.pts.PointsToSet;
import pascal.taie.ir.exp.ClassLiteral;
import pascal.taie.ir.exp.Var;
import pascal.taie.ir.stmt.Invoke;
import pascal.taie.language.annotation.Annotation;
import pascal.taie.language.classes.ClassNames;
import pascal.taie.language.classes.JClass;
import pascal.taie.language.classes.JMethod;
import pascal.taie.language.type.ArrayType;
import pascal.taie.language.type.ClassType;
import pascal.taie.language.type.Type;
import pascal.taie.language.type.VoidType;
import java.util.ArrayList;
import java.util.List;
import static pascal.taie.analysis.pta.plugin.util.InvokeUtils.BASE;
/**
* Models other non-core reflection APIs.
*/
public class OthersModel extends AnalysisModelPlugin {
private static final Descriptor PARAM_ANNOTATIONS = () -> "ParamAnnotations";
private final MetaObjHelper helper;
/**
* Annotation[].
*/
private final ArrayType annotation1Array;
/**
* Annotation[][].
*/
private final ArrayType annotation2Array;
public OthersModel(Solver solver, MetaObjHelper helper) {
super(solver);
this.helper = helper;
ClassType annotationType = typeSystem.getClassType(ClassNames.ANNOTATION);
annotation1Array = typeSystem.getArrayType(annotationType, 1);
annotation2Array = typeSystem.getArrayType(annotationType, 2);
}
// ---------- Model for java.lang.Object starts ----------
@InvokeHandler(signature = "", argIndexes = {BASE})
public void getClass(Context context, Invoke invoke, PointsToSet recvObjs) {
if (!invoke.getContainer().isApplication()) {
// ignore Object.getClass() in library code, until
// we have better treatment with relevant reflective calls
return;
}
Var result = invoke.getResult();
if (result != null) {
recvObjs.forEach(recv -> {
Type type = recv.getObject().getType();
if (type instanceof ClassType classType) {
Obj classObj = helper.getMetaObj(classType.getJClass());
solver.addVarPointsTo(context, result, classObj);
}
});
}
}
// ---------- Model for java.lang.Object ends ----------
// ---------- Model for java.lang.Class starts ----------
@InvokeHandler(signature = "", argIndexes = {0})
public void getPrimitiveClass(Context context, Invoke invoke, PointsToSet nameObjs) {
Var result = invoke.getResult();
if (result != null) {
nameObjs.forEach(nameObj -> {
String name = CSObjs.toString(nameObj);
if (name != null) {
Type type = name.equals("void") ?
VoidType.VOID : typeSystem.getPrimitiveType(name);
solver.addVarPointsTo(context, result,
heapModel.getConstantObj(ClassLiteral.get(type)));
}
});
}
}
@InvokeHandler(signature = "", argIndexes = {BASE, 0})
public void getAnnotation(Context context, Invoke invoke,
PointsToSet baseClasses, PointsToSet annoClasses) {
Var result = invoke.getResult();
if (result != null) {
baseClasses.forEach(baseClass -> {
JClass baseClazz = CSObjs.toClass(baseClass);
if (baseClazz != null) {
annoClasses.forEach(annoClass -> {
JClass annoClazz = CSObjs.toClass(annoClass);
if (annoClazz != null) {
Annotation a = baseClazz.getAnnotation(annoClazz.getName());
if (a != null) {
Obj annoObj = helper.getAnnotationObj(a);
solver.addVarPointsTo(context, result, annoObj);
}
}
});
}
});
}
}
// ---------- Model for java.lang.Class ends ----------
// ---------- Model for java.lang.reflect.Method starts ----------
@InvokeHandler(signature = "", argIndexes = {BASE})
public void getParameterAnnotations(Context context, Invoke invoke, PointsToSet mtdObjs) {
Var result = invoke.getResult();
if (result != null) {
mtdObjs.forEach(mtdObj -> {
JMethod method = CSObjs.toMethod(mtdObj);
if (method != null) {
List paramAnnos = new ArrayList<>();
for (int i = 0; i < method.getParamCount(); ++i) {
paramAnnos.addAll(method.getParamAnnotations(i));
}
if (!paramAnnos.isEmpty()) {
PointsToSet annoSet = solver.makePointsToSet();
paramAnnos.forEach(anno -> {
Obj annoObj = helper.getAnnotationObj(anno);
annoSet.addObject(csManager.getCSObj(emptyContext, annoObj));
});
// Annotation[*] anno1Array = annotation;
Obj anno1Array = heapModel.getMockObj(PARAM_ANNOTATIONS, invoke,
annotation1Array, invoke.getContainer());
CSObj csAnno1Array = csManager.getCSObj(context, anno1Array);
solver.addPointsTo(csManager.getArrayIndex(csAnno1Array), annoSet);
// Annotation[*][] anno2Array = anno1Array;
Obj anno2Array = heapModel.getMockObj(PARAM_ANNOTATIONS, invoke,
annotation2Array, invoke.getContainer());
CSObj csAnno2Array = csManager.getCSObj(context, anno2Array);
solver.addPointsTo(csManager.getArrayIndex(csAnno2Array), csAnno1Array);
// result = anno2Array;
solver.addVarPointsTo(context, result, anno2Array);
}
}
});
}
}
// ---------- Model for java.lang.reflect.Method ends ----------
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy