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

soot.jimple.toolkits.scalar.SlowAvailableExpressions Maven / Gradle / Ivy

There is a newer version: 4.6.0
Show newest version
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