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

soot.dava.internal.SET.SETBasicBlock Maven / Gradle / Ivy

package soot.dava.internal.SET;

/*-
 * #%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.Iterator;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import soot.G;
import soot.util.IterableSet;

public class SETBasicBlock implements Comparable {
  private static final Logger logger = LoggerFactory.getLogger(SETBasicBlock.class);

  private SETNode entryNode, exitNode;
  private final IterableSet predecessors, successors, body;
  private int priority;

  public SETBasicBlock() {
    predecessors = new IterableSet();
    successors = new IterableSet();
    body = new IterableSet();

    entryNode = exitNode = null;
    priority = -1;
  }

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

    SETBasicBlock other = (SETBasicBlock) o;

    int difference = other.get_Priority() - get_Priority(); // major sorting order ... _descending_
    if (difference == 0) {
      difference = 1; // but it doesn't matter.
    }

    return difference;
  }

  private int get_Priority() {
    if (priority == -1) {
      priority = 0;

      if (predecessors.size() == 1) {
        Iterator sit = successors.iterator();

        while (sit.hasNext()) {
          int sucScore = ((SETBasicBlock) sit.next()).get_Priority();

          if (sucScore > priority) {
            priority = sucScore;
          }
        }

        priority++;
      }
    }

    return priority;
  }

  /*
   * adds must be done in order such that the entry node is done first and the exit is done last.
   */

  public void add(SETNode sn) {
    if (body.isEmpty()) {
      entryNode = sn;
    }

    body.add(sn);
    G.v().SETBasicBlock_binding.put(sn, this);

    exitNode = sn;
  }

  public SETNode get_EntryNode() {
    return entryNode;
  }

  public SETNode get_ExitNode() {
    return exitNode;
  }

  public IterableSet get_Predecessors() {
    return predecessors;
  }

  public IterableSet get_Successors() {
    return successors;
  }

  public IterableSet get_Body() {
    return body;
  }

  public static SETBasicBlock get_SETBasicBlock(SETNode o) {
    return G.v().SETBasicBlock_binding.get(o);
  }

  public void printSig() {
    Iterator it = body.iterator();
    while (it.hasNext()) {
      ((SETNode) it.next()).dump();
    }
  }

  public void dump() {
    printSig();
    logger.debug("" + "=== preds ===");

    Iterator it = predecessors.iterator();
    while (it.hasNext()) {
      ((SETBasicBlock) it.next()).printSig();
    }

    logger.debug("" + "=== succs ===");

    it = successors.iterator();
    while (it.hasNext()) {
      ((SETBasicBlock) it.next()).printSig();
    }
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy