⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 pie.java

📁 The ElectricTM VLSI Design System is an open-source Electronic Design Automation (EDA) system that c
💻 JAVA
字号:
/* -*- tab-width: 4 -*- * * Electric(tm) VLSI Design System * * File: Pie.java * * Copyright (c) 2005 Sun Microsystems and Static Free Software * * Electric(tm) is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 3 of the License, or * (at your option) any later version. * * Electric(tm) 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 Public License for more details. * * You should have received a copy of the GNU General Public License * along with Electric(tm); see the file COPYING.  If not, write to * the Free Software Foundation, Inc., 59 Temple Place, Suite 330, * Boston, Mass 02111-1307, USA. */package com.sun.electric.tool.ncc;import com.sun.electric.database.hierarchy.Cell;import com.sun.electric.database.variable.VarContext;import com.sun.electric.tool.generator.layout.LayoutLib;import com.sun.electric.tool.ncc.result.NccResults;import java.lang.reflect.Constructor;import java.lang.reflect.Method;/** Reflective interface to Port Interchange Experiment. This allows us to compile Electric * without the plugin: com.sun.electric.plugins.pie */public class Pie {	private Class pieNccJobClass;	private Constructor pieNccJobConstructor;	private Method pieNccCompare;	// singleton	private static final Pie pie = new Pie();		private Pie() {// PIE is gone - SMR//		try {//			pieNccJobClass = Class.forName("com.sun.electric.plugins.pie.NccJob");//			pieNccJobConstructor = pieNccJobClass.getConstructor(new Class[] {Integer.TYPE});//			Class pieNccClass = Class.forName("com.sun.electric.plugins.pie.Ncc");//			pieNccClass.getMethod("compare", new Class[] {Cell.class, VarContext.class, //					                                      Cell.class, VarContext.class,//					                                      NccOptions.class, PIEOptions.class});//		} catch (Throwable e) {//			pieNccJobClass = null;//			pieNccJobConstructor = null;//		}	}		private static void prln(String msg) {System.out.println(msg);}		public static boolean hasPie() {		return pie.pieNccJobClass!=null;	}	public static void invokePieNcc(int numWind) {		LayoutLib.error(!hasPie(), "trying to invoke non-existant PIE");		try {			pie.pieNccJobConstructor.newInstance(new Integer(numWind));		} catch (Throwable e) {			prln("Invocation of pie NccJob threw Throwable: "+e);			e.printStackTrace();		}	}	public static NccResults invokePieNccCompare(Cell c1, VarContext v1,			                                     Cell c2, VarContext v2,			                                     NccOptions opt, PIEOptions pOpt) {		LayoutLib.error(!hasPie(), "trying to invoke non-existant PIE");		NccResults results = null;		try {			results = (NccResults)			  pie.pieNccCompare.invoke(null, new Object[] {c1, v1, c2, v2, opt, pOpt});		} catch (Throwable e) {			prln("Invocation of pie Ncc.compare threw Throwable: "+e);			e.printStackTrace();		}		return results;	}}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -