/* -*- tab-width: 4 -*-
*
* Electric(tm) VLSI Design System
*
* File: CIFTab.java
*
* Copyright (c) 2004 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.user.dialogs.options;
import com.sun.electric.database.text.Setting;
import com.sun.electric.database.text.TextUtils;
import com.sun.electric.technology.Layer;
import com.sun.electric.technology.Technology;
import com.sun.electric.tool.io.IOTool;
import com.sun.electric.tool.user.dialogs.EDialog;
import com.sun.electric.tool.user.dialogs.PreferencesFrame;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import java.util.Iterator;
import javax.swing.DefaultListModel;
import javax.swing.JList;
import javax.swing.JPanel;
import javax.swing.ListSelectionModel;
import javax.swing.event.DocumentEvent;
import javax.swing.event.DocumentListener;
/**
* Class to handle the "CIF" tab of the Preferences dialog.
*/
public class CIFTab extends PreferencePanel
{
private JList cifLayersList;
private DefaultListModel cifLayersModel;
private boolean changingCIF = false;
private Setting cifOutMimicsDisplaySetting = IOTool.getCIFOutMimicsDisplaySetting();
private Setting cifOutMergesBoxesSetting = IOTool.getCIFOutMergesBoxesSetting();
private Setting cifOutInstantiatesTopLevleSetting = IOTool.getCIFOutInstantiatesTopLevelSetting();
private Setting cifOutScaleFactorSetting = IOTool.getCIFOutScaleFactorSetting();
/** Creates new form CIFTab */
public CIFTab(PreferencesFrame parent, boolean modal)
{
super(parent, modal);
initComponents();
// make all text fields select-all when entered
EDialog.makeTextFieldSelectAllOnTab(cifLayer);
}
/** return the JPanel to use for the user preferences. */
public JPanel getUserPreferencesPanel() { return preferences; }
/** return the JPanel to use for the project preferences. */
public JPanel getProjectPreferencesPanel() { return projSettings; }
/** return the name of this preferences tab. */
public String getName() { return "CIF"; }
/**
* Method called at the start of the dialog.
* Caches current values and displays them in the CIF tab.
*/
public void init()
{
// user preferences
cifInputSquaresWires.setSelected(IOTool.isCIFInSquaresWires());
// project preferences
cifOutputMimicsDisplay.setSelected(getBoolean(cifOutMimicsDisplaySetting));
cifOutputMergesBoxes.setSelected(getBoolean(cifOutMergesBoxesSetting));
cifOutputInstantiatesTopLevel.setSelected(getBoolean(cifOutInstantiatesTopLevleSetting));
cifScale.setText(Integer.toString(getInt(cifOutScaleFactorSetting)));
// build the layers list
cifLayersModel = new DefaultListModel();
cifLayersList = new JList(cifLayersModel);
cifLayersList.setSelectionMode(ListSelectionModel.SINGLE_SELECTION);
cifLayers.setViewportView(cifLayersList);
cifLayersList.clearSelection();
cifLayersList.addMouseListener(new MouseAdapter()
{
public void mouseClicked(MouseEvent evt) { cifClickLayer(); }
});
for(Iterator<Technology> tIt = Technology.getTechnologies(); tIt.hasNext(); )
{
Technology tech = tIt.next();
technologySelection.addItem(tech.getTechName());
}
technologySelection.addActionListener(new ActionListener()
{
public void actionPerformed(ActionEvent evt) { techChanged(); }
});
cifLayer.getDocument().addDocumentListener(new CIFDocumentListener(this));
technologySelection.setSelectedItem(Technology.getCurrent().getTechName());
}
/**
* Method called when the "OK" panel is hit.
* Updates any changed fields in the CIF tab.
*/
public void term()
{
// user preferences
boolean currentValue = cifInputSquaresWires.isSelected();
if (currentValue != IOTool.isCIFInSquaresWires())
IOTool.setCIFInSquaresWires(currentValue);
// project preferences
setBoolean(cifOutMimicsDisplaySetting, cifOutputMimicsDisplay.isSelected());
setBoolean(cifOutMergesBoxesSetting, cifOutputMergesBoxes.isSelected());
setBoolean(cifOutInstantiatesTopLevleSetting, cifOutputInstantiatesTopLevel.isSelected());
setInt(cifOutScaleFactorSetting, TextUtils.atoi(cifScale.getText()));
}
/**
* Method called when the factory reset is requested.
*/
public void reset()
{
// user preferences
if (IOTool.isFactoryCIFInSquaresWires() != IOTool.isCIFInSquaresWires())
IOTool.setCIFInSquaresWires(IOTool.isFactoryCIFInSquaresWires());
}
private void techChanged()
{
String techName = (String)technologySelection.getSelectedItem();
Technology tech = Technology.findTechnology(techName);
if (tech == null) return;
cifLayersModel.clear();
for(Iterator<Layer> it = tech.getLayers(); it.hasNext(); )
{
Layer layer = it.next();
String str = layer.getName();
String cifLayer = getString(layer.getCIFLayerSetting());
if (cifLayer == null) cifLayer = "";
if (cifLayer.length() > 0) str += " (" + cifLayer + ")";
cifLayersModel.addElement(str);
}
cifLayersList.setSelectedIndex(0);
cifClickLayer();
}
/**
* Method called when the user clicks on a layer name in the scrollable list.
*/
private void cifClickLayer()
{
changingCIF = true;
String str = (String)cifLayersList.getSelectedValue();
cifLayer.setText(cifGetLayerName(str));
changingCIF = false;
}
/**
* Method to parse the line in the scrollable list and return the CIF layer name part
* (in parentheses).
*/
private String cifGetLayerName(String str)
{
int openParen = str.indexOf('(');
if (openParen < 0) return "";
int closeParen = str.lastIndexOf(')');
if (closeParen < 0) return "";
String cifLayer = str.substring(openParen+1, closeParen);
return cifLayer;
}
/**
* Method to parse the line in the scrollable list and return the Layer.
*/
private Layer cifGetLayer(String str)
{
String techName = (String)technologySelection.getSelectedItem();
Technology tech = Technology.findTechnology(techName);
if (tech == null) return null;
int openParen = str.indexOf('(');
if (openParen < 0) openParen = str.length()+1;
String layerName = str.substring(0, openParen-1);
Layer layer = tech.findLayer(layerName);
return layer;
}
/**
* Method called when the user types a new layer name into the edit field.
*/
private void cifLayerChanged()
{
if (changingCIF) return;
String str = (String)cifLayersList.getSelectedValue();
Layer layer = cifGetLayer(str);
if (layer == null) return;
String newLine = layer.getName();
String newLayer = cifLayer.getText().trim();
if (newLayer.length() > 0) newLine += " (" + newLayer + ")";
int index = cifLayersList.getSelectedIndex();
cifLayersModel.set(index, newLine);
setString(layer.getCIFLayerSetting(), newLayer);
}
/**
* Class to handle special changes to changes to a CIF layer.
*/
private static class CIFDocumentListener implements DocumentListener
{
CIFTab dialog;
CIFDocumentListener(CIFTab dialog) { this.dialog = dialog; }
public void changedUpdate(DocumentEvent e) { dialog.cifLayerChanged(); }
public void insertUpdate(DocumentEvent e) { dialog.cifLayerChanged(); }
public void removeUpdate(DocumentEvent e) { dialog.cifLayerChanged(); }
}
/** This method is called from within the constructor to
* initialize the form.
* WARNING: Do NOT modify this code. The content of this method is
* always regenerated by the Form Editor.
*/
// <editor-fold defaultstate="collapsed" desc=" Generated Code ">//GEN-BEGIN:initComponents
private void initComponents() {
java.awt.GridBagConstraints gridBagConstraints;
projSettings = new javax.swing.JPanel();
jLabel1 = new javax.swing.JLabel();
cifLayers = new javax.swing.JScrollPane();
cifOutputMimicsDisplay = new javax.swing.JCheckBox();
cifOutputMergesBoxes = new javax.swing.JCheckBox();
cifOutputInstantiatesTopLevel = new javax.swing.JCheckBox();
jLabel2 = new javax.swing.JLabel();
cifLayer = new javax.swing.JTextField();
jPanel2 = new javax.swing.JPanel();
jLabel3 = new javax.swing.JLabel();
technologySelection = new javax.swing.JComboBox();
jLabel4 = new javax.swing.JLabel();
cifScale = new javax.swing.JTextField();
preferences = new javax.swing.JPanel();
cifInputSquaresWires = new javax.swing.JCheckBox();
jSeparator1 = new javax.swing.JSeparator();
getContentPane().setLayout(new java.awt.GridBagLayout());
setTitle("IO Options");
setName("");
addWindowListener(new java.awt.event.WindowAdapter() {
public void windowClosing(java.awt.event.WindowEvent evt) {
closeDialog(evt);
}
});
projSettings.setLayout(new java.awt.GridBagLayout());
jLabel1.setText("CIF Layer:");
gridBagConstraints = new java.awt.GridBagConstraints();
gridBagConstraints.gridx = 2;
gridBagConstraints.gridy = 1;
gridBagConstraints.anchor = java.awt.GridBagConstraints.WEST;
gridBagConstraints.insets = new java.awt.Insets(4, 4, 4, 4);
projSettings.add(jLabel1, gridBagConstraints);
cifLayers.setPreferredSize(new java.awt.Dimension(200, 200));
gridBagConstraints = new java.awt.GridBagConstraints();
gridBagConstraints.gridx = 0;
gridBagConstraints.gridy = 1;
gridBagConstraints.gridwidth = 2;
gridBagConstraints.gridheight = 6;
gridBagConstraints.fill = java.awt.GridBagConstraints.BOTH;
gridBagConstraints.weightx = 1.0;
gridBagConstraints.weighty = 1.0;
gridBagConstraints.insets = new java.awt.Insets(4, 4, 4, 4);
projSettings.add(cifLayers, gridBagConstraints);
cifOutputMimicsDisplay.setText("Output Mimics Display");
gridBagConstraints = new java.awt.GridBagConstraints();
gridBagConstraints.gridx = 2;
gridBagConstraints.gridy = 2;
gridBagConstraints.gridwidth = 3;
gridBagConstraints.anchor = java.awt.GridBagConstraints.WEST;
gridBagConstraints.insets = new java.awt.Insets(4, 4, 4, 4);
projSettings.add(cifOutputMimicsDisplay, gridBagConstraints);
cifOutputMergesBoxes.setText("Output Merges Boxes");
gridBagConstraints = new java.awt.GridBagConstraints();
gridBagConstraints.gridx = 2;
gridBagConstraints.gridy = 3;
gridBagConstraints.gridwidth = 3;
gridBagConstraints.anchor = java.awt.GridBagConstraints.WEST;
gridBagConstraints.insets = new java.awt.Insets(4, 4, 0, 4);
projSettings.add(cifOutputMergesBoxes, gridBagConstraints);
cifOutputInstantiatesTopLevel.setText("Output Instantiates Top Level");
gridBagConstraints = new java.awt.GridBagConstraints();
gridBagConstraints.gridx = 2;
gridBagConstraints.gridy = 5;
gridBagConstraints.gridwidth = 3;
gridBagConstraints.anchor = java.awt.GridBagConstraints.WEST;
gridBagConstraints.insets = new java.awt.Insets(4, 4, 8, 4);
projSettings.add(cifOutputInstantiatesTopLevel, gridBagConstraints);
jLabel2.setText("(time consuming)");
gridBagConstraints = new java.awt.GridBagConstraints();
gridBagConstraints.gridx = 2;
gridBagConstraints.gridy = 4;
gridBagConstraints.gridwidth = 3;
gridBagConstraints.insets = new java.awt.Insets(0, 4, 4, 4);
projSettings.add(jLabel2, gridBagConstraints);
gridBagConstraints = new java.awt.GridBagConstraints();
gridBagConstraints.gridx = 3;
gridBagConstraints.gridy = 1;
gridBagConstraints.gridwidth = 2;
gridBagConstraints.fill = java.awt.GridBagConstraints.HORIZONTAL;
gridBagConstraints.insets = new java.awt.Insets(4, 4, 4, 4);
projSettings.add(cifLayer, gridBagConstraints);
jPanel2.setLayout(new java.awt.GridBagLayout());
gridBagConstraints = new java.awt.GridBagConstraints();
gridBagConstraints.gridx = 1;
gridBagConstraints.gridy = 7;
gridBagConstraints.gridwidth = 3;
gridBagConstraints.fill = java.awt.GridBagConstraints.HORIZONTAL;
projSettings.add(jPanel2, gridBagConstraints);
jLabel3.setText("Technology:");
gridBagConstraints = new java.awt.GridBagConstraints();
gridBagConstraints.gridx = 0;
gridBagConstraints.gridy = 0;
gridBagConstraints.insets = new java.awt.Insets(4, 4, 4, 4);
projSettings.add(jLabel3, gridBagConstraints);
gridBagConstraints = new java.awt.GridBagConstraints();
gridBagConstraints.gridx = 1;
gridBagConstraints.gridy = 0;
gridBagConstraints.fill = java.awt.GridBagConstraints.HORIZONTAL;
gridBagConstraints.insets = new java.awt.Insets(4, 4, 4, 4);
projSettings.add(technologySelection, gridBagConstraints);
jLabel4.setText("Output scale:");
gridBagConstraints = new java.awt.GridBagConstraints();
gridBagConstraints.gridx = 2;
gridBagConstraints.gridy = 6;
gridBagConstraints.anchor = java.awt.GridBagConstraints.WEST;
gridBagConstraints.insets = new java.awt.Insets(4, 4, 4, 4);
projSettings.add(jLabel4, gridBagConstraints);
gridBagConstraints = new java.awt.GridBagConstraints();
gridBagConstraints.gridx = 3;
gridBagConstraints.gridy = 6;
gridBagConstraints.gridwidth = 2;
gridBagConstraints.fill = java.awt.GridBagConstraints.HORIZONTAL;
gridBagConstraints.insets = new java.awt.Insets(4, 4, 4, 4);
projSettings.add(cifScale, gridBagConstraints);
gridBagConstraints = new java.awt.GridBagConstraints();
gridBagConstraints.gridx = 0;
gridBagConstraints.gridy = 2;
getContentPane().add(projSettings, gridBagConstraints);
preferences.setLayout(new java.awt.GridBagLayout());
cifInputSquaresWires.setText("Input Squares Wires");
gridBagConstraints = new java.awt.GridBagConstraints();
gridBagConstraints.gridx = 0;
gridBagConstraints.gridy = 20;
gridBagConstraints.gridwidth = 3;
gridBagConstraints.fill = java.awt.GridBagConstraints.HORIZONTAL;
gridBagConstraints.anchor = java.awt.GridBagConstraints.WEST;
gridBagConstraints.weightx = 1.0;
gridBagConstraints.insets = new java.awt.Insets(2, 4, 4, 4);
preferences.add(cifInputSquaresWires, gridBagConstraints);
gridBagConstraints = new java.awt.GridBagConstraints();
gridBagConstraints.gridx = 0;
gridBagConstraints.gridy = 0;
gridBagConstraints.gridwidth = 3;
gridBagConstraints.fill = java.awt.GridBagConstraints.HORIZONTAL;
getContentPane().add(preferences, gridBagConstraints);
gridBagConstraints = new java.awt.GridBagConstraints();
gridBagConstraints.gridx = 0;
gridBagConstraints.gridy = 1;
gridBagConstraints.fill = java.awt.GridBagConstraints.HORIZONTAL;
getContentPane().add(jSeparator1, gridBagConstraints);
pack();
}// </editor-fold>//GEN-END:initComponents
/** Closes the dialog */
private void closeDialog(java.awt.event.WindowEvent evt)//GEN-FIRST:event_closeDialog
{
setVisible(false);
dispose();
}//GEN-LAST:event_closeDialog
// Variables declaration - do not modify//GEN-BEGIN:variables
private javax.swing.JCheckBox cifInputSquaresWires;
private javax.swing.JTextField cifLayer;
private javax.swing.JScrollPane cifLayers;
private javax.swing.JCheckBox cifOutputInstantiatesTopLevel;
private javax.swing.JCheckBox cifOutputMergesBoxes;
private javax.swing.JCheckBox cifOutputMimicsDisplay;
private javax.swing.JTextField cifScale;
private javax.swing.JLabel jLabel1;
private javax.swing.JLabel jLabel2;
private javax.swing.JLabel jLabel3;
private javax.swing.JLabel jLabel4;
private javax.swing.JPanel jPanel2;
private javax.swing.JSeparator jSeparator1;
private javax.swing.JPanel preferences;
private javax.swing.JPanel projSettings;
private javax.swing.JComboBox technologySelection;
// End of variables declaration//GEN-END:variables
}