-
Minh Hiep Pham authoredMinh Hiep Pham authored
JDialogADDCPUNode.java 8.77 KiB
/* Copyright or (C) or Copr. GET / ENST, Telecom-Paris, Ludovic Apvrille
*
* ludovic.apvrille AT enst.fr
*
* This software is a computer program whose purpose is to allow the
* edition of TURTLE analysis, design and deployment diagrams, to
* allow the generation of RT-LOTOS or Java code from this diagram,
* and at last to allow the analysis of formal validation traces
* obtained from external tools, e.g. RTL from LAAS-CNRS and CADP
* from INRIA Rhone-Alpes.
*
* This software is governed by the CeCILL license under French law and
* abiding by the rules of distribution of free software. You can use,
* modify and/ or redistribute the software under the terms of the CeCILL
* license as circulated by CEA, CNRS and INRIA at the following URL
* "http://www.cecill.info".
*
* As a counterpart to the access to the source code and rights to copy,
* modify and redistribute granted by the license, users are provided only
* with a limited warranty and the software's author, the holder of the
* economic rights, and the successive licensors have only limited
* liability.
*
* In this respect, the user's attention is drawn to the risks associated
* with loading, using, modifying and/or developing or reproducing the
* software by the user in light of its specific status of free software,
* that may mean that it is complicated to manipulate, and that also
* therefore means that it is reserved for developers and experienced
* professionals having in-depth computer knowledge. Users are therefore
* encouraged to load and test the software's suitability as regards their
* requirements in conditions enabling the security of their systems and/or
* data to be ensured and, more generally, to use and operate it in the
* same conditions as regards security.
*
* The fact that you are presently reading this means that you have had
* knowledge of the CeCILL license and that you accept its terms.
*/
package ui.window;
import ui.util.IconManager;
import ui.avatardd.ADDCPUNode;
import javax.swing.*;
import java.awt.*;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
//import javax.swing.event.*;
//import java.util.*;
/**
* Class JDialogADDCPUNode
* Dialog for managing attributes of cpu nodes in ADD
* Creation: 02/07/2014
* @version 1.0 02/07/2014
* @author Ludovic APVRILLE
*/
public class JDialogADDCPUNode extends JDialogBase implements ActionListener {
private static String[] tracemodeTab = {"VCI logger"};
private boolean regularClose;
private JPanel panel2;
private Frame frame;
private ADDCPUNode node;
protected JComboBox<String> tracemode;
private static int selectedTracemode = 0;
// Panel1
protected JTextField nodeName;
// Panel2
protected JTextField nbOfIrq, iCacheWays, iCacheSets, iCacheWords, dCacheWays, dCacheSets, dCacheWords;
protected JTextField index;
protected JTextField cluster_index;
protected JTextField monitored;
/* Creates new form */
public JDialogADDCPUNode(Frame _frame, String _title, ADDCPUNode _node) {
super(_frame, _title, true);
frame = _frame;
node = _node;
initComponents();
myInitComponents();
pack();
}
private void myInitComponents() {
}
private void initComponents() {
Container c = getContentPane();
GridBagLayout gridbag0 = new GridBagLayout();
GridBagLayout gridbag1 = new GridBagLayout();
GridBagLayout gridbag2 = new GridBagLayout();
GridBagConstraints c0 = new GridBagConstraints();
//GridBagConstraints c1 = new GridBagConstraints();
GridBagConstraints c2 = new GridBagConstraints();
setFont(new Font("Helvetica", Font.PLAIN, 14));
c.setLayout(gridbag0);
setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE);
panel2 = new JPanel();
panel2.setLayout(gridbag2);
panel2.setBorder(new javax.swing.border.TitledBorder("CPU attributes"));
panel2.setPreferredSize(new Dimension(400, 300));
c2.gridwidth = 1;
c2.gridheight = 1;
c2.weighty = 1.0;
c2.weightx = 1.0;
c2.fill = GridBagConstraints.HORIZONTAL;
panel2.add(new JLabel("CPU name:"), c2);
c2.gridwidth = GridBagConstraints.REMAINDER; //end row
nodeName = new JTextField(node.getNodeName(), 30);
nodeName.setEditable(true);
nodeName.setFont(new Font("times", Font.PLAIN, 12));
panel2.add(nodeName, c2);
c2.gridwidth = 1;
c2.gridheight = 1;
c2.weighty = 1.0;
c2.weightx = 1.0;
c2.fill = GridBagConstraints.HORIZONTAL;
c2.gridwidth = 1;
panel2.add(new JLabel("Nb Of IRQs :"), c2);
c2.gridwidth = GridBagConstraints.REMAINDER; //end row
nbOfIrq = new JTextField(""+node.getNbOfIRQs(), 15);
panel2.add(nbOfIrq, c2);
c2.gridwidth = 1;
panel2.add(new JLabel("Nb of inst. cache ways:"), c2);
c2.gridwidth = GridBagConstraints.REMAINDER; //end row
iCacheWays = new JTextField(""+node.getICacheWays(), 15);
panel2.add(iCacheWays, c2);
c2.gridwidth = 1;
panel2.add(new JLabel("Nb of inst. cache sets:"), c2);
c2.gridwidth = GridBagConstraints.REMAINDER; //end row
iCacheSets = new JTextField(""+node.getICacheSets(), 15);
panel2.add(iCacheSets, c2);
c2.gridwidth = 1;
panel2.add(new JLabel("Nb of inst. cache words:"), c2);
c2.gridwidth = GridBagConstraints.REMAINDER; //end row
iCacheWords = new JTextField(""+node.getICacheWords(), 15);
panel2.add(iCacheWords, c2);
c2.gridwidth = 1;
panel2.add(new JLabel("Nb of data cache ways:"), c2);
c2.gridwidth = GridBagConstraints.REMAINDER; //end row
dCacheWays = new JTextField(""+node.getDCacheWays(), 15);
panel2.add(dCacheWays, c2);
c2.gridwidth = 1;
panel2.add(new JLabel("Nb of data cache sets:"), c2);
c2.gridwidth = GridBagConstraints.REMAINDER; //end row
dCacheSets = new JTextField(""+node.getDCacheSets(), 15);
panel2.add(dCacheSets, c2);
c2.gridwidth = 1;
panel2.add(new JLabel("Nb of data cache words:"), c2);
c2.gridwidth = GridBagConstraints.REMAINDER; //end row
dCacheWords = new JTextField(""+node.getDCacheWords(), 15);
panel2.add(dCacheWords, c2);
c2.gridwidth = 1;
panel2.add(new JLabel("Index:"), c2);//DG 2.7.
c2.gridwidth = GridBagConstraints.REMAINDER; //end row
index = new JTextField(""+node.getIndex(), 15);
panel2.add(index, c2);
c2.gridwidth = 1;
panel2.add(new JLabel("Cluster Index:"), c2);//DG 2.7.
c2.gridwidth = GridBagConstraints.REMAINDER; //end row
cluster_index = new JTextField(""+node.getIndex(), 15);
panel2.add(cluster_index, c2);
c2.gridwidth = 1;
panel2.add(new JLabel("Monitored:"), c2);
//c2.gridwidth = GridBagConstraints.REMAINDER; //end row
//monitored = new JTextField(""+node.getMonitored(), 15);//DG 19.04.
tracemode = new JComboBox<>(tracemodeTab);
tracemode.setSelectedIndex(selectedTracemode);
tracemode.addActionListener(this);
panel2.add(tracemode, c2);
/*c2.gridwidth = 1;
panel2.add(new JLabel("Clock ratio:"), c2);
c2.gridwidth = GridBagConstraints.REMAINDER; //end row
clockRatio = new JTextField(""+node.getClockRatio(), 15);
panel2.add(clockRatio, c2);*/
// main panel;
c0.gridheight = 10;
c0.weighty = 1.0;
c0.weightx = 1.0;
c0.gridwidth = GridBagConstraints.REMAINDER; //end row
c.add(panel2, c0);
c0.gridwidth = 1;
c0.gridheight = 1;
c0.fill = GridBagConstraints.HORIZONTAL;
initButtons(c0, c, this);
}
public void actionPerformed(ActionEvent evt) {
/* if (evt.getSource() == typeBox) {
boolean b = ((Boolean)(initValues.elementAt(typeBox.getSelectedIndex()))).booleanValue();
initialValue.setEnabled(b);
return;
}*/
if (evt.getSource() == tracemode) {
selectedTracemode = tracemode.getSelectedIndex();
}
String command = evt.getActionCommand();
// Compare the action command to the known actions.
if (command.equals("Save and Close")) {
closeDialog();
} else if (command.equals("Cancel")) {
cancelDialog();
}
}
public void closeDialog() {
regularClose = true;
dispose();
}
public void cancelDialog() {
dispose();
}
public boolean isRegularClose() {
return regularClose;
}
public String getNodeName() {
return nodeName.getText();
}
public String getNbOFIRQ() {
return nbOfIrq.getText();
}
public String getICacheWays() {
return iCacheWays.getText();
}
public String getICacheSets() {
return iCacheSets.getText();
}
public String getICacheWords() {
return iCacheWords.getText();
}
public String getDCacheWays() {
return dCacheWays.getText();
}
public String getDCacheSets() {
return dCacheSets.getText();
}
public String getDCacheWords() {
return dCacheWords.getText();
}
public String getIndex() {
return index.getText();
}
public int getMonitored() {
//return tracemodeTab[tracemode.getSelectedIndex()];
return tracemode.getSelectedIndex();
//return monitored.getText();
}
/*public String getClockRatio(){
return clockRatio.getText();
} */
}