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

pascal.taie.analysis.pta.toolkit.zipper.PotentialContextElement Maven / Gradle / Ivy

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.toolkit.zipper;

import pascal.taie.analysis.pta.core.heap.Obj;
import pascal.taie.analysis.pta.toolkit.PointerAnalysisResultEx;
import pascal.taie.analysis.pta.toolkit.util.OAGs;
import pascal.taie.language.classes.JMethod;
import pascal.taie.language.type.Type;
import pascal.taie.util.Canonicalizer;
import pascal.taie.util.Indexer;
import pascal.taie.util.SimpleIndexer;
import pascal.taie.util.collection.IndexerBitSet;
import pascal.taie.util.collection.Maps;

import java.util.Map;
import java.util.Set;

/**
 * For each object type t, this class compute the set of methods
 * which objects of t could potentially be their context element.
 */
class PotentialContextElement {

    /**
     * Map from each type to PCE methods of the objects of the type.
     */
    private final Map> type2PCEMethods;

    PotentialContextElement(PointerAnalysisResultEx pta,
                            ObjectAllocationGraph oag) {
        Map> invokedMethods = OAGs.computeInvokedMethods(pta);
        Canonicalizer> canonicalizer = new Canonicalizer<>();
        Indexer methodIndexer = new SimpleIndexer<>(
                pta.getBase().getCallGraph().getNodes());
        Set types = pta.getObjectTypes();
        type2PCEMethods = Maps.newConcurrentMap(types.size());
        types.parallelStream().forEach(type -> {
            Set methods = new IndexerBitSet<>(methodIndexer, true);
            // add invoked methods on objects of type
            for (Obj obj : pta.getObjectsOf(type)) {
                methods.addAll(invokedMethods.get(obj));
            }
            // add invoked methods on allocated objects of type
            for (Obj allocatee : oag.getAllocateesOf(type)) {
                methods.addAll(invokedMethods.get(allocatee));
            }
            type2PCEMethods.put(type, canonicalizer.get(methods));
        });
    }

    Set pceMethodsOf(Type type) {
        return type2PCEMethods.get(type);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy