/* -*- tab-width: 4 -*-
*
* Electric(tm) VLSI Design System
*
* File: EDIFTab.java
*
* Copyright (c) 2004, Oracle and/or its affiliates. All rights reserved.
*
* 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.tool.io.FileType;
import com.sun.electric.tool.io.IOTool;
import com.sun.electric.tool.user.dialogs.EDialog;
import com.sun.electric.tool.user.dialogs.OpenFile;
import com.sun.electric.util.TextUtils;
import javax.swing.JPanel;
import javax.swing.JTextArea;
/**
* Class to handle the "EDIF" tab of the Preferences dialog.
*/
public class EDIFTab extends PreferencePanel
{
private JTextArea textArea;
/** Creates new form EDIFTab */
public EDIFTab(java.awt.Frame parent, boolean modal)
{
super(parent, modal);
initComponents();
textArea = new JTextArea();
acceptedParamPane.setViewportView(textArea);
// make all text fields select-all when entered
EDialog.makeTextFieldSelectAllOnTab(edifInputScale);
EDialog.makeTextFieldSelectAllOnTab(edifConfigFile);
}
/** return the panel to use for user preferences. */
public JPanel getUserPreferencesPanel() { return edif; }
/** return the name of this preferences tab. */
public String getName() { return "EDIF"; }
/**
* Method called at the start of the dialog.
* Caches current values and displays them in the EDIF tab.
*/
public void init()
{
edifUseSchematicView.setSelected(IOTool.isEDIFUseSchematicView());
edifInputScale.setText(TextUtils.formatDouble(IOTool.getEDIFInputScale()));
edifCadenceCompatibility.setSelected(IOTool.isEDIFCadenceCompatibility());
edifShowArcNames.setSelected(IOTool.isEDIFShowArcNames());
edifShowNodeNames.setSelected(IOTool.isEDIFShowNodeNames());
edifConfigFile.setText(IOTool.getEDIFConfigurationFile());
String ap = IOTool.getEDIFAcceptedParameters();
String [] params = ap.split("/");
textArea.removeAll();
for(int i=0; i<params.length; i++)
textArea.append(params[i] + "\n");
}
/**
* Method called when the "OK" panel is hit.
* Updates any changed fields in the EDIF tab.
*/
public void term()
{
boolean currentBoolean = edifUseSchematicView.isSelected();
if (currentBoolean != IOTool.isEDIFUseSchematicView())
IOTool.setEDIFUseSchematicView(currentBoolean);
double currentInputScale = TextUtils.atof(edifInputScale.getText());
if (currentInputScale != IOTool.getEDIFInputScale())
IOTool.setEDIFInputScale(currentInputScale);
currentBoolean = edifCadenceCompatibility.isSelected();
if (currentBoolean != IOTool.isEDIFCadenceCompatibility())
IOTool.setEDIFCadenceCompatibility(currentBoolean);
currentBoolean = edifShowArcNames.isSelected();
if (currentBoolean != IOTool.isEDIFShowArcNames())
IOTool.setEDIFShowArcNames(currentBoolean);
currentBoolean = edifShowNodeNames.isSelected();
if (currentBoolean != IOTool.isEDIFShowNodeNames())
IOTool.setEDIFShowNodeNames(currentBoolean);
String currentConfigFile = edifConfigFile.getText();
if (!currentConfigFile.equals(IOTool.getEDIFConfigurationFile()))
IOTool.setEDIFConfigurationFile(currentConfigFile);
StringBuffer ap = new StringBuffer();
String allAP = textArea.getText();
String [] params = allAP.split("\n");
for(int i=0; i<params.length; i++)
{
String paramName = params[i].trim();
if (paramName.length() == 0) continue;
if (ap.length() > 0) ap.append("/");
ap.append(paramName);
}
String currentAcceptedParams = ap.toString();
if (!currentAcceptedParams.equals(IOTool.getEDIFAcceptedParameters()))
IOTool.setEDIFAcceptedParameters(currentAcceptedParams);
}
/**
* Method called when the factory reset is requested.
*/
public void reset()
{
if (IOTool.isFactoryEDIFUseSchematicView() != IOTool.isEDIFUseSchematicView())
IOTool.setEDIFUseSchematicView(IOTool.isFactoryEDIFUseSchematicView());
if (IOTool.getFactoryEDIFInputScale() != IOTool.getEDIFInputScale())
IOTool.setEDIFInputScale(IOTool.getFactoryEDIFInputScale());
if (IOTool.isFactoryEDIFCadenceCompatibility() != IOTool.isEDIFCadenceCompatibility())
IOTool.setEDIFCadenceCompatibility(IOTool.isFactoryEDIFCadenceCompatibility());
if (IOTool.isFactoryEDIFShowArcNames() != IOTool.isEDIFShowArcNames())
IOTool.setEDIFShowArcNames(IOTool.isFactoryEDIFShowArcNames());
if (IOTool.isFactoryEDIFShowNodeNames() != IOTool.isEDIFShowNodeNames())
IOTool.setEDIFShowNodeNames(IOTool.isFactoryEDIFShowNodeNames());
if (!IOTool.getFactoryEDIFConfigurationFile().equals(IOTool.getEDIFConfigurationFile()))
IOTool.setEDIFConfigurationFile(IOTool.getFactoryEDIFConfigurationFile());
if (!IOTool.getFactoryEDIFAcceptedParameters().equals(IOTool.getEDIFAcceptedParameters()))
IOTool.setEDIFAcceptedParameters(IOTool.getFactoryEDIFAcceptedParameters());
}
/** 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;
edif = new javax.swing.JPanel();
edifUseSchematicView = new javax.swing.JCheckBox();
jLabel13 = new javax.swing.JLabel();
edifInputScale = new javax.swing.JTextField();
edifCadenceCompatibility = new javax.swing.JCheckBox();
jLabel4 = new javax.swing.JLabel();
configFile = new javax.swing.JPanel();
jLabel3 = new javax.swing.JLabel();
jLabel2 = new javax.swing.JLabel();
edifConfigFile = new javax.swing.JTextField();
edifBrowse = new javax.swing.JButton();
acceptedParameters = new javax.swing.JPanel();
acceptedParamPane = new javax.swing.JScrollPane();
jLabel1 = new javax.swing.JLabel();
jLabel5 = new javax.swing.JLabel();
edifShowArcNames = new javax.swing.JCheckBox();
edifShowNodeNames = new javax.swing.JCheckBox();
setTitle("IO Options");
setName(""); // NOI18N
addWindowListener(new java.awt.event.WindowAdapter() {
public void windowClosing(java.awt.event.WindowEvent evt) {
closeDialog(evt);
}
});
getContentPane().setLayout(new java.awt.GridBagLayout());
edif.setLayout(new java.awt.GridBagLayout());
edifUseSchematicView.setText("Use Schematic View when writing");
gridBagConstraints = new java.awt.GridBagConstraints();
gridBagConstraints.gridx = 0;
gridBagConstraints.gridy = 0;
gridBagConstraints.gridwidth = 3;
gridBagConstraints.anchor = java.awt.GridBagConstraints.WEST;
gridBagConstraints.insets = new java.awt.Insets(4, 4, 2, 4);
edif.add(edifUseSchematicView, gridBagConstraints);
jLabel13.setText("Scale by:");
gridBagConstraints = new java.awt.GridBagConstraints();
gridBagConstraints.gridx = 0;
gridBagConstraints.gridy = 1;
gridBagConstraints.anchor = java.awt.GridBagConstraints.EAST;
gridBagConstraints.insets = new java.awt.Insets(2, 4, 2, 4);
edif.add(jLabel13, gridBagConstraints);
edifInputScale.setColumns(6);
gridBagConstraints = new java.awt.GridBagConstraints();
gridBagConstraints.gridx = 1;
gridBagConstraints.gridy = 1;
gridBagConstraints.anchor = java.awt.GridBagConstraints.WEST;
gridBagConstraints.insets = new java.awt.Insets(2, 4, 2, 4);
edif.add(edifInputScale, gridBagConstraints);
edifCadenceCompatibility.setText("Cadence compatibility");
gridBagConstraints = new java.awt.GridBagConstraints();
gridBagConstraints.gridx = 0;
gridBagConstraints.gridy = 2;
gridBagConstraints.gridwidth = 3;
gridBagConstraints.anchor = java.awt.GridBagConstraints.WEST;
gridBagConstraints.insets = new java.awt.Insets(2, 4, 4, 4);
edif.add(edifCadenceCompatibility, gridBagConstraints);
jLabel4.setText("when reading");
gridBagConstraints = new java.awt.GridBagConstraints();
gridBagConstraints.gridx = 2;
gridBagConstraints.gridy = 1;
gridBagConstraints.anchor = java.awt.GridBagConstraints.WEST;
gridBagConstraints.insets = new java.awt.Insets(2, 4, 2, 4);
edif.add(jLabel4, gridBagConstraints);
configFile.setBorder(javax.swing.BorderFactory.createTitledBorder("Configuration File"));
configFile.setLayout(new java.awt.GridBagLayout());
jLabel3.setText("EDIF reading and writing.");
gridBagConstraints = new java.awt.GridBagConstraints();
gridBagConstraints.gridx = 0;
gridBagConstraints.gridy = 1;
gridBagConstraints.anchor = java.awt.GridBagConstraints.WEST;
gridBagConstraints.insets = new java.awt.Insets(0, 4, 4, 4);
configFile.add(jLabel3, gridBagConstraints);
jLabel2.setText("The configuration file provides overrides for controlling");
gridBagConstraints = new java.awt.GridBagConstraints();
gridBagConstraints.gridx = 0;
gridBagConstraints.gridy = 0;
gridBagConstraints.gridwidth = 2;
gridBagConstraints.anchor = java.awt.GridBagConstraints.WEST;
gridBagConstraints.insets = new java.awt.Insets(4, 4, 0, 4);
configFile.add(jLabel2, gridBagConstraints);
edifConfigFile.setMinimumSize(new java.awt.Dimension(200, 20));
edifConfigFile.setPreferredSize(new java.awt.Dimension(200, 20));
gridBagConstraints = new java.awt.GridBagConstraints();
gridBagConstraints.gridx = 0;
gridBagConstraints.gridy = 2;
gridBagConstraints.gridwidth = 2;
gridBagConstraints.fill = java.awt.GridBagConstraints.BOTH;
gridBagConstraints.weightx = 1.0;
gridBagConstraints.insets = new java.awt.Insets(1, 4, 4, 4);
configFile.add(edifConfigFile, gridBagConstraints);
edifBrowse.setText("Browse...");
edifBrowse.addActionListener(new java.awt.event.ActionListener() {
public void actionPerformed(java.awt.event.ActionEvent evt) {
edifBrowseActionPerformed(evt);
}
});
gridBagConstraints = new java.awt.GridBagConstraints();
gridBagConstraints.gridx = 1;
gridBagConstraints.gridy = 1;
gridBagConstraints.anchor = java.awt.GridBagConstraints.WEST;
gridBagConstraints.insets = new java.awt.Insets(0, 4, 0, 4);
configFile.add(edifBrowse, gridBagConstraints);
gridBagConstraints = new java.awt.GridBagConstraints();
gridBagConstraints.gridx = 0;
gridBagConstraints.gridy = 6;
gridBagConstraints.gridwidth = 3;
gridBagConstraints.fill = java.awt.GridBagConstraints.HORIZONTAL;
gridBagConstraints.weightx = 1.0;
gridBagConstraints.insets = new java.awt.Insets(2, 0, 0, 0);
edif.add(configFile, gridBagConstraints);
acceptedParameters.setBorder(javax.swing.BorderFactory.createTitledBorder("Accepted Parameters"));
acceptedParameters.setLayout(new java.awt.GridBagLayout());
acceptedParamPane.setMinimumSize(new java.awt.Dimension(150, 100));
acceptedParamPane.setPreferredSize(new java.awt.Dimension(150, 100));
gridBagConstraints = new java.awt.GridBagConstraints();
gridBagConstraints.gridx = 0;
gridBagConstraints.gridy = 2;
gridBagConstraints.fill = java.awt.GridBagConstraints.BOTH;
gridBagConstraints.weightx = 1.0;
gridBagConstraints.weighty = 1.0;
gridBagConstraints.insets = new java.awt.Insets(0, 0, 2, 0);
acceptedParameters.add(acceptedParamPane, gridBagConstraints);
jLabel1.setText("Type parameter names (one per line)");
gridBagConstraints = new java.awt.GridBagConstraints();
gridBagConstraints.gridx = 0;
gridBagConstraints.gridy = 0;
gridBagConstraints.anchor = java.awt.GridBagConstraints.WEST;
gridBagConstraints.insets = new java.awt.Insets(0, 2, 0, 0);
acceptedParameters.add(jLabel1, gridBagConstraints);
jLabel5.setText("that will be placed on nodes when reading EDIF");
gridBagConstraints = new java.awt.GridBagConstraints();
gridBagConstraints.gridx = 0;
gridBagConstraints.gridy = 1;
gridBagConstraints.anchor = java.awt.GridBagConstraints.WEST;
gridBagConstraints.insets = new java.awt.Insets(0, 8, 4, 0);
acceptedParameters.add(jLabel5, gridBagConstraints);
gridBagConstraints = new java.awt.GridBagConstraints();
gridBagConstraints.gridx = 0;
gridBagConstraints.gridy = 5;
gridBagConstraints.gridwidth = 3;
gridBagConstraints.fill = java.awt.GridBagConstraints.BOTH;
gridBagConstraints.weightx = 1.0;
gridBagConstraints.weighty = 1.0;
edif.add(acceptedParameters, gridBagConstraints);
edifShowArcNames.setText("Show arc names");
gridBagConstraints = new java.awt.GridBagConstraints();
gridBagConstraints.gridx = 0;
gridBagConstraints.gridy = 3;
gridBagConstraints.gridwidth = 3;
gridBagConstraints.anchor = java.awt.GridBagConstraints.WEST;
gridBagConstraints.insets = new java.awt.Insets(2, 4, 2, 4);
edif.add(edifShowArcNames, gridBagConstraints);
edifShowNodeNames.setText("Show node names");
gridBagConstraints = new java.awt.GridBagConstraints();
gridBagConstraints.gridx = 0;
gridBagConstraints.gridy = 4;
gridBagConstraints.gridwidth = 3;
gridBagConstraints.anchor = java.awt.GridBagConstraints.WEST;
gridBagConstraints.insets = new java.awt.Insets(2, 4, 4, 4);
edif.add(edifShowNodeNames, gridBagConstraints);
gridBagConstraints = new java.awt.GridBagConstraints();
gridBagConstraints.weightx = 1.0;
getContentPane().add(edif, gridBagConstraints);
pack();
}// </editor-fold>//GEN-END:initComponents
private void edifBrowseActionPerformed(java.awt.event.ActionEvent evt)//GEN-FIRST:event_edifBrowseActionPerformed
{//GEN-HEADEREND:event_edifBrowseActionPerformed
String fileName = OpenFile.chooseInputFile(FileType.ANY, null);
if (fileName == null) return;
edifConfigFile.setText(fileName);
}//GEN-LAST:event_edifBrowseActionPerformed
/** 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.JScrollPane acceptedParamPane;
private javax.swing.JPanel acceptedParameters;
private javax.swing.JPanel configFile;
private javax.swing.JPanel edif;
private javax.swing.JButton edifBrowse;
private javax.swing.JCheckBox edifCadenceCompatibility;
private javax.swing.JTextField edifConfigFile;
private javax.swing.JTextField edifInputScale;
private javax.swing.JCheckBox edifShowArcNames;
private javax.swing.JCheckBox edifShowNodeNames;
private javax.swing.JCheckBox edifUseSchematicView;
private javax.swing.JLabel jLabel1;
private javax.swing.JLabel jLabel13;
private javax.swing.JLabel jLabel2;
private javax.swing.JLabel jLabel3;
private javax.swing.JLabel jLabel4;
private javax.swing.JLabel jLabel5;
// End of variables declaration//GEN-END:variables
}