**/\r
package org.tianocore.frameworkwizard.module.ui;\r
\r
+import java.awt.Dimension;\r
import java.awt.event.ActionEvent;\r
import java.awt.event.ComponentEvent;\r
-import java.awt.event.ItemEvent;\r
import java.awt.event.ItemListener;\r
+import java.awt.event.MouseEvent;\r
import java.util.Vector;\r
\r
import javax.swing.JButton;\r
-import javax.swing.JComboBox;\r
-import javax.swing.JLabel;\r
import javax.swing.JPanel;\r
import javax.swing.JScrollPane;\r
-import javax.swing.JTextArea;\r
-import javax.swing.JTextField;\r
+import javax.swing.JTable;\r
+import javax.swing.ListSelectionModel;\r
+import javax.swing.event.ListSelectionEvent;\r
\r
import org.tianocore.ExternsDocument;\r
-import org.tianocore.PcdDriverTypes;\r
import org.tianocore.ExternsDocument.Externs;\r
import org.tianocore.ExternsDocument.Externs.Extern;\r
import org.tianocore.ModuleSurfaceAreaDocument.ModuleSurfaceArea;\r
import org.tianocore.frameworkwizard.common.DataType;\r
-import org.tianocore.frameworkwizard.common.DataValidation;\r
import org.tianocore.frameworkwizard.common.EnumerationData;\r
+import org.tianocore.frameworkwizard.common.IDefaultTableModel;\r
import org.tianocore.frameworkwizard.common.Log;\r
import org.tianocore.frameworkwizard.common.Tools;\r
import org.tianocore.frameworkwizard.common.Identifications.OpeningModuleType;\r
+import org.tianocore.frameworkwizard.common.ui.IFrame;\r
import org.tianocore.frameworkwizard.common.ui.IInternalFrame;\r
-import org.tianocore.frameworkwizard.common.ui.iCheckBoxList.ICheckBoxList;\r
import org.tianocore.frameworkwizard.module.Identifications.Externs.ExternsIdentification;\r
import org.tianocore.frameworkwizard.module.Identifications.Externs.ExternsVector;\r
+import org.tianocore.frameworkwizard.module.ui.dialog.ExternsDlg;\r
\r
/**\r
The class is used to create, update DataHub of MSA/MBD file \r
//\r
private JPanel jContentPane = null;\r
\r
- private JLabel jLabelName = null;\r
-\r
- private JComboBox jComboBoxType = null;\r
-\r
- private JTextArea jTextAreaList = null;\r
-\r
- private JComboBox jComboBoxList = null;\r
-\r
private JButton jButtonAdd = null;\r
\r
private JButton jButtonRemove = null;\r
\r
private JScrollPane jScrollPane = null;\r
\r
- private JScrollPane jScrollPaneList = null;\r
-\r
- private JLabel jLabelPcdIsDriver = null;\r
-\r
- private JComboBox jComboBoxPcdIsDriver = null;\r
-\r
- private JLabel jLabelC_Name = null;\r
-\r
- private JTextField jTextFieldC_Name = null;\r
+ private JScrollPane jScrollPaneTable = null;\r
\r
- private JLabel jLabelFeatureFlag = null;\r
-\r
- private JLabel jLabelArch = null;\r
-\r
- private JTextField jTextFieldFeatureFlag = null;\r
-\r
- private ICheckBoxList iCheckBoxListArch = null;\r
-\r
- private JScrollPane jScrollPaneArch = null;\r
+ private JTable jTable = null;\r
\r
//\r
// Not used by UI\r
//\r
- private int intSelectedItemId = 0;\r
-\r
private OpeningModuleType omt = null;\r
\r
private ModuleSurfaceArea msa = null;\r
\r
private ExternsVector vid = new ExternsVector();\r
\r
- private EnumerationData ed = new EnumerationData();\r
+ private IDefaultTableModel model = null;\r
\r
- /**\r
- This method initializes jComboBoxType \r
- \r
- @return javax.swing.JComboBox jComboBoxType\r
- \r
- **/\r
- private JComboBox getJComboBoxType() {\r
- if (jComboBoxType == null) {\r
- jComboBoxType = new JComboBox();\r
- jComboBoxType.setBounds(new java.awt.Rectangle(160, 35, 320, 20));\r
- jComboBoxType.setPreferredSize(new java.awt.Dimension(320, 20));\r
- }\r
- return jComboBoxType;\r
- }\r
-\r
- /**\r
- This method initializes jComboBoxFileList \r
- \r
- @return javax.swing.JComboBox jComboBoxFileList\r
- \r
- **/\r
- private JComboBox getJComboBoxList() {\r
- if (jComboBoxList == null) {\r
- jComboBoxList = new JComboBox();\r
- jComboBoxList.setBounds(new java.awt.Rectangle(15, 195, 210, 20));\r
- jComboBoxList.addItemListener(this);\r
- jComboBoxList.addActionListener(this);\r
- jComboBoxList.setPreferredSize(new java.awt.Dimension(210, 20));\r
- }\r
- return jComboBoxList;\r
- }\r
+ private int selectedRow = -1;\r
\r
/**\r
This method initializes jButtonAdd \r
jButtonUpdate = new JButton();\r
jButtonUpdate.setBounds(new java.awt.Rectangle(315, 195, 80, 20));\r
jButtonUpdate.setPreferredSize(new java.awt.Dimension(80, 20));\r
- jButtonUpdate.setText("Update");\r
+ jButtonUpdate.setText("Edit");\r
jButtonUpdate.addActionListener(this);\r
}\r
return jButtonUpdate;\r
}\r
\r
- /**\r
- * This method initializes jScrollPaneFileList \r
- * \r
- * @return javax.swing.JScrollPane \r
- */\r
- private JScrollPane getJScrollPaneList() {\r
- if (jScrollPaneList == null) {\r
- jScrollPaneList = new JScrollPane();\r
- jScrollPaneList.setBounds(new java.awt.Rectangle(15, 220, 465, 240));\r
- jScrollPaneList.setViewportView(getJTextAreaList());\r
- jScrollPaneList.setPreferredSize(new java.awt.Dimension(465, 240));\r
- }\r
- return jScrollPaneList;\r
- }\r
-\r
/**\r
This method initializes jScrollPane \r
\r
}\r
\r
/**\r
- * This method initializes jTextAreaFileList \r
- * \r
- * @return javax.swing.JTextArea \r
- */\r
- private JTextArea getJTextAreaList() {\r
- if (jTextAreaList == null) {\r
- jTextAreaList = new JTextArea();\r
- jTextAreaList.setEditable(false);\r
- }\r
- return jTextAreaList;\r
- }\r
-\r
- /**\r
- * This method initializes jComboBoxPcdIsDriver \r
- * \r
- * @return javax.swing.JComboBox \r
- */\r
- private JComboBox getJComboBoxPcdIsDriver() {\r
- if (jComboBoxPcdIsDriver == null) {\r
- jComboBoxPcdIsDriver = new JComboBox();\r
- jComboBoxPcdIsDriver.setLocation(new java.awt.Point(160, 10));\r
- jComboBoxPcdIsDriver.setPreferredSize(new java.awt.Dimension(320, 20));\r
- jComboBoxPcdIsDriver.setSize(new java.awt.Dimension(320, 20));\r
- jComboBoxPcdIsDriver.addItemListener(this);\r
- }\r
- return jComboBoxPcdIsDriver;\r
- }\r
-\r
- /**\r
- This method initializes jTextFieldC_Name \r
- \r
- @return javax.swing.JTextField \r
+ This method initializes jScrollPaneTable \r
\r
+ @return javax.swing.JScrollPane \r
**/\r
- private JTextField getJTextFieldC_Name() {\r
- if (jTextFieldC_Name == null) {\r
- jTextFieldC_Name = new JTextField();\r
- jTextFieldC_Name.setBounds(new java.awt.Rectangle(160, 60, 320, 20));\r
- jTextFieldC_Name.setPreferredSize(new java.awt.Dimension(320,20));\r
+ private JScrollPane getJScrollPaneTable() {\r
+ if (jScrollPaneTable == null) {\r
+ jScrollPaneTable = new JScrollPane();\r
+ jScrollPaneTable.setBounds(new java.awt.Rectangle(15, 10, 470, 420));\r
+ jScrollPaneTable.setPreferredSize(new Dimension(470, 420));\r
+ jScrollPaneTable.setViewportView(getJTable());\r
}\r
- return jTextFieldC_Name;\r
+ return jScrollPaneTable;\r
}\r
\r
/**\r
- This method initializes jTextFieldFeatureFlag \r
- \r
- @return javax.swing.JTextField \r
+ This method initializes jTable \r
\r
+ @return javax.swing.JTable \r
**/\r
- private JTextField getJTextFieldFeatureFlag() {\r
- if (jTextFieldFeatureFlag == null) {\r
- jTextFieldFeatureFlag = new JTextField();\r
- jTextFieldFeatureFlag.setBounds(new java.awt.Rectangle(160, 85, 320, 20));\r
- jTextFieldFeatureFlag.setPreferredSize(new java.awt.Dimension(320, 20));\r
+ private JTable getJTable() {\r
+ if (jTable == null) {\r
+ jTable = new JTable();\r
+ model = new IDefaultTableModel();\r
+ jTable = new JTable(model);\r
+ jTable.setRowHeight(20);\r
+\r
+ model.addColumn("Type");\r
+ model.addColumn("Name");\r
+ model.addColumn("Value");\r
+\r
+ jTable.setSelectionMode(ListSelectionModel.SINGLE_SELECTION);\r
+ jTable.getSelectionModel().addListSelectionListener(this);\r
+ jTable.getModel().addTableModelListener(this);\r
+ jTable.addMouseListener(this);\r
}\r
- return jTextFieldFeatureFlag;\r
- }\r
-\r
- /**\r
- This method initializes iCheckBoxListArch \r
-\r
- @return ICheckBoxList \r
- **/\r
- private ICheckBoxList getICheckBoxListSupportedArchitectures() {\r
- if (iCheckBoxListArch == null) {\r
- iCheckBoxListArch = new ICheckBoxList();\r
- iCheckBoxListArch.addFocusListener(this);\r
- iCheckBoxListArch.setToolTipText(DataType.SUP_ARCH_LIST_HELP_TEXT);\r
- }\r
- return iCheckBoxListArch;\r
- }\r
-\r
- /**\r
- This method initializes jScrollPaneArch \r
-\r
- @return javax.swing.JScrollPane \r
-\r
- **/\r
- private JScrollPane getJScrollPaneArch() {\r
- if (jScrollPaneArch == null) {\r
- jScrollPaneArch = new JScrollPane();\r
- jScrollPaneArch.setBounds(new java.awt.Rectangle(160, 110, 320, 80));\r
- jScrollPaneArch.setPreferredSize(new java.awt.Dimension(320, 80));\r
- jScrollPaneArch.setViewportView(getICheckBoxListSupportedArchitectures());\r
- }\r
- return jScrollPaneArch;\r
- }\r
-\r
- public static void main(String[] args) {\r
-\r
+ return jTable;\r
}\r
\r
/**\r
this.setSize(500, 515);\r
this.setContentPane(getJScrollPane());\r
this.setTitle("Externs");\r
- initFrame();\r
}\r
\r
/**\r
this.externs = inExterns;\r
\r
if (this.externs != null) {\r
- //\r
- // Get PcdIsDriver\r
- //\r
- if (this.externs.getPcdIsDriver() != null) {\r
- this.jComboBoxPcdIsDriver.setSelectedItem(this.externs.getPcdIsDriver().toString());\r
- }\r
- \r
//\r
// Get specification\r
//\r
String arg0 = externs.getSpecificationList().get(index);\r
String arg1 = EnumerationData.EXTERNS_SPECIFICATION;\r
\r
- id = new ExternsIdentification(arg0, arg1, null, null);\r
+ id = new ExternsIdentification(arg0, arg1);\r
vid.addExterns(id);\r
}\r
}\r
//\r
if (this.externs.getExternList().size() > 0) {\r
for (int index = 0; index < this.externs.getExternList().size(); index++) {\r
- String arg0 = null;\r
- String arg1 = null;\r
- if (this.externs.getExternList().get(index).getModuleEntryPoint() != null) {\r
- arg0 = this.externs.getExternList().get(index).getModuleEntryPoint();\r
- arg1 = EnumerationData.EXTERNS_MODULE_ENTRY_POINT;\r
- }\r
- if (this.externs.getExternList().get(index).getModuleUnloadImage() != null) {\r
- arg0 = this.externs.getExternList().get(index).getModuleUnloadImage();\r
- arg1 = EnumerationData.EXTERNS_MODULE_UNLOAD_IMAGE;\r
- }\r
+ //\r
+ // Get common data\r
+ //\r
+ String featureFlag = externs.getExternList().get(index).getFeatureFlag();\r
+ Vector<String> arch = Tools\r
+ .convertListToVector(externs.getExternList().get(index).getSupArchList());\r
\r
- if (this.externs.getExternList().get(index).getConstructor() != null) {\r
- arg0 = this.externs.getExternList().get(index).getConstructor();\r
- arg1 = EnumerationData.EXTERNS_CONSTRUCTOR;\r
+ //\r
+ // Get Image data\r
+ //\r
+ if (this.externs.getExternList().get(index).getModuleEntryPoint() != null\r
+ || this.externs.getExternList().get(index).getModuleUnloadImage() != null) {\r
+ String moduleEntryPoint = this.externs.getExternList().get(index).getModuleEntryPoint();\r
+ String moduleUnloadImage = this.externs.getExternList().get(index).getModuleUnloadImage();\r
+ String type = EnumerationData.EXTERNS_IMAGE;\r
+ id = new ExternsIdentification(moduleEntryPoint, moduleUnloadImage, type, featureFlag, arch);\r
}\r
- if (this.externs.getExternList().get(index).getDestructor() != null) {\r
- arg0 = this.externs.getExternList().get(index).getDestructor();\r
- arg1 = EnumerationData.EXTERNS_DESTRUCTOR;\r
+\r
+ //\r
+ // Get Library Data\r
+ //\r
+ if (this.externs.getExternList().get(index).getConstructor() != null\r
+ || this.externs.getExternList().get(index).getDestructor() != null) {\r
+ String constructor = this.externs.getExternList().get(index).getConstructor();\r
+ String destructor = this.externs.getExternList().get(index).getDestructor();\r
+ String type = EnumerationData.EXTERNS_LIBRARY;\r
+ id = new ExternsIdentification(constructor, destructor, type, featureFlag, arch);\r
}\r
\r
+ //\r
+ // Get Driver Data\r
+ //\r
if (this.externs.getExternList().get(index).getDriverBinding() != null) {\r
- arg0 = this.externs.getExternList().get(index).getDriverBinding();\r
- arg1 = EnumerationData.EXTERNS_DRIVER_BINDING;\r
- }\r
- if (this.externs.getExternList().get(index).getComponentName() != null) {\r
- arg0 = this.externs.getExternList().get(index).getComponentName();\r
- arg1 = EnumerationData.EXTERNS_COMPONENT_NAME;\r
- }\r
- if (this.externs.getExternList().get(index).getDriverConfig() != null) {\r
- arg0 = this.externs.getExternList().get(index).getDriverConfig();\r
- arg1 = EnumerationData.EXTERNS_DRIVER_CONFIG;\r
- }\r
- if (this.externs.getExternList().get(index).getDriverDiag() != null) {\r
- arg0 = this.externs.getExternList().get(index).getDriverDiag();\r
- arg1 = EnumerationData.EXTERNS_DRIVER_DIAG;\r
+ String driverBinding = this.externs.getExternList().get(index).getDriverBinding();\r
+ String componentName = this.externs.getExternList().get(index).getComponentName();\r
+ String driverConfig = this.externs.getExternList().get(index).getDriverConfig();\r
+ String driverDiag = this.externs.getExternList().get(index).getDriverDiag();\r
+ String type = EnumerationData.EXTERNS_DRIVER;\r
+ id = new ExternsIdentification(driverBinding, componentName, driverConfig, driverDiag, type,\r
+ featureFlag, arch);\r
}\r
\r
- if (this.externs.getExternList().get(index).getSetVirtualAddressMapCallBack() != null) {\r
- arg0 = this.externs.getExternList().get(index).getSetVirtualAddressMapCallBack();\r
- arg1 = EnumerationData.EXTERNS_SET_VIRTUAL_ADDRESS_MAP_CALL_BACK;\r
- }\r
- if (this.externs.getExternList().get(index).getExitBootServicesCallBack() != null) {\r
- arg0 = this.externs.getExternList().get(index).getExitBootServicesCallBack();\r
- arg1 = EnumerationData.EXTERNS_EXIT_BOOT_SERVICES_CALL_BACK;\r
+ //\r
+ // Get Call Back Data\r
+ //\r
+ if (this.externs.getExternList().get(index).getSetVirtualAddressMapCallBack() != null\r
+ || this.externs.getExternList().get(index).getExitBootServicesCallBack() != null) {\r
+ String virtualAddressMap = this.externs.getExternList().get(index)\r
+ .getSetVirtualAddressMapCallBack();\r
+ String exitBootServices = this.externs.getExternList().get(index).getExitBootServicesCallBack();\r
+ String type = EnumerationData.EXTERNS_CALL_BACK;\r
+ id = new ExternsIdentification(virtualAddressMap, exitBootServices, type, featureFlag, arch);\r
}\r
\r
- String arg2 = externs.getExternList().get(index).getFeatureFlag();\r
- Vector<String> arg3 = Tools\r
- .convertListToVector(externs.getExternList().get(index).getSupArchList());\r
-\r
- id = new ExternsIdentification(arg0, arg1, arg2, arg3);\r
+ //\r
+ // Add id to vector\r
+ //\r
vid.addExterns(id);\r
}\r
}\r
}\r
- //\r
- // Update the list\r
- //\r
- Tools.generateComboBoxByVector(jComboBoxList, vid.getExternsName());\r
- reloadListArea();\r
+ showTable();\r
}\r
\r
/**\r
**/\r
private JPanel getJContentPane() {\r
if (jContentPane == null) {\r
- jLabelC_Name = new JLabel();\r
- jLabelC_Name.setBounds(new java.awt.Rectangle(15, 60, 140, 20));\r
- jLabelC_Name.setText("Value");\r
- jLabelPcdIsDriver = new JLabel();\r
- jLabelPcdIsDriver.setBounds(new java.awt.Rectangle(15, 10, 140, 20));\r
- jLabelPcdIsDriver.setText("Pcd Is Driver");\r
- jLabelName = new JLabel();\r
- jLabelName.setText("Choose Type");\r
- jLabelName.setBounds(new java.awt.Rectangle(15, 35, 140, 20));\r
- jLabelArch = new JLabel();\r
- jLabelArch.setBounds(new java.awt.Rectangle(15, 110, 140, 20));\r
- jLabelArch.setText("Arch");\r
- jLabelFeatureFlag = new JLabel();\r
- jLabelFeatureFlag.setBounds(new java.awt.Rectangle(15, 85, 140, 20));\r
- jLabelFeatureFlag.setText("Feature Flag");\r
-\r
jContentPane = new JPanel();\r
jContentPane.setLayout(null);\r
- jContentPane.setPreferredSize(new java.awt.Dimension(490, 475));\r
-\r
- jContentPane.add(jLabelName, null);\r
- jContentPane.add(getJComboBoxType(), null);\r
- jContentPane.add(jLabelFeatureFlag, null);\r
- jContentPane.add(jLabelArch, null);\r
- jContentPane.add(getJTextFieldFeatureFlag(), null);\r
- jContentPane.add(getJScrollPaneArch(), null);\r
- \r
- jContentPane.add(getJComboBoxList(), null);\r
+ jContentPane.setPreferredSize(new java.awt.Dimension(490, 490));\r
+\r
jContentPane.add(getJButtonAdd(), null);\r
jContentPane.add(getJButtonRemove(), null);\r
jContentPane.add(getJButtonUpdate(), null);\r
- jContentPane.add(getJScrollPaneList(), null);\r
- jContentPane.add(jLabelPcdIsDriver, null);\r
- jContentPane.add(getJComboBoxPcdIsDriver(), null);\r
- jContentPane.add(jLabelC_Name, null);\r
- jContentPane.add(getJTextFieldC_Name(), null);\r
+ jContentPane.add(getJScrollPaneTable(), null);\r
}\r
return jContentPane;\r
}\r
\r
+ private void showEdit(int index) {\r
+ ExternsDlg dlg = new ExternsDlg(vid.getExterns(index), new IFrame(), omt.getId());\r
+ int result = dlg.showDialog();\r
+ if (result == DataType.RETURN_TYPE_OK) {\r
+ if (index == -1) {\r
+ this.vid.addExterns(dlg.getId());\r
+ } else {\r
+ this.vid.setExterns(dlg.getId(), index);\r
+ }\r
+ this.showTable();\r
+ this.save();\r
+ dlg.dispose();\r
+ }\r
+ if (result == DataType.RETURN_TYPE_CANCEL) {\r
+ dlg.dispose();\r
+ }\r
+ }\r
+\r
/**\r
- This method initializes Usage type and Externs type\r
+ Clear all table rows\r
\r
**/\r
- private void initFrame() {\r
- Tools.generateComboBoxByVector(this.jComboBoxType, ed.getVExternTypes());\r
- Tools.generateComboBoxByVector(this.jComboBoxPcdIsDriver, ed.getVPcdDriverTypes());\r
- this.iCheckBoxListArch.setAllItems(ed.getVSupportedArchitectures());\r
+ private void clearAll() {\r
+ if (model != null) {\r
+ for (int index = model.getRowCount() - 1; index >= 0; index--) {\r
+ model.removeRow(index);\r
+ }\r
+ }\r
+ }\r
+\r
+ /**\r
+ Read content of vector and put then into table\r
+ \r
+ **/\r
+ private void showTable() {\r
+ clearAll();\r
+\r
+ if (vid.size() > 0) {\r
+ for (int index = 0; index < vid.size(); index++) {\r
+ int line = 1;\r
+\r
+ //\r
+ // For Specification\r
+ //\r
+ if (vid.getExterns(index).getType().equals(EnumerationData.EXTERNS_SPECIFICATION)) {\r
+ line = 1;\r
+ }\r
+\r
+ //\r
+ // For Image\r
+ //\r
+ if (vid.getExterns(index).getType().equals(EnumerationData.EXTERNS_IMAGE)) {\r
+ line = 2;\r
+ }\r
+\r
+ //\r
+ // For Library\r
+ //\r
+ if (vid.getExterns(index).getType().equals(EnumerationData.EXTERNS_LIBRARY)) {\r
+ line = 2;\r
+ }\r
+\r
+ //\r
+ // For Driver\r
+ //\r
+ if (vid.getExterns(index).getType().equals(EnumerationData.EXTERNS_DRIVER)) {\r
+ line = 4;\r
+ }\r
+\r
+ //\r
+ // For Call Back\r
+ //\r
+ if (vid.getExterns(index).getType().equals(EnumerationData.EXTERNS_CALL_BACK)) {\r
+ line = 2;\r
+ }\r
+\r
+ model.addRow(vid.toStringVector(index));\r
+ jTable.setRowHeight(index, line * 18);\r
+ }\r
+ }\r
+ this.jTable.repaint();\r
+ this.jTable.updateUI();\r
}\r
\r
/* (non-Javadoc)\r
*/\r
public void actionPerformed(ActionEvent arg0) {\r
if (arg0.getSource() == jButtonAdd) {\r
- if (!checkAdd()) {\r
- return;\r
- }\r
- addToList();\r
- }\r
- if (arg0.getSource() == jButtonRemove) {\r
- removeFromList();\r
+ showEdit(-1);\r
}\r
if (arg0.getSource() == jButtonUpdate) {\r
- if (!checkAdd()) {\r
+ if (this.selectedRow < 0) {\r
+ Log.wrn("Update Externs", "Please select one record first.");\r
return;\r
}\r
- updateForList();\r
- }\r
- }\r
-\r
- /**\r
- Data validation for all fields\r
- \r
- @retval true - All datas are valid\r
- @retval false - At least one data is invalid\r
- \r
- **/\r
- public boolean checkAdd() {\r
- //\r
- // Check if all fields have correct data types \r
- //\r
-\r
- //\r
- // Check CName \r
- //\r
- if (isEmpty(this.jTextFieldC_Name.getText())) {\r
- Log.err("Value couldn't be empty");\r
- return false;\r
+ showEdit(selectedRow);\r
}\r
\r
- if (!isEmpty(this.jTextFieldC_Name.getText())) {\r
- if (this.jComboBoxType.getSelectedItem().toString().equals(EnumerationData.EXTERNS_SPECIFICATION)) {\r
- if (!DataValidation.isSentence(this.jTextFieldC_Name.getText())) {\r
- Log.err("Incorrect data type for Specification");\r
- return false;\r
- } \r
- } else {\r
- if (!DataValidation.isC_NameType(this.jTextFieldC_Name.getText())) {\r
- Log.err("Incorrect data type for C_Name");\r
- return false;\r
- } \r
+ if (arg0.getSource() == jButtonRemove) {\r
+ if (jTable.isEditing()) {\r
+ jTable.getCellEditor().stopCellEditing();\r
}\r
- }\r
-\r
- //\r
- // Check FeatureFlag\r
- //\r
- if (!isEmpty(this.jTextFieldFeatureFlag.getText())) {\r
- if (!DataValidation.isFeatureFlag(this.jTextFieldFeatureFlag.getText())) {\r
- Log.err("Incorrect data type for Feature Flag");\r
- return false;\r
+ if (selectedRow > -1) {\r
+ this.model.removeRow(selectedRow);\r
+ this.vid.removeExterns(selectedRow);\r
+ selectedRow = -1;\r
+ this.save();\r
}\r
}\r
-\r
- return true;\r
}\r
\r
/**\r
try {\r
int count = this.vid.size();\r
\r
- this.externs = Externs.Factory.newInstance();\r
//\r
- // Save PcdIsDriver first\r
+ // Save pcd and flash map information first\r
//\r
- if (!this.jComboBoxPcdIsDriver.getSelectedItem().toString().equals(DataType.EMPTY_SELECT_ITEM)) {\r
- externs.setPcdIsDriver(PcdDriverTypes.Enum.forString(this.jComboBoxPcdIsDriver.getSelectedItem()\r
- .toString()));\r
+ Externs ex = Externs.Factory.newInstance();\r
+ if (this.externs.getPcdIsDriver() != null) {\r
+ ex.setPcdIsDriver(this.externs.getPcdIsDriver());\r
+ }\r
+ if (this.externs.getTianoR8FlashMapH()) {\r
+ ex.setTianoR8FlashMapH(this.externs.getTianoR8FlashMapH());\r
}\r
+ this.externs = ex;\r
\r
+ //\r
+ // Save externs\r
+ //\r
if (count > 0) {\r
for (int index = 0; index < count; index++) {\r
//\r
// Save specfication\r
//\r
if (vid.getExterns(index).getType().equals(EnumerationData.EXTERNS_SPECIFICATION)) {\r
- if (!isEmpty(vid.getExterns(index).getName())) {\r
+ if (!isEmpty(vid.getExterns(index).getName0())) {\r
this.externs.addNewSpecification();\r
this.externs.setSpecificationArray(externs.getSpecificationList().size() - 1,\r
- vid.getExterns(index).getName());\r
+ vid.getExterns(index).getName0());\r
+ continue;\r
}\r
- } else {\r
- //\r
- // Save extern\r
- //\r
- Extern e = Extern.Factory.newInstance();\r
-\r
- if (vid.getExterns(index).getType().equals(EnumerationData.EXTERNS_MODULE_ENTRY_POINT)) {\r
- if (!isEmpty(vid.getExterns(index).getName())) {\r
- e.setModuleEntryPoint(vid.getExterns(index).getName());\r
+ }\r
+\r
+ Extern e = Extern.Factory.newInstance();\r
+ //\r
+ // Save image\r
+ //\r
+ if (vid.getExterns(index).getType().equals(EnumerationData.EXTERNS_IMAGE)) {\r
+ if (!isEmpty(vid.getExterns(index).getName0()) || !isEmpty(vid.getExterns(index).getName1())) {\r
+ e = Extern.Factory.newInstance();\r
+ if (!isEmpty(vid.getExterns(index).getName0())) {\r
+ e.setModuleEntryPoint(vid.getExterns(index).getName0());\r
}\r
- }\r
- if (vid.getExterns(index).getType().equals(EnumerationData.EXTERNS_MODULE_UNLOAD_IMAGE)) {\r
- if (!isEmpty(vid.getExterns(index).getName())) {\r
- e.setModuleUnloadImage(vid.getExterns(index).getName());\r
+ if (!isEmpty(vid.getExterns(index).getName1())) {\r
+ e.setModuleUnloadImage(vid.getExterns(index).getName1());\r
}\r
}\r
+ }\r
\r
- if (vid.getExterns(index).getType().equals(EnumerationData.EXTERNS_CONSTRUCTOR)) {\r
- if (!isEmpty(vid.getExterns(index).getName())) {\r
- e.setConstructor(vid.getExterns(index).getName());\r
+ //\r
+ // Save library\r
+ //\r
+ if (vid.getExterns(index).getType().equals(EnumerationData.EXTERNS_LIBRARY)) {\r
+ if (!isEmpty(vid.getExterns(index).getName0()) || !isEmpty(vid.getExterns(index).getName1())) {\r
+ e = Extern.Factory.newInstance();\r
+ if (!isEmpty(vid.getExterns(index).getName0())) {\r
+ e.setConstructor(vid.getExterns(index).getName0());\r
}\r
- }\r
- if (vid.getExterns(index).getType().equals(EnumerationData.EXTERNS_DESTRUCTOR)) {\r
- if (!isEmpty(vid.getExterns(index).getName())) {\r
- e.setDestructor(vid.getExterns(index).getName());\r
+ if (!isEmpty(vid.getExterns(index).getName1())) {\r
+ e.setDestructor(vid.getExterns(index).getName1());\r
}\r
}\r
+ }\r
\r
- if (vid.getExterns(index).getType().equals(EnumerationData.EXTERNS_DRIVER_BINDING)) {\r
- if (!isEmpty(vid.getExterns(index).getName())) {\r
- e.setDriverBinding(vid.getExterns(index).getName());\r
+ //\r
+ // Save call back\r
+ //\r
+ if (vid.getExterns(index).getType().equals(EnumerationData.EXTERNS_CALL_BACK)) {\r
+ if (!isEmpty(vid.getExterns(index).getName0()) || !isEmpty(vid.getExterns(index).getName1())) {\r
+ e = Extern.Factory.newInstance();\r
+ if (!isEmpty(vid.getExterns(index).getName0())) {\r
+ e.setSetVirtualAddressMapCallBack(vid.getExterns(index).getName0());\r
}\r
- }\r
- if (vid.getExterns(index).getType().equals(EnumerationData.EXTERNS_COMPONENT_NAME)) {\r
- if (!isEmpty(vid.getExterns(index).getName())) {\r
- e.setComponentName(vid.getExterns(index).getName());\r
+ if (!isEmpty(vid.getExterns(index).getName1())) {\r
+ e.setExitBootServicesCallBack(vid.getExterns(index).getName1());\r
}\r
}\r
- if (vid.getExterns(index).getType().equals(EnumerationData.EXTERNS_DRIVER_CONFIG)) {\r
- if (!isEmpty(vid.getExterns(index).getName())) {\r
- e.setDriverConfig(vid.getExterns(index).getName());\r
+ }\r
+\r
+ //\r
+ // Save driver\r
+ //\r
+ if (vid.getExterns(index).getType().equals(EnumerationData.EXTERNS_DRIVER)) {\r
+ if (!isEmpty(vid.getExterns(index).getName0()) || !isEmpty(vid.getExterns(index).getName1())\r
+ || !isEmpty(vid.getExterns(index).getName2()) || !isEmpty(vid.getExterns(index).getName3())) {\r
+ e = Extern.Factory.newInstance();\r
+ if (!isEmpty(vid.getExterns(index).getName0())) {\r
+ e.setDriverBinding(vid.getExterns(index).getName0());\r
}\r
- }\r
- if (vid.getExterns(index).getType().equals(EnumerationData.EXTERNS_DRIVER_DIAG)) {\r
- if (!isEmpty(vid.getExterns(index).getName())) {\r
- e.setDriverDiag(vid.getExterns(index).getName());\r
+ if (!isEmpty(vid.getExterns(index).getName1())) {\r
+ e.setComponentName(vid.getExterns(index).getName1());\r
}\r
- }\r
-\r
- if (vid.getExterns(index).getType()\r
- .equals(EnumerationData.EXTERNS_SET_VIRTUAL_ADDRESS_MAP_CALL_BACK)) {\r
- if (!isEmpty(vid.getExterns(index).getName())) {\r
- e.setSetVirtualAddressMapCallBack(vid.getExterns(index).getName());\r
+ if (!isEmpty(vid.getExterns(index).getName2())) {\r
+ e.setDriverConfig(vid.getExterns(index).getName2());\r
}\r
- }\r
- if (vid.getExterns(index).getType()\r
- .equals(EnumerationData.EXTERNS_EXIT_BOOT_SERVICES_CALL_BACK)) {\r
- if (!isEmpty(vid.getExterns(index).getName())) {\r
- e.setExitBootServicesCallBack(vid.getExterns(index).getName());\r
+ if (!isEmpty(vid.getExterns(index).getName3())) {\r
+ e.setDriverDiag(vid.getExterns(index).getName3());\r
}\r
}\r
+ }\r
\r
- if (!isEmpty(vid.getExterns(index).getFeatureFlag())) {\r
- e.setFeatureFlag(vid.getExterns(index).getFeatureFlag());\r
- }\r
- if (vid.getExterns(index).getSupArchList() != null\r
- && vid.getExterns(index).getSupArchList().size() > 0) {\r
- e.setSupArchList(vid.getExterns(index).getSupArchList());\r
- }\r
-\r
- this.externs.addNewExtern();\r
- this.externs.setExternArray(this.externs.getExternList().size() - 1, e);\r
+ //\r
+ // Save common data\r
+ //\r
+ if (!isEmpty(vid.getExterns(index).getFeatureFlag())) {\r
+ e.setFeatureFlag(vid.getExterns(index).getFeatureFlag());\r
}\r
+ if (vid.getExterns(index).getSupArchList() != null\r
+ && vid.getExterns(index).getSupArchList().size() > 0) {\r
+ e.setSupArchList(vid.getExterns(index).getSupArchList());\r
+ }\r
+\r
+ this.externs.addNewExtern();\r
+ this.externs.setExternArray(this.externs.getExternList().size() - 1, e);\r
}\r
}\r
\r
this.msa.setExterns(externs);\r
this.omt.setSaved(false);\r
} catch (Exception e) {\r
+ Log.wrn("Update Externs", e.getMessage());\r
Log.err("Update Externs", e.getMessage());\r
}\r
}\r
\r
/* (non-Javadoc)\r
- * @see java.awt.event.ComponentListener#componentResized(java.awt.event.ComponentEvent)\r
- * \r
- * Override componentResized to resize all components when frame's size is changed\r
+ * @see javax.swing.event.ListSelectionListener#valueChanged(javax.swing.event.ListSelectionEvent)\r
+ *\r
*/\r
- public void componentResized(ComponentEvent arg0) {\r
- int intCurrentWidth = this.getJContentPane().getWidth();\r
- int intCurrentHeight = this.getJContentPane().getHeight();\r
- int intPreferredWidth = this.getJContentPane().getPreferredSize().width;\r
- int intPreferredHeight = this.getJContentPane().getPreferredSize().height;\r
-\r
- resizeComponentWidth(this.jComboBoxPcdIsDriver, intCurrentWidth, intPreferredWidth);\r
- resizeComponentWidth(this.jComboBoxType, intCurrentWidth, intPreferredWidth);\r
- resizeComponentWidth(this.jTextFieldC_Name, intCurrentWidth, intPreferredWidth);\r
- resizeComponentWidth(this.jTextFieldFeatureFlag, intCurrentWidth, intPreferredWidth);\r
- resizeComponentWidth(this.jScrollPaneArch, intCurrentWidth, intPreferredWidth);\r
-\r
- resizeComponentWidth(jComboBoxList, intCurrentWidth, intPreferredWidth);\r
- resizeComponent(jScrollPaneList, intCurrentWidth, intCurrentHeight, intPreferredWidth, intPreferredHeight);\r
-\r
- relocateComponentX(jButtonAdd, intCurrentWidth, intPreferredWidth, DataType.SPACE_TO_RIGHT_FOR_ADD_BUTTON);\r
- relocateComponentX(jButtonRemove, intCurrentWidth, intPreferredWidth, DataType.SPACE_TO_RIGHT_FOR_REMOVE_BUTTON);\r
- relocateComponentX(jButtonUpdate, intCurrentWidth, intPreferredWidth, DataType.SPACE_TO_RIGHT_FOR_UPDATE_BUTTON);\r
- }\r
-\r
- private ExternsIdentification getCurrentExterns() {\r
- String arg0 = this.jTextFieldC_Name.getText();\r
- String arg1 = this.jComboBoxType.getSelectedItem().toString();\r
-\r
- String arg2 = this.jTextFieldFeatureFlag.getText();\r
- Vector<String> arg3 = this.iCheckBoxListArch.getAllCheckedItemsString();\r
-\r
- id = new ExternsIdentification(arg0, arg1, arg2, arg3);\r
- return id;\r
- }\r
-\r
- /**\r
- Add current item to Vector\r
- \r
- **/\r
- private void addToList() {\r
- intSelectedItemId = vid.size();\r
-\r
- vid.addExterns(getCurrentExterns());\r
-\r
- jComboBoxList.addItem(id.getName());\r
- jComboBoxList.setSelectedItem(id.getName());\r
-\r
- //\r
- // Reset select item index\r
- //\r
- intSelectedItemId = vid.size();\r
-\r
- //\r
- // Reload all fields of selected item\r
- //\r
- reloadFromList();\r
-\r
- // \r
- // Save to memory\r
- //\r
- save();\r
- }\r
-\r
- /**\r
- Remove current item from Vector\r
- \r
- **/\r
- private void removeFromList() {\r
- //\r
- // Check if exist items\r
- //\r
- if (this.vid.size() < 1) {\r
+ public void valueChanged(ListSelectionEvent arg0) {\r
+ if (arg0.getValueIsAdjusting()) {\r
return;\r
}\r
-\r
- int intTempIndex = intSelectedItemId;\r
-\r
- jComboBoxList.removeItemAt(intSelectedItemId);\r
-\r
- vid.removeExterns(intTempIndex);\r
-\r
- //\r
- // Reload all fields of selected item\r
- //\r
- reloadFromList();\r
-\r
- // \r
- // Save to memory\r
- //\r
- save();\r
- }\r
-\r
- /**\r
- Update current item of Vector\r
- \r
- **/\r
- private void updateForList() {\r
- //\r
- // Check if exist items\r
- //\r
- if (this.vid.size() < 1) {\r
+ ListSelectionModel lsm = (ListSelectionModel) arg0.getSource();\r
+ if (lsm.isSelectionEmpty()) {\r
return;\r
- }\r
-\r
- //\r
- // Backup selected item index\r
- //\r
- int intTempIndex = intSelectedItemId;\r
-\r
- vid.updateExterns(getCurrentExterns(), intTempIndex);\r
-\r
- jComboBoxList.removeAllItems();\r
- for (int index = 0; index < vid.size(); index++) {\r
- jComboBoxList.addItem(vid.getExterns(index).getName());\r
- }\r
-\r
- //\r
- // Restore selected item index\r
- //\r
- intSelectedItemId = intTempIndex;\r
-\r
- //\r
- // Reset select item index\r
- //\r
- jComboBoxList.setSelectedIndex(intSelectedItemId);\r
-\r
- //\r
- // Reload all fields of selected item\r
- //\r
- reloadFromList();\r
-\r
- // \r
- // Save to memory\r
- //\r
- save();\r
- }\r
-\r
- /**\r
- Refresh all fields' values of selected item of Vector\r
- \r
- **/\r
- private void reloadFromList() {\r
- if (vid.size() > 0) {\r
- //\r
- // Get selected item index\r
- //\r
- intSelectedItemId = jComboBoxList.getSelectedIndex();\r
-\r
- this.jTextFieldC_Name.setText(vid.getExterns(intSelectedItemId).getName());\r
- this.jComboBoxType.setSelectedItem(vid.getExterns(intSelectedItemId).getType());\r
-\r
- jTextFieldFeatureFlag.setText(vid.getExterns(intSelectedItemId).getFeatureFlag());\r
- iCheckBoxListArch.setAllItemsUnchecked();\r
- iCheckBoxListArch.initCheckedItem(true, vid.getExterns(intSelectedItemId).getSupArchList());\r
-\r
} else {\r
+ selectedRow = lsm.getMinSelectionIndex();\r
}\r
-\r
- reloadListArea();\r
- }\r
-\r
- /**\r
- Update list area pane via the elements of Vector\r
- \r
- **/\r
- private void reloadListArea() {\r
- String strListItem = "";\r
- for (int index = 0; index < vid.size(); index++) {\r
- strListItem = strListItem + vid.getExterns(index).getName() + DataType.UNIX_LINE_SEPARATOR;\r
- }\r
- this.jTextAreaList.setText(strListItem);\r
}\r
\r
/* (non-Javadoc)\r
- * @see java.awt.event.ItemListener#itemStateChanged(java.awt.event.ItemEvent)\r
+ * @see java.awt.event.MouseListener#mouseClicked(java.awt.event.MouseEvent)\r
*\r
- * Reflesh the frame when selected item changed\r
- * \r
*/\r
- public void itemStateChanged(ItemEvent arg0) {\r
- if (arg0.getSource() == this.jComboBoxList && arg0.getStateChange() == ItemEvent.SELECTED) {\r
- reloadFromList();\r
- }\r
- if (arg0.getSource() == this.jComboBoxPcdIsDriver && arg0.getStateChange() == ItemEvent.SELECTED && externs != null) {\r
- String s = this.jComboBoxPcdIsDriver.getSelectedItem().toString();\r
- if (s.equals(DataType.EMPTY_SELECT_ITEM)) {\r
- this.externs.setPcdIsDriver(null);\r
+ public void mouseClicked(MouseEvent arg0) {\r
+ if (arg0.getClickCount() == 2) {\r
+ if (this.selectedRow < 0) {\r
+ return;\r
} else {\r
- this.externs.setPcdIsDriver(PcdDriverTypes.Enum.forString(s));\r
+ showEdit(selectedRow);\r
}\r
- this.msa.setExterns(externs);\r
- this.omt.setSaved(false);\r
}\r
}\r
+\r
+ /* (non-Javadoc)\r
+ * @see java.awt.event.ComponentListener#componentResized(java.awt.event.ComponentEvent)\r
+ * \r
+ * Override componentResized to resize all components when frame's size is changed\r
+ */\r
+ public void componentResized(ComponentEvent arg0) {\r
+ int intCurrentWidth = this.getJContentPane().getWidth();\r
+ int intCurrentHeight = this.getJContentPane().getHeight();\r
+ int intPreferredWidth = this.getJContentPane().getPreferredSize().width;\r
+ int intPreferredHeight = this.getJContentPane().getPreferredSize().height;\r
+\r
+ Tools.resizeComponent(this.jScrollPaneTable, intCurrentWidth, intCurrentHeight, intPreferredWidth,\r
+ intPreferredHeight);\r
+ Tools.relocateComponent(this.jButtonAdd, intCurrentWidth, intCurrentHeight, intPreferredWidth,\r
+ intPreferredHeight, DataType.SPACE_TO_RIGHT_FOR_ADD_BUTTON,\r
+ DataType.SPACE_TO_BOTTOM_FOR_ADD_BUTTON);\r
+ Tools.relocateComponent(this.jButtonRemove, intCurrentWidth, intCurrentHeight, intPreferredWidth,\r
+ intPreferredHeight, DataType.SPACE_TO_RIGHT_FOR_REMOVE_BUTTON,\r
+ DataType.SPACE_TO_BOTTOM_FOR_REMOVE_BUTTON);\r
+ Tools.relocateComponent(this.jButtonUpdate, intCurrentWidth, intCurrentHeight, intPreferredWidth,\r
+ intPreferredHeight, DataType.SPACE_TO_RIGHT_FOR_UPDATE_BUTTON,\r
+ DataType.SPACE_TO_BOTTOM_FOR_UPDATE_BUTTON);\r
+ }\r
}\r