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

soot.toolkits.graph.CompleteBlockGraph Maven / Gradle / Ivy

package soot.toolkits.graph;

/*-
 * #%L
 * Soot - a J*va Optimization Framework
 * %%
 * Copyright (C) 1999 Patrice Pominville, Raja Vallee-Rai
 * %%
 * This program 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 2.1 of the
 * License, or (at your option) any later version.
 * 
 * This program 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 General Lesser Public License for more details.
 * 
 * You should have received a copy of the GNU General Lesser Public
 * License along with this program.  If not, see
 * .
 * #L%
 */

import soot.Body;
import soot.Trap;

/**
 * 

* Represents a CFG for a {@link Body} instance where the nodes are {@link Block} instances, and where control flow * associated with exceptions is taken into account. When dividing the {@link Body} into basic blocks, * CompleteBlockGraph assumes that every {@link Unit} covered by a {@link Trap} has the potential to throw an * exception caught by the {@link Trap}. This generally has the effect of separating every covered {@link Unit} into a * separate block. * *

* This implementation of CompleteBlockGraph is included for backwards compatibility, but the graphs it produces * are not necessarily identical to the graphs produced by the implementation of CompleteBlockGraph See the * documentation for {@link CompleteUnitGraph} for details of the incompatibilities. *

*/ public class CompleteBlockGraph extends ExceptionalBlockGraph { public CompleteBlockGraph(Body b) { super(new CompleteUnitGraph(b)); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy