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

soot.dava.toolkits.base.finders.SwitchNode Maven / Gradle / Ivy

package soot.dava.toolkits.base.finders;

/*-
 * #%L
 * Soot - a J*va Optimization Framework
 * %%
 * Copyright (C) 2003 Jerome Miecznikowski
 * %%
 * 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.HashMap;
import java.util.Iterator;
import java.util.LinkedList;
import java.util.List;
import java.util.TreeSet;

import soot.dava.internal.asg.AugmentedStmt;
import soot.util.IterableSet;

public class SwitchNode implements Comparable {
  private final LinkedList preds, succs;
  private AugmentedStmt as;
  private int score;
  private TreeSet indexSet;
  private IterableSet body;

  public SwitchNode(AugmentedStmt as, TreeSet indexSet, IterableSet body) {
    this.as = as;
    this.indexSet = indexSet;
    this.body = body;

    preds = new LinkedList();
    succs = new LinkedList();

    score = -1;
  }

  public int get_Score() {
    if (score == -1) {
      score = 0;

      if (preds.size() < 2) {

        Iterator sit = succs.iterator();
        while (sit.hasNext()) {
          SwitchNode ssn = (SwitchNode) sit.next();

          int curScore = ssn.get_Score();
          if (score < curScore) {
            score = curScore;
          }
        }

        score++;
      }
    }

    return score;
  }

  public List get_Preds() {
    return preds;
  }

  public List get_Succs() {
    return succs;
  }

  public AugmentedStmt get_AugStmt() {
    return as;
  }

  public TreeSet get_IndexSet() {
    return new TreeSet(indexSet);
  }

  public IterableSet get_Body() {
    return body;
  }

  public SwitchNode reset() {
    preds.clear();
    succs.clear();

    return this;
  }

  public void setup_Graph(HashMap binding) {
    Iterator rit = ((AugmentedStmt) as.bsuccs.get(0)).get_Reachers().iterator();
    while (rit.hasNext()) {
      SwitchNode pred = binding.get(rit.next());

      if (pred != null) {
        if (preds.contains(pred) == false) {
          preds.add(pred);
        }

        if (pred.succs.contains(this) == false) {
          pred.succs.add(this);
        }
      }
    }
  }

  /*
   * Can compare to an Integer, a String, a set of Indices, and another SwitchNode.
   */

  public int compareTo(Object o) {
    if (o == this) {
      return 0;
    }

    if (indexSet.last() instanceof String) {
      return 1;
    }

    if (o instanceof String) {
      return -1;
    }

    if (o instanceof Integer) {
      return ((Integer) indexSet.last()).intValue() - ((Integer) o).intValue();
    }

    if (o instanceof TreeSet) {
      TreeSet other = (TreeSet) o;

      if (other.last() instanceof String) {
        return -1;
      }

      return ((Integer) indexSet.last()).intValue() - ((Integer) other.last()).intValue();
    }

    SwitchNode other = (SwitchNode) o;

    if (other.indexSet.last() instanceof String) {
      return -1;
    }

    return ((Integer) indexSet.last()).intValue() - ((Integer) other.indexSet.last()).intValue();
  }
}