]> git.proxmox.com Git - mirror_edk2.git/blobdiff - Tools/Source/FrameworkWizard/src/org/tianocore/frameworkwizard/module/ui/MsaHeader.java
Fixed wording for Legacy FlashMap.h Header question
[mirror_edk2.git] / Tools / Source / FrameworkWizard / src / org / tianocore / frameworkwizard / module / ui / MsaHeader.java
index 9cf0d380e0244fd1ee3ada129b8d7657657ae039..bf7afce417a1b7a7eaceff60240e8fbb0140aca7 100644 (file)
@@ -20,6 +20,7 @@ import java.awt.event.ComponentEvent;
 import java.awt.event.FocusEvent;\r
 import java.util.Vector;\r
 \r
+import javax.swing.ButtonGroup;\r
 import javax.swing.JButton;\r
 import javax.swing.JCheckBox;\r
 import javax.swing.JComboBox;\r
@@ -29,10 +30,12 @@ import javax.swing.JScrollPane;
 import javax.swing.JTextArea;\r
 import javax.swing.JTextField;\r
 \r
+import org.tianocore.ExternsDocument;\r
 import org.tianocore.ModuleDefinitionsDocument;\r
 import org.tianocore.ModuleSurfaceAreaDocument;\r
 import org.tianocore.ModuleTypeDef;\r
 import org.tianocore.MsaHeaderDocument;\r
+import org.tianocore.PcdDriverTypes;\r
 import org.tianocore.LicenseDocument.License;\r
 import org.tianocore.frameworkwizard.common.DataType;\r
 import org.tianocore.frameworkwizard.common.DataValidation;\r
@@ -42,6 +45,7 @@ import org.tianocore.frameworkwizard.common.Tools;
 import org.tianocore.frameworkwizard.common.Identifications.OpeningModuleType;\r
 import org.tianocore.frameworkwizard.common.ui.IInternalFrame;\r
 import org.tianocore.frameworkwizard.common.ui.StarLabel;\r
+import javax.swing.JRadioButton;\r
 \r
 /**\r
  The class is used to create, update MsaHeader of MSA file\r
@@ -58,9 +62,16 @@ public class MsaHeader extends IInternalFrame {
     private static final long serialVersionUID = -8152099582923006900L;\r
 \r
     private int dialogWidth = 500;\r
-    \r
+\r
     private int dialogHeight = 630;\r
+\r
+    private final int labelWidth = 155;\r
     \r
+    private int valueWidth = 320;\r
+    \r
+    private final int labelCol = 12;\r
+    \r
+    private final int valueCol = 168;\r
     //\r
     //Define class members\r
     //\r
@@ -114,8 +125,6 @@ public class MsaHeader extends IInternalFrame {
 \r
     private JLabel jLabelBinaryModule = null;\r
 \r
-    private JComboBox jComboBoxBinaryModule = null;\r
-\r
     private JLabel jLabelOutputFileBasename = null;\r
 \r
     private JTextField jTextFieldOutputFileBasename = null;\r
@@ -152,8 +161,6 @@ public class MsaHeader extends IInternalFrame {
 \r
     private StarLabel jStarLabel14 = null;\r
 \r
-//    private StarLabel jStarLabel15 = null;\r
-\r
     private JCheckBox jCheckBoxIa32 = null;\r
 \r
     private JCheckBox jCheckBoxX64 = null;\r
@@ -165,7 +172,13 @@ public class MsaHeader extends IInternalFrame {
     private JCheckBox jCheckBoxArm = null;\r
 \r
     private JCheckBox jCheckBoxPpc = null;\r
-    \r
+\r
+    private JComboBox jComboBoxPcdIsDriver = null;\r
+\r
+    private JCheckBox jCheckBoxPcd = null;\r
+\r
+    private JCheckBox jCheckBoxFlashMap = null;\r
+\r
     //\r
     // Not used for UI\r
     //\r
@@ -175,10 +188,16 @@ public class MsaHeader extends IInternalFrame {
 \r
     private ModuleSurfaceAreaDocument.ModuleSurfaceArea msa = null;\r
 \r
+    private ExternsDocument.Externs ex = null;\r
+\r
     private OpeningModuleType omt = null;\r
 \r
     private EnumerationData ed = new EnumerationData();\r
 \r
+    private JRadioButton jRadioButtonBinaryModuleTrue = null;\r
+\r
+    private JRadioButton jRadioButtonBinaryModuleFalse = null;\r
+\r
     /**\r
      * This method initializes jCheckBoxIa32    \r
      *  \r
@@ -187,7 +206,7 @@ public class MsaHeader extends IInternalFrame {
     private JCheckBox getJCheckBoxIa32() {\r
         if (jCheckBoxIa32 == null) {\r
             jCheckBoxIa32 = new JCheckBox();\r
-            jCheckBoxIa32.setBounds(new java.awt.Rectangle(160, 505, 55, 20));\r
+            jCheckBoxIa32.setBounds(new java.awt.Rectangle(valueCol, 505, 55, 20));\r
             jCheckBoxIa32.setText("IA32");\r
             jCheckBoxIa32.setToolTipText(DataType.SUP_ARCH_LIST_HELP_TEXT);\r
             jCheckBoxIa32.addFocusListener(this);\r
@@ -203,7 +222,7 @@ public class MsaHeader extends IInternalFrame {
     private JCheckBox getJCheckBoxX64() {\r
         if (jCheckBoxX64 == null) {\r
             jCheckBoxX64 = new JCheckBox();\r
-            jCheckBoxX64.setBounds(new java.awt.Rectangle(215, 505, 53, 20));\r
+            jCheckBoxX64.setBounds(new java.awt.Rectangle(valueCol + 55, 505, 53, 20));\r
             jCheckBoxX64.setText("X64");\r
             jCheckBoxX64.setToolTipText(DataType.SUP_ARCH_LIST_HELP_TEXT);\r
             jCheckBoxX64.addFocusListener(this);\r
@@ -219,7 +238,7 @@ public class MsaHeader extends IInternalFrame {
     private JCheckBox getJCheckBoxIpf() {\r
         if (jCheckBoxIpf == null) {\r
             jCheckBoxIpf = new JCheckBox();\r
-            jCheckBoxIpf.setBounds(new java.awt.Rectangle(270, 505, 52, 20));\r
+            jCheckBoxIpf.setBounds(new java.awt.Rectangle(valueCol + 110, 505, 52, 20));\r
             jCheckBoxIpf.setText("IPF");\r
             jCheckBoxIpf.setToolTipText(DataType.SUP_ARCH_LIST_HELP_TEXT);\r
             jCheckBoxIpf.addFocusListener(this);\r
@@ -235,7 +254,7 @@ public class MsaHeader extends IInternalFrame {
     private JCheckBox getJCheckBoxEbc() {\r
         if (jCheckBoxEbc == null) {\r
             jCheckBoxEbc = new JCheckBox();\r
-            jCheckBoxEbc.setBounds(new java.awt.Rectangle(325, 505, 53, 20));\r
+            jCheckBoxEbc.setBounds(new java.awt.Rectangle(valueCol + 165, 505, 53, 20));\r
             jCheckBoxEbc.setText("EBC");\r
             jCheckBoxEbc.setToolTipText(DataType.SUP_ARCH_LIST_HELP_TEXT);\r
             jCheckBoxEbc.addFocusListener(this);\r
@@ -251,7 +270,7 @@ public class MsaHeader extends IInternalFrame {
     private JCheckBox getJCheckBoxArm() {\r
         if (jCheckBoxArm == null) {\r
             jCheckBoxArm = new JCheckBox();\r
-            jCheckBoxArm.setBounds(new java.awt.Rectangle(380, 505, 54, 20));\r
+            jCheckBoxArm.setBounds(new java.awt.Rectangle(valueCol + 220, 505, 54, 20));\r
             jCheckBoxArm.setText("ARM");\r
             jCheckBoxArm.setToolTipText(DataType.SUP_ARCH_LIST_HELP_TEXT);\r
             jCheckBoxArm.addFocusListener(this);\r
@@ -267,7 +286,7 @@ public class MsaHeader extends IInternalFrame {
     private JCheckBox getJCheckBoxPpc() {\r
         if (jCheckBoxPpc == null) {\r
             jCheckBoxPpc = new JCheckBox();\r
-            jCheckBoxPpc.setBounds(new java.awt.Rectangle(435, 505, 53, 20));\r
+            jCheckBoxPpc.setBounds(new java.awt.Rectangle(valueCol + 285, 505, 53, 20));\r
             jCheckBoxPpc.setText("PPC");\r
             jCheckBoxPpc.setToolTipText(DataType.SUP_ARCH_LIST_HELP_TEXT);\r
             jCheckBoxPpc.addFocusListener(this);\r
@@ -284,7 +303,7 @@ public class MsaHeader extends IInternalFrame {
     private JTextField getJTextFieldBaseName() {\r
         if (jTextFieldBaseName == null) {\r
             jTextFieldBaseName = new JTextField();\r
-            jTextFieldBaseName.setBounds(new java.awt.Rectangle(160, 10, 320, 20));\r
+            jTextFieldBaseName.setBounds(new java.awt.Rectangle(valueCol, 10, valueWidth, 20));\r
             jTextFieldBaseName.setPreferredSize(new java.awt.Dimension(320, 20));\r
             jTextFieldBaseName.addFocusListener(this);\r
             jTextFieldBaseName.setToolTipText("A brief Identifier, such as USB I/O Library, of the module");\r
@@ -302,7 +321,7 @@ public class MsaHeader extends IInternalFrame {
         if (jTextFieldGuid == null) {\r
             jTextFieldGuid = new JTextField();\r
             jTextFieldGuid.setPreferredSize(new java.awt.Dimension(250, 20));\r
-            jTextFieldGuid.setLocation(new java.awt.Point(160, 60));\r
+            jTextFieldGuid.setLocation(new java.awt.Point(valueCol, 60));\r
             jTextFieldGuid.setSize(new java.awt.Dimension(250, 20));\r
             jTextFieldGuid.addFocusListener(this);\r
             jTextFieldGuid.setToolTipText("Guaranteed Unique Identification Number, Registry Format (8-4-4-4-12)");\r
@@ -319,9 +338,9 @@ public class MsaHeader extends IInternalFrame {
     private JTextField getJTextFieldVersion() {\r
         if (jTextFieldVersion == null) {\r
             jTextFieldVersion = new JTextField();\r
-            jTextFieldVersion.setPreferredSize(new java.awt.Dimension(320, 20));\r
-            jTextFieldVersion.setLocation(new java.awt.Point(160, 85));\r
-            jTextFieldVersion.setSize(new java.awt.Dimension(320, 20));\r
+            jTextFieldVersion.setPreferredSize(new java.awt.Dimension(valueWidth, 20));\r
+            jTextFieldVersion.setLocation(new java.awt.Point(valueCol, 85));\r
+            jTextFieldVersion.setSize(new java.awt.Dimension(valueWidth, 20));\r
             jTextFieldVersion.addFocusListener(this);\r
             jTextFieldVersion.setToolTipText("A Version Number, 1.0, 1, 1.01, 1.0.1");\r
         }\r
@@ -336,10 +355,11 @@ public class MsaHeader extends IInternalFrame {
      **/\r
     private JButton getJButtonGenerateGuid() {\r
         if (jButtonGenerateGuid == null) {\r
+            int genGuidCol = valueCol + 285;\r
             jButtonGenerateGuid = new JButton();\r
             jButtonGenerateGuid.setPreferredSize(new java.awt.Dimension(65, 20));\r
             jButtonGenerateGuid.setSize(new java.awt.Dimension(65, 20));\r
-            jButtonGenerateGuid.setLocation(new java.awt.Point(415, 60));\r
+            jButtonGenerateGuid.setLocation(new java.awt.Point(genGuidCol, 60));\r
             jButtonGenerateGuid.setText("GEN");\r
             jButtonGenerateGuid.addActionListener(this);\r
         }\r
@@ -393,15 +413,15 @@ public class MsaHeader extends IInternalFrame {
      **/\r
     private JTextField getJTextFieldSpecification() {\r
         if (jTextFieldSpecification == null) {\r
+            int specWidth = valueWidth + 50;\r
             jTextFieldSpecification = new JTextField();\r
-            \r
-            jTextFieldSpecification.setPreferredSize(new java.awt.Dimension(320, 20));\r
+\r
+            jTextFieldSpecification.setPreferredSize(new java.awt.Dimension(specWidth, 20));\r
             jTextFieldSpecification.setText("FRAMEWORK_BUILD_PACKAGING_SPECIFICATION   0x00000052");\r
             jTextFieldSpecification.setBorder(null);\r
-            \r
-            \r
-            jTextFieldSpecification.setSize(new java.awt.Dimension(320, 20));\r
-            jTextFieldSpecification.setLocation(new java.awt.Point(2, dialogHeight - 30));\r
+\r
+            jTextFieldSpecification.setSize(new java.awt.Dimension(specWidth, 20));\r
+            jTextFieldSpecification.setLocation(new java.awt.Point(labelCol, dialogHeight - 30));\r
             jTextFieldSpecification.setEditable(false);\r
             jTextFieldSpecification.addFocusListener(this);\r
         }\r
@@ -454,10 +474,10 @@ public class MsaHeader extends IInternalFrame {
         if (jScrollPaneLicense == null) {\r
             jScrollPaneLicense = new JScrollPane();\r
             jScrollPaneLicense.setHorizontalScrollBarPolicy(javax.swing.JScrollPane.HORIZONTAL_SCROLLBAR_NEVER);\r
-            jScrollPaneLicense.setSize(new java.awt.Dimension(320, 120));\r
-            jScrollPaneLicense.setLocation(new java.awt.Point(160, 305));\r
+            jScrollPaneLicense.setSize(new java.awt.Dimension(valueWidth, 120));\r
+            jScrollPaneLicense.setLocation(new java.awt.Point(valueCol, 305));\r
             jScrollPaneLicense.setViewportView(getJTextAreaLicense());\r
-            jScrollPaneLicense.setPreferredSize(new java.awt.Dimension(320, 120));\r
+            jScrollPaneLicense.setPreferredSize(new java.awt.Dimension(valueWidth, 120));\r
         }\r
         return jScrollPaneLicense;\r
     }\r
@@ -472,10 +492,10 @@ public class MsaHeader extends IInternalFrame {
         if (jScrollPaneDescription == null) {\r
             jScrollPaneDescription = new JScrollPane();\r
             jScrollPaneDescription.setHorizontalScrollBarPolicy(javax.swing.JScrollPane.HORIZONTAL_SCROLLBAR_NEVER);\r
-            jScrollPaneDescription.setSize(new java.awt.Dimension(320, 120));\r
-            jScrollPaneDescription.setLocation(new java.awt.Point(160, 135));\r
+            jScrollPaneDescription.setSize(new java.awt.Dimension(valueWidth, 120));\r
+            jScrollPaneDescription.setLocation(new java.awt.Point(valueCol, 135));\r
             jScrollPaneDescription.setViewportView(getJTextAreaDescription());\r
-            jScrollPaneDescription.setPreferredSize(new java.awt.Dimension(320, 120));\r
+            jScrollPaneDescription.setPreferredSize(new java.awt.Dimension(valueWidth, 120));\r
         }\r
         return jScrollPaneDescription;\r
     }\r
@@ -489,9 +509,9 @@ public class MsaHeader extends IInternalFrame {
     private JTextField getJTextFieldAbstract() {\r
         if (jTextFieldAbstract == null) {\r
             jTextFieldAbstract = new JTextField();\r
-            jTextFieldAbstract.setPreferredSize(new java.awt.Dimension(320, 20));\r
-            jTextFieldAbstract.setLocation(new java.awt.Point(160, 110));\r
-            jTextFieldAbstract.setSize(new java.awt.Dimension(320, 20));\r
+            jTextFieldAbstract.setPreferredSize(new java.awt.Dimension(valueWidth, 20));\r
+            jTextFieldAbstract.setLocation(new java.awt.Point(valueCol, 110));\r
+            jTextFieldAbstract.setSize(new java.awt.Dimension(valueWidth, 20));\r
             jTextFieldAbstract.addFocusListener(this);\r
             jTextFieldAbstract.setToolTipText("A one sentence description of this module.");\r
         }\r
@@ -507,8 +527,8 @@ public class MsaHeader extends IInternalFrame {
     private JComboBox getJComboBoxModuleType() {\r
         if (jComboBoxModuleType == null) {\r
             jComboBoxModuleType = new JComboBox();\r
-            jComboBoxModuleType.setBounds(new java.awt.Rectangle(160, 35, 320, 20));\r
-            jComboBoxModuleType.setPreferredSize(new java.awt.Dimension(320, 20));\r
+            jComboBoxModuleType.setBounds(new java.awt.Rectangle(valueCol, 35, valueWidth, 20));\r
+            jComboBoxModuleType.setPreferredSize(new java.awt.Dimension(valueWidth, 20));\r
             jComboBoxModuleType.addFocusListener(this);\r
         }\r
         return jComboBoxModuleType;\r
@@ -523,9 +543,9 @@ public class MsaHeader extends IInternalFrame {
     private JTextField getJTextFieldURL() {\r
         if (jTextFieldURL == null) {\r
             jTextFieldURL = new JTextField();\r
-            jTextFieldURL.setPreferredSize(new java.awt.Dimension(320, 20));\r
-            jTextFieldURL.setLocation(new java.awt.Point(160, 430));\r
-            jTextFieldURL.setSize(new java.awt.Dimension(320, 20));\r
+            jTextFieldURL.setPreferredSize(new java.awt.Dimension(valueWidth, 20));\r
+            jTextFieldURL.setLocation(new java.awt.Point(valueCol, 430));\r
+            jTextFieldURL.setSize(new java.awt.Dimension(valueWidth, 20));\r
             jTextFieldURL.addFocusListener(this);\r
             jTextFieldURL.setToolTipText("A URL for the latest version of the license.");\r
         }\r
@@ -555,10 +575,10 @@ public class MsaHeader extends IInternalFrame {
     private JScrollPane getJScrollPaneCopyright() {\r
         if (jScrollPaneCopyright == null) {\r
             jScrollPaneCopyright = new JScrollPane();\r
-            jScrollPaneCopyright.setBounds(new java.awt.Rectangle(160, 260, 320, 40));\r
-            jScrollPaneCopyright.setPreferredSize(new java.awt.Dimension(320, 40));\r
+            jScrollPaneCopyright.setBounds(new java.awt.Rectangle(valueCol, 260, valueWidth, 40));\r
+            jScrollPaneCopyright.setPreferredSize(new java.awt.Dimension(valueWidth, 40));\r
             jScrollPaneCopyright.setViewportView(getJTextAreaCopyright());\r
-            jScrollPaneCopyright.setSize(new java.awt.Dimension(320, 40));\r
+            jScrollPaneCopyright.setSize(new java.awt.Dimension(valueWidth, 40));\r
         }\r
         return jScrollPaneCopyright;\r
     }\r
@@ -577,35 +597,12 @@ public class MsaHeader extends IInternalFrame {
             jTextAreaCopyright.setWrapStyleWord(true);\r
             jTextAreaCopyright.setSelectionStart(0);\r
             jTextAreaCopyright.setSelectionEnd(0);\r
-            jTextAreaCopyright.setBounds(new java.awt.Rectangle(0, 0, 320, 40));\r
+            jTextAreaCopyright.setBounds(new java.awt.Rectangle(0, 0, valueWidth, 40));\r
             jTextAreaCopyright.setToolTipText("One or more copyright lines.");\r
         }\r
         return jTextAreaCopyright;\r
     }\r
 \r
-    /**\r
-     * This method initializes jComboBoxBinaryModule    \r
-     *  \r
-     * @return javax.swing.JComboBox    \r
-     */\r
-    private JComboBox getJComboBoxBinaryModule() {\r
-        if (jComboBoxBinaryModule == null) {\r
-            jComboBoxBinaryModule = new JComboBox();\r
-            jComboBoxBinaryModule.setBounds(new java.awt.Rectangle(160, 480, 320, 20));\r
-            jComboBoxBinaryModule.setPreferredSize(new java.awt.Dimension(320, 20));\r
-            jComboBoxBinaryModule.addFocusListener(this);\r
-            jComboBoxBinaryModule.setToolTipText("<html>Modules are either source modules <br>"\r
-                                                 + "which can be compiled or binary <br>"\r
-                                                 + "modules which are linked.  <br>"\r
-                                                 + "A module cannot contain both. <br>"\r
-                                                 + "The GUID numbers should be identical <br>"\r
-                                                 + "for a binary and source MSA, <br>"\r
-                                                 + "however the BINARY MSA should have <br>"\r
-                                                 + "a higher version number.</html>");\r
-        }\r
-        return jComboBoxBinaryModule;\r
-    }\r
-\r
     /**\r
      * This method initializes jTextFieldOutputFileBasename \r
      *  \r
@@ -614,14 +611,33 @@ public class MsaHeader extends IInternalFrame {
     private JTextField getJTextFieldOutputFileBasename() {\r
         if (jTextFieldOutputFileBasename == null) {\r
             jTextFieldOutputFileBasename = new JTextField();\r
-            jTextFieldOutputFileBasename.setBounds(new java.awt.Rectangle(160, 455, 320, 20));\r
-            jTextFieldOutputFileBasename.setPreferredSize(new java.awt.Dimension(320, 20));\r
+            jTextFieldOutputFileBasename.setBounds(new java.awt.Rectangle(valueCol, 455, valueWidth, 20));\r
+            jTextFieldOutputFileBasename.setPreferredSize(new java.awt.Dimension(valueWidth, 20));\r
             jTextFieldOutputFileBasename.addFocusListener(this);\r
             jTextFieldOutputFileBasename.setToolTipText("Enter a single word for generated output file names.");\r
         }\r
         return jTextFieldOutputFileBasename;\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.setPreferredSize(new java.awt.Dimension(valueWidth, 20));\r
+            jComboBoxPcdIsDriver.setBounds(new java.awt.Rectangle(valueCol, 530, valueWidth, 20));\r
+            jComboBoxPcdIsDriver.addItemListener(this);\r
+            jComboBoxPcdIsDriver.addFocusListener(this);\r
+            jComboBoxPcdIsDriver.setEnabled(false);\r
+            Tools.generateComboBoxByVector(jComboBoxPcdIsDriver, ed.getVPcdDriverTypes());\r
+            jComboBoxPcdIsDriver.setVisible(false);\r
+        }\r
+        return jComboBoxPcdIsDriver;\r
+    }\r
+\r
     /**\r
      This is the default constructor\r
      \r
@@ -654,8 +670,14 @@ public class MsaHeader extends IInternalFrame {
             md.setSupportedArchitectures(ed.getVSupportedArchitectures());\r
             msa.setModuleDefinitions(md);\r
         }\r
+\r
+        //\r
+        // Init items of Header, Definitions and Externs\r
+        //\r
         init(msa.getMsaHeader());\r
         init(msa.getModuleDefinitions());\r
+        init(msa.getExterns());\r
+\r
         this.setVisible(true);\r
         this.setViewMode(false);\r
     }\r
@@ -757,9 +779,9 @@ public class MsaHeader extends IInternalFrame {
                 this.setSelectedItems(Tools.convertListToVector(md.getSupportedArchitectures()));\r
             }\r
             if (md.getBinaryModule()) {\r
-                this.jComboBoxBinaryModule.setSelectedIndex(1);\r
+                this.jRadioButtonBinaryModuleTrue.setSelected(true);\r
             } else {\r
-                this.jComboBoxBinaryModule.setSelectedIndex(0);\r
+                this.jRadioButtonBinaryModuleFalse.setSelected(true);\r
             }\r
             if (md.getOutputFileBasename() != null) {\r
                 this.jTextFieldOutputFileBasename.setText(md.getOutputFileBasename());\r
@@ -767,6 +789,28 @@ public class MsaHeader extends IInternalFrame {
         }\r
     }\r
 \r
+    /**\r
+     This method initializes this\r
+     Fill values to all fields if these values are not empty\r
+     \r
+     @param inEx  The input data of ExternsDocument.Externs\r
+     \r
+     **/\r
+    private void init(ExternsDocument.Externs inEx) {\r
+        if (inEx != null) {\r
+            this.ex = inEx;\r
+            if (ex.getPcdIsDriver() != null) {\r
+                this.jCheckBoxPcd.setSelected(true);\r
+                this.jComboBoxPcdIsDriver.setEnabled(true);\r
+                this.jComboBoxPcdIsDriver.setSelectedItem(ex.getPcdIsDriver());\r
+                // TODO:  If the module type is DXE_DRIVER, set PCD_DXE_DRIVER\r
+                //        If the module type is PEIM, set PCD_PEI_DRIVER\r
+                //        If the module type is anything else, unset this!\r
+            }\r
+            this.jCheckBoxFlashMap.setSelected(ex.getTianoR8FlashMapH());\r
+        }\r
+    }\r
+\r
     /**\r
      This method initializes jContentPane\r
      \r
@@ -778,56 +822,56 @@ public class MsaHeader extends IInternalFrame {
 \r
             jLabelURL = new JLabel();\r
             jLabelURL.setText("License URL");\r
-            jLabelURL.setLocation(new java.awt.Point(15, 430));\r
-            jLabelURL.setSize(new java.awt.Dimension(140, 20));\r
+            jLabelURL.setLocation(new java.awt.Point(labelCol, 430));\r
+            jLabelURL.setSize(new java.awt.Dimension(labelWidth, 20));\r
             jLabelBaseName = new JLabel();\r
             jLabelBaseName.setText("Module Name");\r
-            jLabelBaseName.setBounds(new java.awt.Rectangle(15, 10, 140, 20));\r
+            jLabelBaseName.setBounds(new java.awt.Rectangle(labelCol, 10, labelWidth, 20));\r
             jLabelModuleType = new JLabel();\r
-            jLabelModuleType.setBounds(new java.awt.Rectangle(15, 35, 140, 20));\r
+            jLabelModuleType.setBounds(new java.awt.Rectangle(labelCol, 35, labelWidth, 20));\r
             jLabelModuleType.setText("Module Type");\r
             jLabelGuid = new JLabel();\r
             jLabelGuid.setText("Guid Value");\r
-            jLabelGuid.setLocation(new java.awt.Point(15, 60));\r
-            jLabelGuid.setSize(new java.awt.Dimension(140, 20));\r
+            jLabelGuid.setLocation(new java.awt.Point(labelCol, 60));\r
+            jLabelGuid.setSize(new java.awt.Dimension(labelWidth, 20));\r
             jLabelVersion = new JLabel();\r
             jLabelVersion.setText("Version");\r
-            jLabelVersion.setLocation(new java.awt.Point(15, 85));\r
-            jLabelVersion.setSize(new java.awt.Dimension(140, 20));\r
+            jLabelVersion.setLocation(new java.awt.Point(labelCol, 85));\r
+            jLabelVersion.setSize(new java.awt.Dimension(labelWidth, 20));\r
             jLabelAbstract = new JLabel();\r
             jLabelAbstract.setText("Abstract");\r
-            jLabelAbstract.setLocation(new java.awt.Point(15, 110));\r
-            jLabelAbstract.setSize(new java.awt.Dimension(140, 20));\r
+            jLabelAbstract.setLocation(new java.awt.Point(labelCol, 110));\r
+            jLabelAbstract.setSize(new java.awt.Dimension(labelWidth, 20));\r
             jLabelDescription = new JLabel();\r
             jLabelDescription.setText("Description");\r
-            jLabelDescription.setLocation(new java.awt.Point(15, 135));\r
-            jLabelDescription.setSize(new java.awt.Dimension(140, 20));\r
+            jLabelDescription.setLocation(new java.awt.Point(labelCol, 135));\r
+            jLabelDescription.setSize(new java.awt.Dimension(labelWidth, 20));\r
             jLabelCopyright = new JLabel();\r
             jLabelCopyright.setText("Copyright");\r
-            jLabelCopyright.setLocation(new java.awt.Point(15, 260));\r
-            jLabelCopyright.setSize(new java.awt.Dimension(140, 20));\r
+            jLabelCopyright.setLocation(new java.awt.Point(labelCol, 260));\r
+            jLabelCopyright.setSize(new java.awt.Dimension(labelWidth, 20));\r
             jLabelLicense = new JLabel();\r
             jLabelLicense.setText("License");\r
-            jLabelLicense.setLocation(new java.awt.Point(15, 305));\r
-            jLabelLicense.setSize(new java.awt.Dimension(140, 20));\r
+            jLabelLicense.setLocation(new java.awt.Point(labelCol, 305));\r
+            jLabelLicense.setSize(new java.awt.Dimension(labelWidth, 20));\r
             jLabelOutputFileBasename = new JLabel();\r
-            jLabelOutputFileBasename.setBounds(new java.awt.Rectangle(15, 455, 140, 20));\r
+            jLabelOutputFileBasename.setBounds(new java.awt.Rectangle(labelCol, 455, labelWidth, 20));\r
             jLabelOutputFileBasename.setText("Output File Basename");\r
             jLabelBinaryModule = new JLabel();\r
-            jLabelBinaryModule.setBounds(new java.awt.Rectangle(15, 480, 140, 20));\r
+            jLabelBinaryModule.setBounds(new java.awt.Rectangle(labelCol, 480, labelWidth, 20));\r
             jLabelBinaryModule.setText("Binary Module");\r
             jLabelArch = new JLabel();\r
-            jLabelArch.setBounds(new java.awt.Rectangle(15, 505, 140, 20));\r
+            jLabelArch.setBounds(new java.awt.Rectangle(labelCol, 505, labelWidth, 20));\r
             jLabelArch.setText("Supported Architectures");\r
             jLabelSpecification = new JLabel();\r
             jLabelSpecification.setText("Specification");\r
-            jLabelSpecification.setLocation(new java.awt.Point(14, 530));\r
-            jLabelSpecification.setSize(new java.awt.Dimension(140, 20));\r
+            jLabelSpecification.setLocation(new java.awt.Point(labelCol, 530));\r
+            jLabelSpecification.setSize(new java.awt.Dimension(labelWidth, 20));\r
 \r
             jContentPane = new JPanel();\r
             jContentPane.setLayout(null);\r
             jContentPane.setPreferredSize(new java.awt.Dimension(dialogWidth - 10, dialogHeight - 10));\r
-            \r
+\r
             jContentPane.addFocusListener(this);\r
 \r
             jContentPane.add(jLabelBaseName, null);\r
@@ -840,7 +884,6 @@ public class MsaHeader extends IInternalFrame {
             jContentPane.add(jLabelLicense, null);\r
             jContentPane.add(jLabelCopyright, null);\r
             jContentPane.add(jLabelDescription, null);\r
-//            jContentPane.add(jLabelSpecification, null);\r
             jContentPane.add(getJTextFieldSpecification(), null);\r
             jContentPane.add(getJButtonOk(), null);\r
             jContentPane.add(getJButtonCancel(), null);\r
@@ -855,7 +898,6 @@ public class MsaHeader extends IInternalFrame {
             jContentPane.add(jLabelOutputFileBasename, null);\r
             jContentPane.add(getJTextFieldOutputFileBasename(), null);\r
             jContentPane.add(jLabelBinaryModule, null);\r
-            jContentPane.add(getJComboBoxBinaryModule(), null);\r
             jContentPane.add(jLabelArch, null);\r
 \r
             jStarLabel1 = new StarLabel();\r
@@ -880,8 +922,6 @@ public class MsaHeader extends IInternalFrame {
             jStarLabel13.setLocation(new java.awt.Point(0, 480));\r
             jStarLabel14 = new StarLabel();\r
             jStarLabel14.setLocation(new java.awt.Point(0, 505));\r
-//            jStarLabel15 = new StarLabel();\r
-//            jStarLabel15.setLocation(new java.awt.Point(0, 530));\r
 \r
             jContentPane.add(jStarLabel1, null);\r
             jContentPane.add(jStarLabel2, null);\r
@@ -894,7 +934,6 @@ public class MsaHeader extends IInternalFrame {
             jContentPane.add(jStarLabel12, null);\r
             jContentPane.add(jStarLabel13, null);\r
             jContentPane.add(jStarLabel14, null);\r
-//            jContentPane.add(jStarLabel15, null);\r
             jContentPane.add(getJScrollPaneCopyright(), null);\r
 \r
             jContentPane.add(getJCheckBoxIa32(), null);\r
@@ -903,6 +942,16 @@ public class MsaHeader extends IInternalFrame {
             jContentPane.add(getJCheckBoxEbc(), null);\r
             jContentPane.add(getJCheckBoxArm(), null);\r
             jContentPane.add(getJCheckBoxPpc(), null);\r
+\r
+            jContentPane.add(getJCheckBoxPcd(), null);\r
+            jContentPane.add(getJComboBoxPcdIsDriver(), null);\r
+            jContentPane.add(getJCheckBoxFlashMap(), null);\r
+\r
+            ButtonGroup bg = new ButtonGroup();\r
+            jContentPane.add(getJRadioButtonBinaryModuleTrue(), null);\r
+            jContentPane.add(getJRadioButtonBinaryModuleFalse(), null);\r
+            bg.add(getJRadioButtonBinaryModuleTrue());\r
+            bg.add(getJRadioButtonBinaryModuleFalse());\r
         }\r
         return jContentPane;\r
     }\r
@@ -923,14 +972,20 @@ public class MsaHeader extends IInternalFrame {
             this.setEdited(true);\r
             this.dispose();\r
         }\r
+\r
         if (arg0.getSource() == jButtonCancel) {\r
             this.setEdited(false);\r
         }\r
+\r
         if (arg0.getSource() == jButtonGenerateGuid) {\r
             jTextFieldGuid.setText(Tools.generateUuidString());\r
             jTextFieldGuid.requestFocus();\r
             jButtonGenerateGuid.requestFocus();\r
         }\r
+\r
+        if (arg0.getSource() == this.jCheckBoxPcd) {\r
+            this.jComboBoxPcdIsDriver.setEnabled(this.jCheckBoxPcd.isSelected());\r
+        }\r
     }\r
 \r
     /**\r
@@ -997,7 +1052,8 @@ public class MsaHeader extends IInternalFrame {
             return false;\r
         }\r
         if (!DataValidation.isAbstract(this.jTextFieldAbstract.getText())) {\r
-            Log.wrn("Update Msa Header", "Incorrect data type for Abstract, is should be a sentence describing the module.");\r
+            Log.wrn("Update Msa Header",\r
+                    "Incorrect data type for Abstract, is should be a sentence describing the module.");\r
             //this.jTextFieldAbstract.requestFocus();\r
             return false;\r
         }\r
@@ -1074,7 +1130,6 @@ public class MsaHeader extends IInternalFrame {
     private void initFrame() {\r
         EnumerationData ed = new EnumerationData();\r
         Tools.generateComboBoxByVector(jComboBoxModuleType, ed.getVModuleType());\r
-        Tools.generateComboBoxByVector(jComboBoxBinaryModule, ed.getVBoolean());\r
         this.setSelectedItems(ed.getVSupportedArchitectures());\r
     }\r
 \r
@@ -1117,11 +1172,11 @@ public class MsaHeader extends IInternalFrame {
         Tools.resizeComponentWidth(this.jTextFieldSpecification, intCurrentWidth, intPreferredWidth);\r
         Tools.resizeComponentWidth(this.jTextFieldAbstract, intCurrentWidth, intPreferredWidth);\r
         Tools.resizeComponentWidth(this.jComboBoxModuleType, intCurrentWidth, intPreferredWidth);\r
-        Tools.resizeComponentWidth(this.jComboBoxBinaryModule, intCurrentWidth, intPreferredWidth);\r
         Tools.resizeComponentWidth(this.jTextFieldOutputFileBasename, intCurrentWidth, intPreferredWidth);\r
+        Tools.resizeComponentWidth(this.jComboBoxPcdIsDriver, intCurrentWidth, intPreferredWidth);\r
 \r
         Tools.relocateComponentX(this.jButtonGenerateGuid, intCurrentWidth, intPreferredWidth,\r
-                           DataType.SPACE_TO_RIGHT_FOR_GENERATE_BUTTON);\r
+                                 DataType.SPACE_TO_RIGHT_FOR_GENERATE_BUTTON);\r
     }\r
 \r
     public void focusLost(FocusEvent arg0) {\r
@@ -1318,14 +1373,21 @@ public class MsaHeader extends IInternalFrame {
         //\r
         // Check Binary Module Type\r
         //\r
-        if (arg0.getSource() == this.jComboBoxBinaryModule) {\r
-            if (jComboBoxBinaryModule.getSelectedItem().toString().equals(DataType.TRUE)) {\r
+        if (arg0.getSource() == this.jRadioButtonBinaryModuleTrue) {\r
+            if (jRadioButtonBinaryModuleTrue.isSelected()) {\r
                 if (md.getBinaryModule()) {\r
                     return;\r
                 } else {\r
                     md.setBinaryModule(true);\r
                 }\r
-            } else if (jComboBoxBinaryModule.getSelectedItem().toString().equals(DataType.FALSE)) {\r
+            }\r
+        }\r
+\r
+        //\r
+        // Check Binary Module Type\r
+        //\r
+        if (arg0.getSource() == this.jRadioButtonBinaryModuleFalse) {\r
+            if (jRadioButtonBinaryModuleFalse.isSelected()) {\r
                 if (md.getBinaryModule()) {\r
                     md.setBinaryModule(false);\r
                 } else {\r
@@ -1347,6 +1409,84 @@ public class MsaHeader extends IInternalFrame {
             }\r
         }\r
 \r
+        //\r
+        // Check Pcd is Driver\r
+        //\r
+        if (arg0.getSource() == this.jCheckBoxPcd || arg0.getSource() == this.jComboBoxPcdIsDriver) {\r
+            if ((this.ex == null) && this.jCheckBoxPcd.isSelected()) {\r
+                this.ex = ExternsDocument.Externs.Factory.newInstance();\r
+                this.ex.setPcdIsDriver(PcdDriverTypes.Enum.forString(this.jComboBoxPcdIsDriver.getSelectedItem()\r
+                                                                                              .toString()));\r
+                this.msa.setExterns(this.ex);\r
+            } else if ((this.ex != null) && (this.ex.getPcdIsDriver() == null) && this.jCheckBoxPcd.isSelected()) {\r
+                this.ex.setPcdIsDriver(PcdDriverTypes.Enum.forString(this.jComboBoxPcdIsDriver.getSelectedItem()\r
+                                                                                              .toString()));\r
+                this.msa.setExterns(this.ex);\r
+            } else if ((this.ex != null) && (this.ex.getPcdIsDriver() != null)) {\r
+                if (this.jCheckBoxPcd.isSelected()\r
+                    && !this.jComboBoxPcdIsDriver.getSelectedItem().toString().equals(\r
+                                                                                      this.ex.getPcdIsDriver()\r
+                                                                                             .toString())) {\r
+                    this.ex.setPcdIsDriver(PcdDriverTypes.Enum.forString(this.jComboBoxPcdIsDriver.getSelectedItem()\r
+                                                                                                  .toString()));\r
+                    this.msa.setExterns(this.ex);\r
+                }\r
+                if (!this.jCheckBoxPcd.isSelected()) {\r
+                    ExternsDocument.Externs newEx = ExternsDocument.Externs.Factory.newInstance();\r
+                    if (this.ex.getExternList() != null) {\r
+                        for (int index = 0; index < this.ex.getExternList().size(); index++) {\r
+                            newEx.addNewExtern();\r
+                            newEx.setExternArray(index, this.ex.getExternArray(index));\r
+                        }\r
+                    }\r
+                    if (this.ex.getSpecificationList() != null) {\r
+                        for (int index = 0; index < this.ex.getSpecificationList().size(); index++) {\r
+                            newEx.addNewSpecification();\r
+                            newEx.setSpecificationArray(index, this.ex.getSpecificationArray(index));\r
+                        }\r
+                    }\r
+                    if (this.ex.getTianoR8FlashMapH()) {\r
+                        newEx.setTianoR8FlashMapH(this.ex.getTianoR8FlashMapH());\r
+                    }\r
+                    this.ex = newEx;\r
+                    this.msa.setExterns(this.ex);\r
+                }\r
+            }\r
+        }\r
+\r
+        //\r
+        // Check Flash Map\r
+        //\r
+        if (arg0.getSource() == this.jCheckBoxFlashMap) {\r
+            if ((this.ex == null) && this.jCheckBoxFlashMap.isSelected()) {\r
+                this.ex = ExternsDocument.Externs.Factory.newInstance();\r
+                this.ex.setTianoR8FlashMapH(this.jCheckBoxFlashMap.isSelected());\r
+                this.msa.setExterns(this.ex);\r
+            } else if ((this.ex != null) && this.jCheckBoxFlashMap.isSelected()) {\r
+                this.ex.setTianoR8FlashMapH(this.jCheckBoxFlashMap.isSelected());\r
+                this.msa.setExterns(this.ex);\r
+            } else if ((this.ex != null) && !this.jCheckBoxFlashMap.isSelected()) {\r
+                ExternsDocument.Externs newEx = ExternsDocument.Externs.Factory.newInstance();\r
+                if (this.ex.getExternList() != null) {\r
+                    for (int index = 0; index < this.ex.getExternList().size(); index++) {\r
+                        newEx.addNewExtern();\r
+                        newEx.setExternArray(index, this.ex.getExternArray(index));\r
+                    }\r
+                }\r
+                if (this.ex.getSpecificationList() != null) {\r
+                    for (int index = 0; index < this.ex.getSpecificationList().size(); index++) {\r
+                        newEx.addNewSpecification();\r
+                        newEx.setSpecificationArray(index, this.ex.getSpecificationArray(index));\r
+                    }\r
+                }\r
+                if (this.ex.getPcdIsDriver() != null) {\r
+                    newEx.setPcdIsDriver(this.ex.getPcdIsDriver());\r
+                }\r
+                this.ex = newEx;\r
+                this.msa.setExterns(this.ex);\r
+            }\r
+        }\r
+\r
         this.save();\r
     }\r
 \r
@@ -1436,4 +1576,82 @@ public class MsaHeader extends IInternalFrame {
             }\r
         }\r
     }\r
+\r
+    /**\r
+     * This method initializes jCheckBoxPcd    \r
+     *         \r
+     * @return javax.swing.JCheckBox   \r
+     */\r
+    private JCheckBox getJCheckBoxPcd() {\r
+        if (jCheckBoxPcd == null) {\r
+            jCheckBoxPcd = new JCheckBox();\r
+            jCheckBoxPcd.setBounds(new java.awt.Rectangle(labelCol, 530, labelWidth, 20));\r
+            jCheckBoxPcd.setText("Is this a PCD Driver?");\r
+            jCheckBoxPcd.addFocusListener(this);\r
+            jCheckBoxPcd.addActionListener(this);\r
+        }\r
+        return jCheckBoxPcd;\r
+    }\r
+\r
+    /**\r
+     * This method initializes jCheckBoxFlashMap       \r
+     *         \r
+     * @return javax.swing.JCheckBox   \r
+     */\r
+    private JCheckBox getJCheckBoxFlashMap() {\r
+        if (jCheckBoxFlashMap == null) {\r
+            jCheckBoxFlashMap = new JCheckBox();\r
+            jCheckBoxFlashMap.setBounds(new java.awt.Rectangle(labelCol, 555, 480, 20));\r
+            jCheckBoxFlashMap.setText("Does this module require a legacy FlashMap header file?");\r
+            jCheckBoxFlashMap.addFocusListener(this);\r
+        }\r
+        return jCheckBoxFlashMap;\r
+    }\r
+\r
+    /**\r
+     * This method initializes jRadioButtonBinaryModuleTrue    \r
+     *         \r
+     * @return javax.swing.JRadioButton        \r
+     */\r
+    private JRadioButton getJRadioButtonBinaryModuleTrue() {\r
+        if (jRadioButtonBinaryModuleTrue == null) {\r
+            jRadioButtonBinaryModuleTrue = new JRadioButton();\r
+            jRadioButtonBinaryModuleTrue.setBounds(new java.awt.Rectangle(valueCol, 480, 140, 20));\r
+            jRadioButtonBinaryModuleTrue.setText("True");\r
+            jRadioButtonBinaryModuleTrue.setSelected(true);\r
+            jRadioButtonBinaryModuleTrue.addFocusListener(this);\r
+            jRadioButtonBinaryModuleTrue.setToolTipText("<html>Modules are either source modules <br>"\r
+                                                        + "which can be compiled or binary <br>"\r
+                                                        + "modules which are linked.  <br>"\r
+                                                        + "A module cannot contain both. <br>"\r
+                                                        + "The GUID numbers should be identical <br>"\r
+                                                        + "for a binary and source MSA, <br>"\r
+                                                        + "however the BINARY MSA should have <br>"\r
+                                                        + "a higher version number.</html>");\r
+        }\r
+        return jRadioButtonBinaryModuleTrue;\r
+    }\r
+\r
+    /**\r
+     * This method initializes jRadioButtonBinaryModuleFalse   \r
+     *         \r
+     * @return javax.swing.JRadioButton        \r
+     */\r
+    private JRadioButton getJRadioButtonBinaryModuleFalse() {\r
+        if (jRadioButtonBinaryModuleFalse == null) {\r
+            jRadioButtonBinaryModuleFalse = new JRadioButton();\r
+            jRadioButtonBinaryModuleFalse.setBounds(new java.awt.Rectangle(valueCol + 140, 480, 140, 20));\r
+            jRadioButtonBinaryModuleFalse.setText("False");\r
+            jRadioButtonBinaryModuleFalse.addFocusListener(this);\r
+            jRadioButtonBinaryModuleFalse.setToolTipText("<html>Modules are either source modules <br>"\r
+                                                         + "which can be compiled or binary <br>"\r
+                                                         + "modules which are linked.  <br>"\r
+                                                         + "A module cannot contain both. <br>"\r
+                                                         + "The GUID numbers should be identical <br>"\r
+                                                         + "for a binary and source MSA, <br>"\r
+                                                         + "however the BINARY MSA should have <br>"\r
+                                                         + "a higher version number.</html>");\r
+        }\r
+        return jRadioButtonBinaryModuleFalse;\r
+    }\r
 }\r