Package edu.cmu.cs.fusion

Source Code of edu.cmu.cs.fusion.SharedAnalysisData

/**
* Copyright (c) 2006-2009 Marwan Abi-Antoun, Jonathan Aldrich, Nels E. Beckman,   
* Kevin Bierhoff, David Dickey, Ciera Jaspan, Thomas LaToza, Gabriel Zenarosa, and others.
*
* This file is part of Crystal.
*
* Crystal 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 3 of the License, or
* (at your option) any later version.
*
* Crystal 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 Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with Crystal.  If not, see <http://www.gnu.org/licenses/>.
*/
package edu.cmu.cs.fusion;

import java.io.IOException;
import java.util.logging.ConsoleHandler;
import java.util.logging.FileHandler;
import java.util.logging.Formatter;
import java.util.logging.Handler;
import java.util.logging.Level;
import java.util.logging.LogRecord;
import java.util.logging.Logger;
import java.util.logging.SimpleFormatter;

import org.eclipse.core.runtime.IProgressMonitor;
import org.eclipse.jdt.core.IJavaProject;
import org.eclipse.jdt.core.JavaModelException;

import edu.cmu.cs.crystal.internal.Crystal;
import edu.cmu.cs.crystal.internal.ShortExceptionFormatter;
import edu.cmu.cs.crystal.internal.ShortFormatter;
import edu.cmu.cs.crystal.internal.StandardAnalysisReporter;
import edu.cmu.cs.crystal.util.TypeHierarchy;
import edu.cmu.cs.crystal.util.typehierarchy.CachedTypeHierarchy;
import edu.cmu.cs.fusion.constraint.FreeVars;

/**
* @author ciera
* @since Crystal 3.4.1
*/
public class SharedAnalysisData {
  static private TypeHierarchy hierarchy;
  static private IJavaProject project;
  static private Logger core;
  static private Logger warn;
  static private boolean setLoggers;
 
  public SharedAnalysisData() {   
    if (!setLoggers) {
      Formatter simpleFormatter = new Formatter() {
        public String format(LogRecord record) {
          return record.getMessage();
        }
      };
     
      //Fix the Crystal loggers so they'll behave as we want.
      Logger crystalLogger = Logger.getLogger(Crystal.class.getName());
      crystalLogger.setLevel(Level.WARNING);
      Handler handler = new ConsoleHandler();
      handler.setFormatter(new ShortExceptionFormatter());
      crystalLogger.addHandler(handler);
      try {
        handler = new FileHandler("%h/crystal.txt");
        handler.setFormatter(new SimpleFormatter());
        crystalLogger.addHandler(handler);
      } catch (SecurityException e) {
        crystalLogger.log(Level.WARNING, "Could not create crystal handler", e.getMessage());
      } catch (IOException e) {
        crystalLogger.log(Level.WARNING, "Could not create crystal handler", e.getMessage());
      }
      crystalLogger.setUseParentHandlers(false);
     
      //Fix the Crystal loggers so they'll behave as we want.
      Logger regLogger = Logger.getLogger(StandardAnalysisReporter.REGRESSION_LOGGER);
      regLogger.setLevel(Level.SEVERE);
      regLogger.addHandler(new ConsoleHandler());
      regLogger.setUseParentHandlers(false);
   

      //The core logger. Should be at warnings only under most circumstances
      core = Logger.getLogger(FusionAnalysis.FUSION_LOGGER);
      core.setLevel(Level.WARNING);
      handler = new ConsoleHandler();
      handler.setFormatter(new ShortExceptionFormatter());
      core.addHandler(handler);
      core.setUseParentHandlers(false);
      try {
        handler = new FileHandler("%h/fusion_core.txt");
        handler.setFormatter(new ShortFormatter());
        core.addHandler(handler);
      } catch (SecurityException e) {
        core.log(Level.WARNING, "Could not create core handler", e.getMessage());
      } catch (IOException e) {
        core.log(Level.WARNING, "Could not create core handler", e.getMessage());
      }


      //The reports logger. Set to info if we want to generate reports.
      warn = Logger.getLogger(FusionAnalysis.REPORTS_LOGGER);
      warn.setLevel(Level.INFO);
      try {
        handler = new FileHandler("%h/fusion_warnings.txt");
        handler.setFormatter(simpleFormatter);
        warn.addHandler(handler);
        warn.setUseParentHandlers(false);
      } catch (SecurityException e) {
        core.log(Level.WARNING, "Could not create warnings handler", e.getMessage());
      } catch (IOException e) {
        core.log(Level.WARNING, "Could not create warnings handler", e.getMessage());
      }

      setLoggers = true;
    }
  }
 

    public void checkForProjectReset(IJavaProject newProject, IProgressMonitor monitor) throws JavaModelException {
    if (project == null || !project.equals(newProject)) {
      //we have a new project. reset the type hierarchy
      if (monitor != null)
        monitor.subTask("Creating new type hierarchy");
      project = newProject;
      hierarchy = new CachedTypeHierarchy(project);
      FreeVars.setHierarchy(hierarchy);
    }
  }
 
  public TypeHierarchy getHierarchy() {
    return hierarchy;
  }

  public boolean existsCommonSubtype(String t1, String t2) {
    return hierarchy.existsCommonSubtype(t1, t2);
  }

  public boolean existsCommonSubtype(String t1, String t2,
      boolean skipCheck1, boolean skipCheck2) {
    return hierarchy.existsCommonSubtype(t1, t2, skipCheck1, skipCheck2);
  }

  public boolean isSubtypeCompatible(String subType, String superType) {
    return hierarchy.isSubtypeCompatible(subType, superType);
  }

}
TOP

Related Classes of edu.cmu.cs.fusion.SharedAnalysisData

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.