package com.sun.electric.tool.generator.flag; import java.lang.reflect.Constructor; import com.sun.electric.database.hierarchy.Cell; import com.sun.electric.database.hierarchy.Library; import com.sun.electric.technology.Technology; import com.sun.electric.tool.Job; import com.sun.electric.tool.routing.SeaOfGates; public class Flag { private static void prln(String s) {Utils.prln(s);} private void doEverything(Cell schCell, Job flagJob, SeaOfGates.SeaOfGatesOptions prefs) { FlagAnnotations ann = new FlagAnnotations(schCell); if (!ann.isAutoGen()) { prln("Cell: "+schCell.libDescribe()+" has no autoGen annotation"); return; } String className = ann.getAutoGenClassName(); Class layGenClass = null; try { layGenClass = Class.forName(className); } catch (ClassNotFoundException e) { prln("Can't find layout generator class: "+className); return; } Constructor<FlagDesign> layGenConstructor = null; try { layGenConstructor = layGenClass.getConstructor(FlagConstructorData.class); } catch (NoSuchMethodException e) { prln("Layout generator class: "+className+ " has no contructor that takes arguments: (FlagConstructorData)"); return; } Library autoLib = schCell.getLibrary(); String groupName = schCell.getCellName().getName(); prln("Generate layout for Cell: "+groupName); prln("Using layout generator: "+className); Cell layCell = Cell.newInstance(autoLib, groupName+"{lay}"); layCell.setTechnology(Technology.getCMOS90Technology()); try { layGenConstructor.newInstance( new FlagConstructorData(layCell, schCell, flagJob, prefs)); } catch (Throwable th) { prln("Layout generator: "+className+" threw Exception: "+th.getMessage()); prln("Printing stack trace:"); Utils.printStackTrace(th); th.printStackTrace(); } } public Flag(Cell schCell, Job flagJob, SeaOfGates.SeaOfGatesOptions prefs) { try { doEverything(schCell, flagJob, prefs); } catch (Throwable th) { prln("Oh my! Something went wrong."); Utils.printStackTrace(th); th.printStackTrace(); } } }