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

soot.jbco.jimpleTransformations.New2InitFlowAnalysis Maven / Gradle / Ivy

package soot.jbco.jimpleTransformations;

/*-
 * #%L
 * Soot - a J*va Optimization Framework
 * %%
 * Copyright (C) 1997 - 1999 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.Local;
import soot.Unit;
import soot.Value;
import soot.ValueBox;
import soot.jimple.DefinitionStmt;
import soot.jimple.NewExpr;
import soot.toolkits.graph.DirectedGraph;
import soot.toolkits.scalar.ArraySparseSet;
import soot.toolkits.scalar.BackwardFlowAnalysis;
import soot.toolkits.scalar.FlowSet;

/**
 * @author Michael Batchelder
 *
 *         Created on 10-Jul-2006
 */
public class New2InitFlowAnalysis extends BackwardFlowAnalysis {

  FlowSet emptySet = new ArraySparseSet();

  public New2InitFlowAnalysis(DirectedGraph graph) {
    super(graph);

    doAnalysis();
  }

  @Override
  protected void flowThrough(FlowSet in, Unit d, FlowSet out) {
    in.copy(out);

    if (d instanceof DefinitionStmt) {
      DefinitionStmt ds = (DefinitionStmt) d;
      if (ds.getRightOp() instanceof NewExpr) {
        Value v = ds.getLeftOp();
        if (v instanceof Local && in.contains(v)) {
          out.remove(v);
        }
      }
    } else {
      for (ValueBox useBox : d.getUseBoxes()) {
        Value v = useBox.getValue();
        if (v instanceof Local) {
          out.add(v);
        }
      }
    }
    /*
     * else if (d instanceof InvokeStmt) { InvokeExpr ie = ((InvokeStmt)d).getInvokeExpr(); if (ie instanceof
     * SpecialInvokeExpr) { Value v = ((SpecialInvokeExpr)ie).getBase(); if (v instanceof Local && !inf.contains(v))
     * outf.add(v); } }
     */
  }

  @Override
  protected FlowSet newInitialFlow() {
    return emptySet.clone();
  }

  @Override
  protected FlowSet entryInitialFlow() {
    return emptySet.clone();
  }

  @Override
  protected void merge(FlowSet in1, FlowSet in2, FlowSet out) {
    in1.union(in2, out);
  }

  @Override
  protected void copy(FlowSet source, FlowSet dest) {
    source.copy(dest);
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy