Skip to content
Snippets Groups Projects
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();
	} */ 

	
}