![JAR search and dependency download from the Maven repository](/logo.png)
soot.jimple.toolkits.scalar.SlowAvailableExpressions Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of soot Show documentation
Show all versions of soot Show documentation
A Java Optimization Framework
package soot.jimple.toolkits.scalar;
/*-
* #%L
* Soot - a J*va Optimization Framework
* %%
* Copyright (C) 2000 Patrick Lam
* %%
* 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 java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import soot.Body;
import soot.EquivalentValue;
import soot.Unit;
import soot.Value;
import soot.jimple.AssignStmt;
import soot.jimple.Stmt;
import soot.toolkits.graph.ExceptionalUnitGraphFactory;
import soot.toolkits.scalar.UnitValueBoxPair;
import soot.util.Chain;
import soot.util.HashChain;
/**
* Provides an user-interface for the AvailableExpressionsAnalysis class. Returns, for each statement, the list of
* expressions available before and after it.
*/
public class SlowAvailableExpressions implements AvailableExpressions {
protected final Map> unitToPairsAfter;
protected final Map> unitToPairsBefore;
protected final Map> unitToEquivsAfter;
protected final Map> unitToEquivsBefore;
/** Wrapper for SlowAvailableExpressionsAnalysis. */
public SlowAvailableExpressions(Body b) {
final Chain units = b.getUnits();
this.unitToPairsAfter = new HashMap>(units.size() * 2 + 1, 0.7f);
this.unitToPairsBefore = new HashMap>(units.size() * 2 + 1, 0.7f);
this.unitToEquivsAfter = new HashMap>(units.size() * 2 + 1, 0.7f);
this.unitToEquivsBefore = new HashMap>(units.size() * 2 + 1, 0.7f);
SlowAvailableExpressionsAnalysis analysis
= new SlowAvailableExpressionsAnalysis(ExceptionalUnitGraphFactory.createExceptionalUnitGraph(b));
for (Unit s : units) {
{
List pairsBefore = new ArrayList();
Chain equivsBefore = new HashChain();
for (Value v : analysis.getFlowBefore(s)) {
Stmt containingStmt = analysis.rhsToContainingStmt.get(v);
pairsBefore.add(new UnitValueBoxPair(containingStmt, ((AssignStmt) containingStmt).getRightOpBox()));
EquivalentValue ev = new EquivalentValue(v);
if (!equivsBefore.contains(ev)) {
equivsBefore.add(ev);
}
}
unitToPairsBefore.put(s, pairsBefore);
unitToEquivsBefore.put(s, equivsBefore);
}
{
List pairsAfter = new ArrayList();
Chain equivsAfter = new HashChain();
for (Value v : analysis.getFlowAfter(s)) {
Stmt containingStmt = analysis.rhsToContainingStmt.get(v);
pairsAfter.add(new UnitValueBoxPair(containingStmt, ((AssignStmt) containingStmt).getRightOpBox()));
EquivalentValue ev = new EquivalentValue(v);
if (!equivsAfter.contains(ev)) {
equivsAfter.add(ev);
}
}
unitToPairsAfter.put(s, pairsAfter);
unitToEquivsAfter.put(s, equivsAfter);
}
}
}
/** Returns a List containing the UnitValueBox pairs corresponding to expressions available before u. */
@Override
public List getAvailablePairsBefore(Unit u) {
return unitToPairsBefore.get(u);
}
/** Returns a List containing the UnitValueBox pairs corresponding to expressions available after u. */
@Override
public List getAvailablePairsAfter(Unit u) {
return unitToPairsAfter.get(u);
}
/** Returns a Chain containing the EquivalentValue objects corresponding to expressions available before u. */
@Override
public Chain getAvailableEquivsBefore(Unit u) {
return unitToEquivsBefore.get(u);
}
/** Returns a Chain containing the EquivalentValue objects corresponding to expressions available after u. */
@Override
public Chain getAvailableEquivsAfter(Unit u) {
return unitToEquivsAfter.get(u);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy