]> git.proxmox.com Git - mirror_edk2.git/blobdiff - Tools/Source/FrameworkWizard/src/org/tianocore/frameworkwizard/platform/ui/FpdFileContents.java
a. Enhanced toolchain setting UI for ModuleSa build options and global build options.
[mirror_edk2.git] / Tools / Source / FrameworkWizard / src / org / tianocore / frameworkwizard / platform / ui / FpdFileContents.java
index d97f2a7cba0d101f4dca1c78367ee0fa0732434a..9e2f955599a4130847bee90aac003e4b48a78ad6 100644 (file)
@@ -23,6 +23,7 @@ import java.util.List;
 import java.util.ListIterator;\r
 import java.util.Map;\r
 import java.util.Set;\r
+import java.util.Vector;\r
 \r
 import javax.xml.namespace.QName;\r
 \r
@@ -32,11 +33,14 @@ import org.apache.xmlbeans.XmlOptions;
 import org.tianocore.AntTaskDocument;\r
 import org.tianocore.BuildOptionsDocument;\r
 import org.tianocore.DynamicPcdBuildDefinitionsDocument;\r
+import org.tianocore.EfiSectionType;\r
 import org.tianocore.FlashDefinitionFileDocument;\r
 import org.tianocore.FlashDocument;\r
 import org.tianocore.FrameworkModulesDocument;\r
+import org.tianocore.IntermediateOutputType;\r
 import org.tianocore.LibrariesDocument;\r
 import org.tianocore.ModuleSADocument;\r
+import org.tianocore.ModuleSaBuildOptionsDocument;\r
 import org.tianocore.ModuleSurfaceAreaDocument;\r
 import org.tianocore.OptionDocument;\r
 import org.tianocore.OptionsDocument;\r
@@ -53,10 +57,11 @@ import org.tianocore.LicenseDocument;
 import org.tianocore.PlatformHeaderDocument;\r
 import org.tianocore.SkuInfoDocument;\r
 import org.tianocore.UserDefinedAntTasksDocument;\r
-import org.tianocore.frameworkwizard.platform.ui.global.GlobalData;\r
+import org.tianocore.UserExtensionsDocument;\r
+import org.tianocore.frameworkwizard.platform.ui.global.WorkspaceProfile;\r
 import org.tianocore.frameworkwizard.platform.ui.global.SurfaceAreaQuery;\r
-import org.tianocore.frameworkwizard.platform.ui.id.ModuleIdentification;\r
-import org.tianocore.frameworkwizard.platform.ui.id.PackageIdentification;\r
+import org.tianocore.frameworkwizard.module.Identifications.ModuleIdentification;\r
+import org.tianocore.frameworkwizard.packaging.PackageIdentification;\r
 \r
 /**\r
  This class processes fpd file contents such as add remove xml elements. \r
@@ -82,7 +87,9 @@ public class FpdFileContents {
     \r
     private DynamicPcdBuildDefinitionsDocument.DynamicPcdBuildDefinitions fpdDynPcdBuildDefs = null;\r
     \r
-    public static HashMap<String, ArrayList<String>> dynPcdMap = null;\r
+    private HashMap<String, ArrayList<String>> dynPcdMap = null;\r
+    \r
+    private HashMap<String, String> defaultPcdValue = new HashMap<String, String>();\r
     \r
     /**\r
      * look through all pcd data in all ModuleSA, create pcd -> ModuleSA mappings.\r
@@ -92,17 +99,19 @@ public class FpdFileContents {
           dynPcdMap = new HashMap<String, ArrayList<String>>();\r
           List<ModuleSADocument.ModuleSA> l = getfpdFrameworkModules().getModuleSAList();\r
           if (l == null) {\r
+              removeElement(getfpdFrameworkModules());\r
+              fpdFrameworkModules = null;\r
               return;\r
           }\r
           ListIterator<ModuleSADocument.ModuleSA> li = l.listIterator();\r
           while (li.hasNext()) {\r
-              ModuleSADocument.ModuleSA msa = li.next();\r
-              if (msa.getPcdBuildDefinition() == null || msa.getPcdBuildDefinition().getPcdDataList() == null) {\r
+              ModuleSADocument.ModuleSA moduleSa = li.next();\r
+              if (moduleSa.getPcdBuildDefinition() == null || moduleSa.getPcdBuildDefinition().getPcdDataList() == null) {\r
                   continue;\r
               }\r
-              String ModuleInfo = msa.getModuleGuid() + " " + msa.getModuleVersion() +\r
-               " " + msa.getPackageGuid() + " " + msa.getPackageVersion();\r
-              List<PcdBuildDefinitionDocument.PcdBuildDefinition.PcdData> lp = msa.getPcdBuildDefinition().getPcdDataList();\r
+              String ModuleInfo = moduleSa.getModuleGuid() + " " + moduleSa.getModuleVersion() +\r
+               " " + moduleSa.getPackageGuid() + " " + moduleSa.getPackageVersion() + " " + listToString(moduleSa.getSupArchList());\r
+              List<PcdBuildDefinitionDocument.PcdBuildDefinition.PcdData> lp = moduleSa.getPcdBuildDefinition().getPcdDataList();\r
               ListIterator<PcdBuildDefinitionDocument.PcdBuildDefinition.PcdData> lpi = lp.listIterator();\r
               while (lpi.hasNext()) {\r
                   PcdBuildDefinitionDocument.PcdBuildDefinition.PcdData pcdData = lpi.next();\r
@@ -119,6 +128,10 @@ public class FpdFileContents {
           }\r
       }\r
     }\r
+    \r
+    public ArrayList<String> getDynPcdMapValue(String key) {\r
+        return dynPcdMap.get(key);\r
+    }\r
     /**\r
      Constructor to create a new spd file\r
      **/\r
@@ -171,31 +184,36 @@ public class FpdFileContents {
         return fpdFrameworkModules;\r
     }\r
     \r
-    public int getPlatformDefsSkuInfoCount(){\r
-        if (getfpdPlatformDefs().getSkuInfo() == null || getfpdPlatformDefs().getSkuInfo().getUiSkuNameList() == null) {\r
-            return 0;\r
-        }\r
-        return getfpdPlatformDefs().getSkuInfo().getUiSkuNameList().size();\r
-    }\r
-    \r
-    public void getPlatformDefsSkuInfos(String[][] saa){\r
-        if (getfpdPlatformDefs().getSkuInfo() == null || getfpdPlatformDefs().getSkuInfo().getUiSkuNameList() == null) {\r
-            return ;\r
+    public void getFrameworkModuleGuid (String fvName, Vector<String> vGuid) {\r
+        if (getFrameworkModulesCount() == 0){\r
+            return;\r
         }\r
         \r
-        List<SkuInfoDocument.SkuInfo.UiSkuName> l = getfpdPlatformDefs().getSkuInfo().getUiSkuNameList();\r
-        ListIterator<SkuInfoDocument.SkuInfo.UiSkuName> li = l.listIterator();\r
-        int i = 0;\r
+        ListIterator li = getfpdFrameworkModules().getModuleSAList().listIterator();\r
         while(li.hasNext()) {\r
-            SkuInfoDocument.SkuInfo.UiSkuName sku = li.next();\r
-            saa[i][0] = sku.getSkuID()+"";\r
-            saa[i][1] = sku.getStringValue();\r
-            ++i;\r
+            ModuleSADocument.ModuleSA moduleSa = (ModuleSADocument.ModuleSA)li.next();\r
+            if (moduleSa.getModuleSaBuildOptions() == null) {\r
+                continue;\r
+            }\r
+            String fvBinding = moduleSa.getModuleSaBuildOptions().getFvBinding();\r
+            if (fvBinding == null) {\r
+                continue;\r
+            }\r
+            \r
+            String[] fvNames = fvBinding.split(" ");\r
+            for (int i = 0; i < fvNames.length; ++i) {\r
+                if (fvNames[i].equals(fvName) || fvNames[i].replaceAll("_", "").equals(fvName)) {\r
+                    vGuid.add(moduleSa.getModuleGuid());\r
+                    break;\r
+                }\r
+            }\r
         }\r
     }\r
     \r
     public int getFrameworkModulesCount() {\r
-        if (getfpdFrameworkModules().getModuleSAList() == null){\r
+        if (getfpdFrameworkModules().getModuleSAList() == null || getfpdFrameworkModules().getModuleSAList().size() == 0){\r
+            removeElement(getfpdFrameworkModules());\r
+            fpdFrameworkModules = null;\r
             return 0;\r
         }\r
         return getfpdFrameworkModules().getModuleSAList().size();\r
@@ -209,35 +227,80 @@ public class FpdFileContents {
         ListIterator li = getfpdFrameworkModules().getModuleSAList().listIterator();\r
         int i = 0;\r
         while(li.hasNext()) {\r
-            ModuleSADocument.ModuleSA msa = (ModuleSADocument.ModuleSA)li.next();\r
-            saa[i][1] = msa.getModuleGuid();\r
-            saa[i][2] = msa.getModuleVersion();\r
+            ModuleSADocument.ModuleSA moduleSa = (ModuleSADocument.ModuleSA)li.next();\r
+            saa[i][0] = moduleSa.getModuleGuid();\r
+            saa[i][1] = moduleSa.getModuleVersion();\r
             \r
-            saa[i][3] = msa.getPackageGuid();\r
-            saa[i][4] = msa.getPackageVersion();\r
-//            saa[i][4] = listToString(msa.getSupArchList());\r
+            saa[i][2] = moduleSa.getPackageGuid();\r
+            saa[i][3] = moduleSa.getPackageVersion();\r
+            saa[i][4] = listToString(moduleSa.getSupArchList());\r
             ++i;\r
         }\r
     }\r
     \r
+    public void getFrameworkModuleInfo(int i, String[] sa) {\r
+        ModuleSADocument.ModuleSA msa = getModuleSA(i);\r
+        if (msa == null) {\r
+            return;\r
+        }\r
+        sa[0] = msa.getModuleGuid();\r
+        sa[1] = msa.getModuleVersion();\r
+        sa[2] = msa.getPackageGuid();\r
+        sa[3] = msa.getPackageVersion();\r
+        sa[4] = listToString(msa.getSupArchList());\r
+    }\r
+    \r
     public ModuleSADocument.ModuleSA getModuleSA(String key) {\r
         String[] s = key.split(" ");\r
-        if (getfpdFrameworkModules().getModuleSAList() == null) {\r
+        if (getfpdFrameworkModules().getModuleSAList() == null || getfpdFrameworkModules().getModuleSAList().size() == 0) {\r
+            removeElement(getfpdFrameworkModules());\r
+            fpdFrameworkModules = null;\r
             return null;\r
         }\r
         ListIterator li = getfpdFrameworkModules().getModuleSAList().listIterator();\r
         while(li.hasNext()) {\r
-            ModuleSADocument.ModuleSA msa = (ModuleSADocument.ModuleSA)li.next();\r
-            if (msa.getModuleGuid().equals(s[0]) && msa.getModuleVersion().equals(s[1])\r
-                            && msa.getPackageGuid().equals(s[2]) && msa.getPackageVersion().equals(s[3])) {\r
-                \r
-                return msa;\r
+            ModuleSADocument.ModuleSA moduleSa = (ModuleSADocument.ModuleSA)li.next();\r
+            if (moduleSa.getModuleGuid().equalsIgnoreCase(s[0]) && moduleSa.getPackageGuid().equalsIgnoreCase(s[2])) {\r
+                if (moduleSa.getModuleVersion() != null) {\r
+                    if (!moduleSa.getModuleVersion().equals(s[1])) {\r
+                        continue;\r
+                    }\r
+                }\r
+                if (moduleSa.getPackageVersion() != null) {\r
+                    if (!moduleSa.getPackageVersion().equals(s[3])) {\r
+                        continue;\r
+                    }\r
+                }\r
+                //ToDo add arch check for s[4]\r
+                if (moduleSa.getSupArchList() != null) {\r
+                    if (!listToString(moduleSa.getSupArchList()).equals(s[4])) {\r
+                        continue;\r
+                    }\r
+                }\r
+                return moduleSa;\r
             }\r
         }\r
         return null;\r
     }\r
+    \r
+    private ModuleSADocument.ModuleSA getModuleSA(int i) {\r
+        ModuleSADocument.ModuleSA moduleSa = null;\r
+        if (fpdRoot.getFrameworkModules() == null) {\r
+            return null;\r
+        }\r
+        XmlCursor cursor = fpdRoot.getFrameworkModules().newCursor();\r
+        if (cursor.toFirstChild()) {\r
+            for (int j = 0; j < i; ++j) {\r
+                cursor.toNextSibling();\r
+            }\r
+            moduleSa = (ModuleSADocument.ModuleSA)cursor.getObject();\r
+        }\r
+        cursor.dispose();\r
+        return moduleSa;\r
+    }\r
+    \r
     public void removeModuleSA(int i) {\r
-        XmlObject o = getfpdFrameworkModules();\r
+        XmlObject o = fpdRoot.getFrameworkModules();\r
         if (o == null) {\r
             return;\r
         }\r
@@ -252,112 +315,347 @@ public class FpdFileContents {
             //\r
             ModuleSADocument.ModuleSA moduleSa = (ModuleSADocument.ModuleSA)cursor.getObject();\r
             String moduleInfo = moduleSa.getModuleGuid() + " " + moduleSa.getModuleVersion() + " " +\r
-            moduleSa.getPackageGuid()+ " " + moduleSa.getPackageVersion();\r
+            moduleSa.getPackageGuid()+ " " + moduleSa.getPackageVersion() + " " + listToString(moduleSa.getSupArchList());\r
             PcdBuildDefinitionDocument.PcdBuildDefinition pcdBuildDef = moduleSa.getPcdBuildDefinition();\r
-            if (pcdBuildDef != null) {\r
-                maintainDynPcdMap(pcdBuildDef, moduleInfo);\r
+            if (pcdBuildDef != null && pcdBuildDef.getPcdDataList() != null) {\r
+                ListIterator<PcdBuildDefinitionDocument.PcdBuildDefinition.PcdData> li = pcdBuildDef.getPcdDataList().listIterator();\r
+                while(li.hasNext()) {\r
+                    PcdBuildDefinitionDocument.PcdBuildDefinition.PcdData pcdData = li.next();\r
+                    maintainDynPcdMap(pcdData.getCName() + " " + pcdData.getTokenSpaceGuidCName(), moduleInfo);\r
+                }\r
+            }\r
+            \r
+            cursor.push();\r
+            cursor.toPrevToken();\r
+            if (cursor.isComment()) {\r
+                cursor.removeXml();\r
             }\r
+            cursor.pop();\r
             cursor.removeXml();\r
+            if (getFrameworkModulesCount() == 0) {\r
+                cursor.toParent();\r
+                cursor.removeXml();\r
+            }\r
         }\r
         cursor.dispose();\r
     }\r
     \r
-    private void maintainDynPcdMap(PcdBuildDefinitionDocument.PcdBuildDefinition o, String moduleInfo) {\r
-        XmlCursor cursor = o.newCursor();\r
-        boolean fromLibInstance = false;\r
-        if (!cursor.toFirstChild()){\r
-            return;\r
+    public boolean adjustPcd (int seqModuleSa) throws Exception {\r
+        boolean dataModified = false;\r
+        ModuleSADocument.ModuleSA moduleSa = getModuleSA(seqModuleSa);\r
+        int pcdCount = getPcdDataCount(seqModuleSa);\r
+        String[][] saaModuleSaPcd = new String[pcdCount][7];\r
+        getPcdData(seqModuleSa, saaModuleSaPcd);\r
+        String mg = moduleSa.getModuleGuid();\r
+        String mv = moduleSa.getModuleVersion();\r
+        String pg = moduleSa.getPackageGuid();\r
+        String pv = moduleSa.getPackageVersion();\r
+        String arch = listToString(moduleSa.getSupArchList());\r
+        //\r
+        // delete pcd in ModuleSA but not in MSA files any longer.\r
+        //\r
+        String moduleKey = mg + " " + mv + " " + pg + " " + pv + " " + arch;\r
+        int libCount = getLibraryInstancesCount(moduleKey);\r
+        String[][] saaLib = new String[libCount][5];\r
+        getLibraryInstances(moduleKey, saaLib);\r
+        ModuleIdentification mi = WorkspaceProfile.getModuleId(moduleKey);\r
+        Vector<ModuleIdentification> vMi = new Vector<ModuleIdentification>();\r
+        vMi.add(mi);\r
+        try {\r
+    nextPcd:for (int i = 0; i < saaModuleSaPcd.length; ++i) {\r
+                if (WorkspaceProfile.pcdInMsa(saaModuleSaPcd[i][0], saaModuleSaPcd[i][1], mi)){\r
+                    continue;\r
+                }\r
+                for (int j = 0; j < saaLib.length; ++j) {\r
+                    String libKey = saaLib[j][1] + " " + saaLib[j][2] + " " + saaLib[j][3] + " " + saaLib[j][4];\r
+                    ModuleIdentification libMi = WorkspaceProfile.getModuleId(libKey);\r
+                    vMi.add(libMi);\r
+                    if (WorkspaceProfile.pcdInMsa(saaModuleSaPcd[i][0], saaModuleSaPcd[i][1], libMi)) {\r
+                        continue nextPcd;\r
+                    }\r
+                }\r
+                removePcdData(seqModuleSa, saaModuleSaPcd[i][0], saaModuleSaPcd[i][1]);\r
+                dataModified = true;\r
+            }\r
+        }\r
+        catch (Exception e) {\r
+            \r
         }\r
         //\r
-        // deal with first child, same process in the while loop below for siblings.\r
+        // add new Pcd from MSA file to ModuleSA.\r
         //\r
-        PcdBuildDefinitionDocument.PcdBuildDefinition.PcdData pcdData = (PcdBuildDefinitionDocument.PcdBuildDefinition.PcdData)cursor.getObject();\r
-        String pcdKey = pcdData.getCName() + " " + pcdData.getTokenSpaceGuidCName();\r
+        try {\r
+       \r
+            for (int i = 0; i < vMi.size(); ++i) {\r
+                ModuleSurfaceAreaDocument.ModuleSurfaceArea msa = (ModuleSurfaceAreaDocument.ModuleSurfaceArea) WorkspaceProfile\r
+                                                                                                                          .getModuleXmlObject(vMi\r
+                                                                                                                                                 .get(i));\r
+                if (msa.getPcdCoded() == null || msa.getPcdCoded().getPcdEntryList() == null) {\r
+                    continue;\r
+                }\r
+                ListIterator li = msa.getPcdCoded().getPcdEntryList().listIterator();\r
+     msaPcdIter:while (li.hasNext()) {\r
+                    PcdCodedDocument.PcdCoded.PcdEntry msaPcd = (PcdCodedDocument.PcdCoded.PcdEntry) li.next();\r
+                    ArrayList<String> al = getDynPcdMapValue(msaPcd.getCName() + " " + msaPcd.getTokenSpaceGuidCName());\r
+                    if (al != null) {\r
+                        for (int j = 0; j < al.size(); ++j) {\r
+                            if (al.get(j).contains(moduleKey)) {\r
+                                continue msaPcdIter;\r
+                            }\r
+                        }\r
+                    }\r
+                    \r
+                    Map<String, XmlObject> m = new HashMap<String, XmlObject>();\r
+                    m.put("ModuleSurfaceArea", msa);\r
+                    SurfaceAreaQuery.setDoc(m);\r
+                    PackageIdentification[] depPkgs = SurfaceAreaQuery.getDependencePkg(null, vMi.get(i));\r
+                    PcdDeclarationsDocument.PcdDeclarations.PcdEntry spdPcd = LookupPcdDeclaration(msaPcd, depPkgs);\r
+                    if (spdPcd == null) {\r
+                        //\r
+                        // ToDo Error \r
+                        //\r
+                        throw new PcdDeclNotFound("No Declaration for PCD Entry " + msaPcd.getCName() + " in Module "\r
+                                                  + mi.getName());\r
+                    }\r
+                    //\r
+                    // AddItem to ModuleSA PcdBuildDefinitions\r
+                    //\r
+                    String defaultVal = msaPcd.getDefaultValue() == null ? spdPcd.getDefaultValue()\r
+                                                                        : msaPcd.getDefaultValue();\r
+\r
+                    genPcdData(msaPcd.getCName(), spdPcd.getToken(), msaPcd.getTokenSpaceGuidCName(),\r
+                               msaPcd.getPcdItemType().toString(), spdPcd.getDatumType() + "", defaultVal, moduleSa);\r
+                    dataModified = true;\r
+                 }\r
+\r
+            }\r
+        }\r
+        catch (Exception e){\r
+           throw e;\r
+        }\r
+        \r
+        return dataModified;\r
+    }\r
+    \r
+    private void maintainDynPcdMap(String pcdKey, String moduleInfo) {\r
+        \r
         ArrayList<String> al = dynPcdMap.get(pcdKey);\r
+        if (al == null) {\r
+            return;\r
+        }\r
+        String[] s = moduleInfo.split(" ");\r
         for(int i = 0; i < al.size(); ++i){\r
-            if (al.get(i).startsWith(moduleInfo)){\r
-                fromLibInstance = true;\r
+            String consumer = al.get(i);\r
+            if (consumer.contains(s[0]) && consumer.contains(s[2])){\r
+                String[] consumerPart = consumer.split(" ");\r
+                if (!consumerPart[4].equals(s[4])) {\r
+                    continue;\r
+                }\r
+                al.remove(consumer);\r
                 break;\r
             }\r
         }\r
-        al.remove(moduleInfo + " " + pcdData.getItemType().toString());\r
+\r
         if (al.size() == 0) {\r
+            defaultPcdValue.remove(pcdKey);\r
             dynPcdMap.remove(pcdKey);\r
+            String[] s1 = pcdKey.split(" ");\r
+            removeDynamicPcdBuildData(s1[0], s1[1]);\r
+        }\r
+        \r
+    }\r
+    //\r
+    // key for ModuleSA : "ModuleGuid ModuleVer PackageGuid PackageVer Arch"\r
+    //\r
+    public int getPcdDataCount (int i){\r
+        ModuleSADocument.ModuleSA msa = getModuleSA(i);\r
+        \r
+        if (msa == null || msa.getPcdBuildDefinition() == null || msa.getPcdBuildDefinition().getPcdDataList() == null){\r
+            return 0;\r
+        }\r
+        return msa.getPcdBuildDefinition().getPcdDataList().size();\r
+        \r
+    }\r
+    \r
+    public void getPcdData (int i, String[][] saa) {\r
+        ModuleSADocument.ModuleSA msa = getModuleSA(i);\r
+        \r
+        if (msa == null || msa.getPcdBuildDefinition() == null || msa.getPcdBuildDefinition().getPcdDataList() == null){\r
+            return;\r
+        }\r
+        ListIterator<PcdBuildDefinitionDocument.PcdBuildDefinition.PcdData>li = msa.getPcdBuildDefinition().getPcdDataList().listIterator();\r
+        for (int k = 0; k < saa.length; ++k) {\r
+            PcdBuildDefinitionDocument.PcdBuildDefinition.PcdData pcdData = li.next();\r
+            saa[k][0] = pcdData.getCName();\r
+            saa[k][1] = pcdData.getTokenSpaceGuidCName();\r
+            saa[k][2] = pcdData.getItemType()+"";\r
+            saa[k][3] = pcdData.getToken().toString();\r
+            saa[k][4] = pcdData.getMaxDatumSize()+"";\r
+            saa[k][5] = pcdData.getDatumType()+"";\r
+            saa[k][6] = pcdData.getValue();\r
+            \r
+        }\r
+    }\r
+    \r
+    public void removePcdData (int seqModuleSa, String cName, String tsGuid) {\r
+        ModuleSADocument.ModuleSA moduleSa = getModuleSA(seqModuleSa);\r
+        if (moduleSa == null || moduleSa.getPcdBuildDefinition() == null){\r
+            return;\r
         }\r
         \r
-        if (pcdData.getItemType().toString().equals("DYNAMIC")) {\r
-            if (dynPcdMap.get(pcdKey) == null) {\r
-                removeDynamicPcdBuildData(pcdData.getCName(), pcdData.getTokenSpaceGuidCName());\r
+        String mg = moduleSa.getModuleGuid();\r
+        String mv = moduleSa.getModuleVersion();\r
+        String pg = moduleSa.getPackageGuid();\r
+        String pv = moduleSa.getPackageVersion();\r
+        String arch = listToString(moduleSa.getSupArchList());\r
+        String moduleKey = mg + " " + mv + " " + pg + " " + pv + " " + arch;\r
+        \r
+        XmlCursor cursor = moduleSa.getPcdBuildDefinition().newCursor();\r
+        if (cursor.toFirstChild()){\r
+            \r
+            do {\r
+                PcdBuildDefinitionDocument.PcdBuildDefinition.PcdData pcdData = (PcdBuildDefinitionDocument.PcdBuildDefinition.PcdData)cursor.getObject();\r
+                if (pcdData.getCName().equals(cName) && pcdData.getTokenSpaceGuidCName().equals(tsGuid)) {\r
+                    maintainDynPcdMap(cName + " " + tsGuid, moduleKey);\r
+                    if (getPcdDataCount(seqModuleSa) == 1) {\r
+                        cursor.toParent();\r
+                    }\r
+                    cursor.removeXml();\r
+                    break;\r
+                }\r
             }\r
+            while(cursor.toNextSibling());\r
+            \r
         }\r
-        if (fromLibInstance){\r
-            cursor.removeXml();\r
+        cursor.dispose();\r
+    }\r
+    \r
+    public void updatePcdData (String key, String cName, String tsGuid, String itemType, String maxSize, String value){\r
+        ModuleSADocument.ModuleSA moduleSa = getModuleSA(key);\r
+        if (moduleSa == null || moduleSa.getPcdBuildDefinition() == null){\r
+            return;\r
         }\r
-        while(cursor.toNextSibling()) {\r
-            fromLibInstance = false;\r
-            pcdData = (PcdBuildDefinitionDocument.PcdBuildDefinition.PcdData)cursor.getObject();\r
-            //\r
-            // remove each pcd record from dynPcdMap\r
-            //\r
-            pcdKey = pcdData.getCName() + " " + pcdData.getTokenSpaceGuidCName();\r
-            al = dynPcdMap.get(pcdKey);\r
-            for(int i = 0; i < al.size(); ++i){\r
-                if (al.get(i).startsWith(moduleInfo)){\r
-                    fromLibInstance = true;\r
+        \r
+        XmlCursor cursor = moduleSa.getPcdBuildDefinition().newCursor();\r
+        if (cursor.toFirstChild()){\r
+            do {\r
+                PcdBuildDefinitionDocument.PcdBuildDefinition.PcdData pcdData = (PcdBuildDefinitionDocument.PcdBuildDefinition.PcdData)cursor.getObject();\r
+                if (pcdData.getCName().equals(cName) && pcdData.getTokenSpaceGuidCName().equals(tsGuid)) {\r
+                    pcdData.setItemType(PcdItemTypes.Enum.forString(itemType));\r
+                    if(pcdData.getDatumType().equals("VOID*")) {\r
+                        pcdData.setMaxDatumSize(new Integer(maxSize));\r
+                    }\r
+                    pcdData.setValue(value);\r
+                    defaultPcdValue.put(cName + " " + tsGuid, value);\r
                     break;\r
                 }\r
             }\r
-            al.remove(moduleInfo + " " + pcdData.getItemType().toString());\r
-            if (al.size() == 0) {\r
-                dynPcdMap.remove(pcdKey);\r
+            while(cursor.toNextSibling());\r
+        }\r
+        cursor.dispose();\r
+    }\r
+    \r
+    /**Get original Pcd info from MSA & SPD files.\r
+     * @param mi ModuleIdentification from which MSA & SPD come\r
+     * @param cName PCD cName\r
+     * @param sa Results: HelpText, Original item type.\r
+     * @return\r
+     */\r
+    public boolean getPcdBuildDataInfo(ModuleIdentification mi, String cName, String tsGuid, String[] sa) throws Exception{\r
+        try {\r
+           \r
+            ModuleSurfaceAreaDocument.ModuleSurfaceArea msa = (ModuleSurfaceAreaDocument.ModuleSurfaceArea)WorkspaceProfile.getModuleXmlObject(mi);\r
+            if (msa.getPcdCoded() == null) {\r
+                return false;\r
             }\r
             \r
-            if (pcdData.getItemType().toString().equals("DYNAMIC")) {\r
-                //\r
-                // First check whether this is the only consumer of this dyn pcd.\r
-                //\r
-                if (dynPcdMap.get(pcdKey) == null) {\r
+            Map<String, XmlObject> m = new HashMap<String, XmlObject>();\r
+            m.put("ModuleSurfaceArea", msa);\r
+            SurfaceAreaQuery.setDoc(m);\r
+            PackageIdentification[] depPkgs = SurfaceAreaQuery.getDependencePkg(null, mi);\r
+            //\r
+            // First look through MSA pcd entries.\r
+            //\r
+            List<PcdCodedDocument.PcdCoded.PcdEntry> l = msa.getPcdCoded().getPcdEntryList();\r
+            ListIterator li = l.listIterator();\r
+            while(li.hasNext()) {\r
+                PcdCodedDocument.PcdCoded.PcdEntry msaPcd = (PcdCodedDocument.PcdCoded.PcdEntry)li.next();\r
+                if (!msaPcd.getCName().equals(cName)) {\r
+                    continue;\r
+                }\r
+                if (!msaPcd.getTokenSpaceGuidCName().equals(tsGuid)) {\r
+                    continue;\r
+                }\r
+                PcdDeclarationsDocument.PcdDeclarations.PcdEntry spdPcd = LookupPcdDeclaration(msaPcd, depPkgs);\r
+                if (spdPcd == null) {\r
                     //\r
-                    // delete corresponding entry in DynamicPcdBuildData\r
+                    // ToDo Error \r
                     //\r
-                    removeDynamicPcdBuildData(pcdData.getCName(), pcdData.getTokenSpaceGuidCName());\r
+                    throw new PcdDeclNotFound(mi.getName() + " " + msaPcd.getCName());\r
                 }\r
+                //\r
+                // Get Pcd help text and original item type.\r
+                //\r
+                sa[0] = spdPcd.getHelpText() + msaPcd.getHelpText();\r
+                sa[1] = msaPcd.getPcdItemType()+"";\r
+                return true;\r
             }\r
-            if (fromLibInstance){\r
-                cursor.removeXml();\r
-            }\r
+            \r
+            \r
         }\r
-    }\r
-    //\r
-    // key for ModuleSA : "ModuleGuid ModuleVer PackageGuid PackageVer"\r
-    //\r
-    public int getPcdDataCount(String key){\r
-        ModuleSADocument.ModuleSA msa = getModuleSA(key);\r
-        if (msa == null || msa.getPcdBuildDefinition() == null || msa.getPcdBuildDefinition().getPcdDataList() == null){\r
-            return 0;\r
+        catch (Exception e){\r
+            e.printStackTrace();\r
+            throw e;\r
         }\r
-        return msa.getPcdBuildDefinition().getPcdDataList().size();\r
+        \r
+        return false;\r
     }\r
     \r
-    public void getPcdData(String key, String[][] saa) {\r
-        ModuleSADocument.ModuleSA msa = getModuleSA(key);\r
-        if (msa == null || msa.getPcdBuildDefinition() == null || msa.getPcdBuildDefinition().getPcdDataList() == null){\r
-            return;\r
+    /**Remove PCDBuildDefinition entries from ModuleSA\r
+     * @param moduleKey identifier of ModuleSA.\r
+     * @param consumer where these entries come from.\r
+     */\r
+    public void removePcdData(String moduleKey, ModuleIdentification consumer) {\r
+        try {\r
+            ModuleSurfaceAreaDocument.ModuleSurfaceArea msa = (ModuleSurfaceAreaDocument.ModuleSurfaceArea)WorkspaceProfile.getModuleXmlObject(consumer);\r
+            if (msa.getPcdCoded() == null) {\r
+                return;\r
+            }\r
+            \r
+            List<PcdCodedDocument.PcdCoded.PcdEntry> l = msa.getPcdCoded().getPcdEntryList();\r
+            ListIterator li = l.listIterator();\r
+            \r
+            while(li.hasNext()) {\r
+                PcdCodedDocument.PcdCoded.PcdEntry msaPcd = (PcdCodedDocument.PcdCoded.PcdEntry)li.next();\r
+                ModuleSADocument.ModuleSA moduleSA = getModuleSA(moduleKey);\r
+                if (moduleSA.getPcdBuildDefinition() != null) {\r
+                    XmlCursor cursor = moduleSA.getPcdBuildDefinition().newCursor();\r
+                    if (cursor.toFirstChild()) {\r
+                        do {\r
+                            PcdBuildDefinitionDocument.PcdBuildDefinition.PcdData pcdData = (PcdBuildDefinitionDocument.PcdBuildDefinition.PcdData) cursor\r
+                                                                                                                                                          .getObject();\r
+                            if (msaPcd.getCName().equals(pcdData.getCName())\r
+                                && msaPcd.getTokenSpaceGuidCName().equals(pcdData.getTokenSpaceGuidCName())) {\r
+\r
+                                maintainDynPcdMap(pcdData.getCName() + " " + pcdData.getTokenSpaceGuidCName(),\r
+                                                  moduleKey);\r
+                                cursor.removeXml();\r
+                                break;\r
+                            }\r
+                        } while (cursor.toNextSibling());\r
+                    }\r
+                    cursor.dispose();\r
+                }\r
+            }\r
+            \r
         }\r
-        ListIterator<PcdBuildDefinitionDocument.PcdBuildDefinition.PcdData>li = msa.getPcdBuildDefinition().getPcdDataList().listIterator();\r
-        for (int i = 0; i < saa.length; ++i) {\r
-            PcdBuildDefinitionDocument.PcdBuildDefinition.PcdData pcdData = li.next();\r
-            saa[i][0] = pcdData.getCName();\r
-            saa[i][1] = pcdData.getTokenSpaceGuidCName();\r
-            saa[i][2] = pcdData.getItemType().toString();\r
-            saa[i][3] = pcdData.getToken().toString();\r
-            saa[i][4] = pcdData.getDatumType().toString();\r
-            saa[i][5] = pcdData.getValue();\r
+        catch (Exception e){\r
+            e.printStackTrace();\r
             \r
         }\r
     }\r
     //\r
-    // key for ModuleSA : "ModuleGuid ModuleVer PackageGuid PackageVer"\r
+    // key for ModuleSA : "ModuleGuid ModuleVer PackageGuid PackageVer Arch"\r
     //\r
     public int getLibraryInstancesCount(String key) {\r
         ModuleSADocument.ModuleSA msa = getModuleSA(key);\r
@@ -383,18 +681,34 @@ public class FpdFileContents {
         }\r
     }\r
     \r
-    public void removeLibraryInstances(String key) {\r
+    public void removeLibraryInstance(String key, int i) {\r
         ModuleSADocument.ModuleSA msa = getModuleSA(key);\r
         if (msa == null || msa.getLibraries() == null){\r
             return ;\r
         }\r
         \r
         XmlCursor cursor = msa.getLibraries().newCursor();\r
-        cursor.removeXml();\r
+        if (cursor.toFirstChild()) {\r
+            for (int j = 0; j < i; ++j) {\r
+                cursor.toNextSibling();\r
+            }\r
+            cursor.push();\r
+            cursor.toPrevToken();\r
+            if (cursor.isComment()) {\r
+                cursor.removeXml();\r
+            }\r
+            cursor.pop();\r
+            cursor.removeXml();\r
+            if (getLibraryInstancesCount(key) == 0) {\r
+                cursor.toParent();\r
+                cursor.removeXml();\r
+            }\r
+        }\r
+        \r
         cursor.dispose();\r
     }\r
     \r
-    public void genLibraryInstance(String mg, String mv, String pg, String pv, String key) {\r
+    public void genLibraryInstance(ModuleIdentification libMi, String key) {\r
         ModuleSADocument.ModuleSA msa = getModuleSA(key);\r
         if (msa == null){\r
             msa = getfpdFrameworkModules().addNewModuleSA();\r
@@ -404,68 +718,398 @@ public class FpdFileContents {
             libs = msa.addNewLibraries();\r
         }\r
         \r
+        String mn = libMi.getName();\r
+        String mg = libMi.getGuid();\r
+        String mv = libMi.getVersion();\r
+        String pn = libMi.getPackageId().getName();\r
+        String pg = libMi.getPackageId().getGuid();\r
+        String pv = libMi.getPackageId().getVersion();\r
         LibrariesDocument.Libraries.Instance instance = libs.addNewInstance();\r
+        XmlCursor cursor = instance.newCursor();\r
+        try{\r
+            String comment = "Pkg: " + pn + " Mod: " + mn \r
+                + " Path: " + libMi.getPath().substring(System.getenv("WORKSPACE").length() + 1);\r
+            cursor.insertComment(comment);\r
+        }\r
+        catch (Exception e){\r
+            e.printStackTrace();\r
+        }\r
+        finally {\r
+            cursor.dispose();\r
+        }\r
+        \r
         instance.setModuleGuid(mg);\r
         instance.setModuleVersion(mv);\r
         instance.setPackageGuid(pg);\r
         instance.setPackageVersion(pv);\r
         \r
     }\r
-    /**add pcd information of module mi to a ModuleSA. \r
-     * @param mi\r
-     * @param moduleSa if null, generate a new ModuleSA.\r
-     */\r
-    public void addFrameworkModulesPcdBuildDefs(ModuleIdentification mi, ModuleSADocument.ModuleSA moduleSa){\r
-        //ToDo add Arch filter\r
-        \r
-        try {\r
-            ModuleSurfaceAreaDocument.ModuleSurfaceArea msa = (ModuleSurfaceAreaDocument.ModuleSurfaceArea)GlobalData.getModuleXmlObject(mi);\r
-            if (msa.getPcdCoded() == null) {\r
+    \r
+    public String getFvBinding(String moduleKey){\r
+        ModuleSADocument.ModuleSA moduleSa = getModuleSA(moduleKey);\r
+        return getFvBinding (moduleSa);\r
+    }\r
+    \r
+    public String getFvBinding (ModuleSADocument.ModuleSA moduleSa) {\r
+        if (moduleSa == null || moduleSa.getModuleSaBuildOptions() == null) {\r
+            return null;\r
+        }\r
+        return moduleSa.getModuleSaBuildOptions().getFvBinding();\r
+    }\r
+    \r
+    public void setFvBinding(ModuleSADocument.ModuleSA moduleSa, String fvBinding) {\r
+        if (moduleSa == null ) {\r
+            return;\r
+        }\r
+        if (fvBinding == null || fvBinding.length() == 0) {\r
+            if(moduleSa.getModuleSaBuildOptions() != null){\r
+                moduleSa.getModuleSaBuildOptions().unsetFvBinding();\r
+            }\r
+        }\r
+        else {\r
+            if(moduleSa.getModuleSaBuildOptions() == null){\r
+                moduleSa.addNewModuleSaBuildOptions().setFvBinding(fvBinding);\r
                 return;\r
             }\r
-            if (moduleSa == null) {\r
-                moduleSa = genModuleSA(mi);\r
+            moduleSa.getModuleSaBuildOptions().setFvBinding(fvBinding);\r
+        }\r
+    }\r
+    \r
+    public void setFvBinding(String moduleKey, String fvBinding){\r
+        ModuleSADocument.ModuleSA moduleSa = getModuleSA(moduleKey);\r
+        setFvBinding (moduleSa, fvBinding);\r
+    }\r
+    \r
+    private int fvBindingForModuleSA (ModuleSADocument.ModuleSA moduleSa, String fvName) {\r
+        if (moduleSa == null || moduleSa.getModuleSaBuildOptions() == null || moduleSa.getModuleSaBuildOptions().getFvBinding() == null) {\r
+            return -1;\r
+        }\r
+        \r
+        String fvNameList = moduleSa.getModuleSaBuildOptions().getFvBinding();\r
+        String[] fvNamesArray = fvNameList.split(" ");\r
+        int occursAt = -1;\r
+        for (int i = 0; i < fvNamesArray.length; ++i) {\r
+            if (fvNamesArray[i].equals(fvName)) {\r
+                occursAt = i;\r
+                break;\r
             }\r
-            Map<String, XmlObject> m = new HashMap<String, XmlObject>();\r
-            m.put("ModuleSurfaceArea", msa);\r
-            SurfaceAreaQuery.setDoc(m);\r
-            PackageIdentification[] depPkgs = SurfaceAreaQuery.getDependencePkg(null);\r
-            //\r
-            // Implementing InitializePlatformPcdBuildDefinitions\r
-            //\r
-            List<PcdCodedDocument.PcdCoded.PcdEntry> l = msa.getPcdCoded().getPcdEntryList();\r
-            ListIterator li = l.listIterator();\r
-            while(li.hasNext()) {\r
-                PcdCodedDocument.PcdCoded.PcdEntry msaPcd = (PcdCodedDocument.PcdCoded.PcdEntry)li.next();\r
-                PcdDeclarationsDocument.PcdDeclarations.PcdEntry spdPcd = LookupPcdDeclaration(msaPcd, depPkgs);\r
-                if (spdPcd == null) {\r
-                    //\r
+        }\r
+        return occursAt;\r
+    }\r
+    \r
+    public void removeFvBinding (ModuleSADocument.ModuleSA moduleSa, String fvName) {\r
+        if (moduleSa == null || moduleSa.getModuleSaBuildOptions() == null || moduleSa.getModuleSaBuildOptions().getFvBinding() == null) {\r
+            return;\r
+        }\r
+        \r
+        String fvNameList = moduleSa.getModuleSaBuildOptions().getFvBinding();\r
+        String[] fvNamesArray = fvNameList.split(" ");\r
+        int occursAt = -1;\r
+        for (int i = 0; i < fvNamesArray.length; ++i) {\r
+            if (fvNamesArray[i].equals(fvName)) {\r
+                occursAt = i;\r
+                break;\r
+            }\r
+        }\r
+        // jump over where the input fvName occurs in the original Fv list.\r
+        if (occursAt != -1) {\r
+            String newFvNameList = " ";\r
+            for (int i = 0; i < fvNamesArray.length; ++i) {\r
+                if (i == occursAt) {\r
+                    continue;\r
+                }\r
+                newFvNameList += fvNamesArray[i];\r
+            }\r
+            setFvBinding (moduleSa, newFvNameList.trim());\r
+        }\r
+\r
+    }\r
+    \r
+    /**\r
+     * @param fvName The FV name that to be removed from FvBinding List.\r
+     */\r
+    public void removeFvBindingAll (String fvName) {\r
+        if (getfpdFrameworkModules().getModuleSAList() == null || getfpdFrameworkModules().getModuleSAList().size() == 0){\r
+            removeElement(getfpdFrameworkModules());\r
+            fpdFrameworkModules = null;\r
+            return;\r
+        }\r
+        \r
+        Iterator<ModuleSADocument.ModuleSA> li = getfpdFrameworkModules().getModuleSAList().iterator();\r
+        while (li.hasNext()) {\r
+            ModuleSADocument.ModuleSA moduleSa = li.next();\r
+            removeFvBinding (moduleSa, fvName); \r
+        }\r
+    }\r
+    \r
+    public void appendFvBindingAll (String fvName) {\r
+        if (getfpdFrameworkModules().getModuleSAList() == null || getfpdFrameworkModules().getModuleSAList().size() == 0){\r
+            removeElement(getfpdFrameworkModules());\r
+            fpdFrameworkModules = null;\r
+            return;\r
+        }\r
+        \r
+        Iterator<ModuleSADocument.ModuleSA> li = getfpdFrameworkModules().getModuleSAList().iterator();\r
+        while (li.hasNext()) {\r
+            ModuleSADocument.ModuleSA moduleSa = li.next();\r
+            appendFvBinding (moduleSa, fvName); \r
+        }\r
+    }\r
+    \r
+    public void appendFvBindingFor (String oldFvName, String newFvName) {\r
+        if (getfpdFrameworkModules().getModuleSAList() == null || getfpdFrameworkModules().getModuleSAList().size() == 0){\r
+            removeElement(getfpdFrameworkModules());\r
+            fpdFrameworkModules = null;\r
+            return;\r
+        }\r
+        \r
+        Iterator<ModuleSADocument.ModuleSA> li = getfpdFrameworkModules().getModuleSAList().iterator();\r
+        while (li.hasNext()) {\r
+            ModuleSADocument.ModuleSA moduleSa = li.next();\r
+            String fvBinding = getFvBinding (moduleSa);\r
+            if (fvBinding != null && fvBindingForModuleSA (moduleSa, oldFvName) >= 0) {\r
+                appendFvBinding (moduleSa, newFvName); \r
+            }\r
+        }\r
+    }\r
+    \r
+    public void appendFvBinding (String moduleKey, String fvName) {\r
+        ModuleSADocument.ModuleSA moduleSa = getModuleSA(moduleKey);\r
+        appendFvBinding (moduleSa, fvName);\r
+    }\r
+    \r
+    public void appendFvBinding (ModuleSADocument.ModuleSA moduleSa, String fvName) {\r
+        if (moduleSa == null) {\r
+            return;\r
+        }\r
+        \r
+        if (moduleSa.getModuleSaBuildOptions() == null || moduleSa.getModuleSaBuildOptions().getFvBinding() == null) {\r
+            setFvBinding(moduleSa, fvName);\r
+            return;\r
+        }\r
+        \r
+        String fvNameList = moduleSa.getModuleSaBuildOptions().getFvBinding();\r
+        String newFvNameList = fvNameList + " " + fvName;\r
+        setFvBinding (moduleSa, newFvNameList.trim());\r
+    }\r
+    \r
+    public void updateFvBindingInModuleSA (ModuleIdentification mi, String fvName) {\r
+        Vector<Object> vSupArchs = new Vector<Object>();\r
+        getPlatformDefsSupportedArchs(vSupArchs);\r
+        String moduleInfo = mi.getGuid() + " " + mi.getVersion() + " " + mi.getPackageId().getGuid() + " " + mi.getPackageId().getVersion();\r
+        for (int i = 0; i < vSupArchs.size(); ++i) {\r
+            String moduleKey = moduleInfo + " " + vSupArchs.get(i);\r
+            appendFvBinding (moduleKey, fvName);\r
+        }\r
+    }\r
+    \r
+    public String getFfsFileNameGuid(String moduleKey){\r
+        ModuleSADocument.ModuleSA moduleSa = getModuleSA(moduleKey);\r
+        if (moduleSa == null || moduleSa.getModuleSaBuildOptions() == null) {\r
+            return null;\r
+        }\r
+        return moduleSa.getModuleSaBuildOptions().getFfsFileNameGuid();\r
+    }\r
+    \r
+    public void setFfsFileNameGuid(String moduleKey, String fileGuid){\r
+        ModuleSADocument.ModuleSA msa = getModuleSA(moduleKey);\r
+        if (msa == null ) {\r
+            return;\r
+        }\r
+        if(msa.getModuleSaBuildOptions() == null){\r
+            msa.addNewModuleSaBuildOptions();\r
+            \r
+        }\r
+        ModuleSaBuildOptionsDocument.ModuleSaBuildOptions msaBuildOpts= msa.getModuleSaBuildOptions();\r
+        if (fileGuid != null) {\r
+            msaBuildOpts.setFfsFileNameGuid(fileGuid);\r
+        }\r
+        else{\r
+            XmlCursor cursor = msaBuildOpts.newCursor();\r
+            if (cursor.toChild(xmlNs, "FfsFileNameGuid")) {\r
+                cursor.removeXml();\r
+            }\r
+            cursor.dispose();\r
+        }\r
+        \r
+    }\r
+    \r
+    public String getFfsFormatKey(String moduleKey){\r
+        ModuleSADocument.ModuleSA msa = getModuleSA(moduleKey);\r
+        if (msa == null || msa.getModuleSaBuildOptions() == null) {\r
+            return null;\r
+        }\r
+        return msa.getModuleSaBuildOptions().getFfsFormatKey();\r
+    }\r
+    \r
+    public void setFfsFormatKey(String moduleKey, String ffsKey){\r
+        ModuleSADocument.ModuleSA msa = getModuleSA(moduleKey);\r
+        if (msa == null ) {\r
+            return;\r
+        }\r
+        if(msa.getModuleSaBuildOptions() == null){\r
+            msa.addNewModuleSaBuildOptions().setFfsFormatKey(ffsKey);\r
+            return;\r
+        }\r
+        msa.getModuleSaBuildOptions().setFfsFormatKey(ffsKey);\r
+    }\r
+    \r
+    public void setModuleSAForceDebug(int i, boolean dbgEnable) {\r
+        ModuleSADocument.ModuleSA moduleSa = getModuleSA(i);\r
+        moduleSa.setForceDebug(dbgEnable);\r
+    }\r
+    \r
+    public boolean getModuleSAForceDebug (int i) {\r
+        ModuleSADocument.ModuleSA moduleSa = getModuleSA(i);\r
+        if (moduleSa.getForceDebug() == true) {\r
+            return true;\r
+        }\r
+        return false;\r
+    }\r
+    \r
+    public void getModuleSAOptions(String moduleKey, String[][] saa) {\r
+        ModuleSADocument.ModuleSA msa = getModuleSA(moduleKey);\r
+        if (msa == null || msa.getModuleSaBuildOptions() == null || msa.getModuleSaBuildOptions().getOptions() == null\r
+                        || msa.getModuleSaBuildOptions().getOptions().getOptionList() == null) {\r
+            return ;\r
+        }\r
+        \r
+        List<OptionDocument.Option> lOpt = msa.getModuleSaBuildOptions().getOptions().getOptionList();\r
+        ListIterator li = lOpt.listIterator();\r
+        int i = 0;\r
+        while(li.hasNext()) {\r
+            OptionDocument.Option opt = (OptionDocument.Option)li.next();\r
+            if (opt.getBuildTargets() != null) {\r
+                saa[i][0] = listToString(opt.getBuildTargets());\r
+            }\r
+            saa[i][1] = opt.getToolChainFamily();\r
+            saa[i][2] = opt.getTagName();\r
+            saa[i][3] = opt.getToolCode();\r
+            \r
+            if (opt.getSupArchList() != null){\r
+                saa[i][4] = listToString(opt.getSupArchList());\r
+            }\r
+            else {\r
+                saa[i][4] = "";\r
+            }\r
+            \r
+            saa[i][5] = opt.getStringValue();\r
+             \r
+            ++i;\r
+        }\r
+    }\r
+    \r
+    public int getModuleSAOptionsCount(String moduleKey){\r
+        ModuleSADocument.ModuleSA msa = getModuleSA(moduleKey);\r
+        if (msa == null || msa.getModuleSaBuildOptions() == null || msa.getModuleSaBuildOptions().getOptions() == null\r
+                        || msa.getModuleSaBuildOptions().getOptions().getOptionList() == null) {\r
+            return 0;\r
+        }\r
+        return msa.getModuleSaBuildOptions().getOptions().getOptionList().size();\r
+    }\r
+    \r
+    public void genModuleSAOptionsOpt(String moduleKey, Vector<Object> buildTargets, String toolChain, String tagName, String toolCmd, Vector<Object> archList, String contents) {\r
+        ModuleSADocument.ModuleSA msa = getModuleSA(moduleKey);\r
+        if (msa.getModuleSaBuildOptions() == null) {\r
+            msa.addNewModuleSaBuildOptions();\r
+        }\r
+        if (msa.getModuleSaBuildOptions().getOptions() == null){\r
+            msa.getModuleSaBuildOptions().addNewOptions();\r
+        }\r
+        OptionDocument.Option opt = msa.getModuleSaBuildOptions().getOptions().addNewOption();\r
+        setBuildOptionsOpt(buildTargets, toolChain, tagName, toolCmd, archList, contents, opt);\r
+    }\r
+    \r
+    public void removeModuleSAOptionsOpt(String moduleKey, int i) {\r
+        ModuleSADocument.ModuleSA msa = getModuleSA(moduleKey);\r
+        if (msa.getModuleSaBuildOptions() == null || msa.getModuleSaBuildOptions().getOptions() == null) {\r
+            return ;\r
+        }\r
+        OptionsDocument.Options opts = msa.getModuleSaBuildOptions().getOptions();\r
+        XmlCursor cursor = opts.newCursor();\r
+        if (cursor.toFirstChild()) {\r
+            for (int j = 0; j < i; ++j){\r
+                cursor.toNextSibling();\r
+            }\r
+            cursor.removeXml();\r
+        }\r
+        cursor.dispose();\r
+    }\r
+    \r
+    public void updateModuleSAOptionsOpt(String moduleKey, int i, Vector<Object> buildTargets, String toolChain, String tagName, String toolCmd, Vector<Object> archList, String contents) {\r
+        ModuleSADocument.ModuleSA msa = getModuleSA(moduleKey);\r
+        if (msa.getModuleSaBuildOptions() == null || msa.getModuleSaBuildOptions().getOptions() == null) {\r
+            return ;\r
+        }\r
+        OptionsDocument.Options opts = msa.getModuleSaBuildOptions().getOptions();\r
+        XmlCursor cursor = opts.newCursor();\r
+        if (cursor.toFirstChild()) {\r
+            for (int j = 0; j < i; ++j){\r
+                cursor.toNextSibling();\r
+            }\r
+            OptionDocument.Option opt = (OptionDocument.Option)cursor.getObject();\r
+            setBuildOptionsOpt(buildTargets, toolChain, tagName, toolCmd, archList, contents, opt);\r
+        }\r
+        cursor.dispose();\r
+    }\r
+    \r
+    /**add pcd information of module mi to a ModuleSA. \r
+     * @param mi\r
+     * @param moduleSa if null, generate a new ModuleSA.\r
+     */\r
+    public void addFrameworkModulesPcdBuildDefs(ModuleIdentification mi, String arch, ModuleSADocument.ModuleSA moduleSa) throws Exception {\r
+        //ToDo add Arch filter\r
+        \r
+        try {\r
+            if (moduleSa == null) {\r
+                moduleSa = genModuleSA(mi, arch);\r
+            }\r
+            \r
+            ModuleSurfaceAreaDocument.ModuleSurfaceArea msa = (ModuleSurfaceAreaDocument.ModuleSurfaceArea)WorkspaceProfile.getModuleXmlObject(mi);\r
+            if (msa.getPcdCoded() == null) {\r
+                return;\r
+            }\r
+            \r
+            Map<String, XmlObject> m = new HashMap<String, XmlObject>();\r
+            m.put("ModuleSurfaceArea", msa);\r
+            SurfaceAreaQuery.setDoc(m);\r
+            PackageIdentification[] depPkgs = SurfaceAreaQuery.getDependencePkg(null, mi);\r
+            //\r
+            // Implementing InitializePlatformPcdBuildDefinitions\r
+            //\r
+            List<PcdCodedDocument.PcdCoded.PcdEntry> l = msa.getPcdCoded().getPcdEntryList();\r
+            ListIterator li = l.listIterator();\r
+            while(li.hasNext()) {\r
+                PcdCodedDocument.PcdCoded.PcdEntry msaPcd = (PcdCodedDocument.PcdCoded.PcdEntry)li.next();\r
+                PcdDeclarationsDocument.PcdDeclarations.PcdEntry spdPcd = LookupPcdDeclaration(msaPcd, depPkgs);\r
+                if (spdPcd == null) {\r
+                    //\r
                     // ToDo Error \r
                     //\r
-                    break;\r
+                    throw new PcdDeclNotFound("No Declaration for PCD Entry " + msaPcd.getCName() + " in Module " + mi.getName());\r
                 }\r
                 //\r
                 // AddItem to ModuleSA PcdBuildDefinitions\r
                 //\r
                 String defaultVal = msaPcd.getDefaultValue() == null ? spdPcd.getDefaultValue() : msaPcd.getDefaultValue();\r
+                \r
                 genPcdData(msaPcd.getCName(), spdPcd.getToken(), msaPcd.getTokenSpaceGuidCName(), msaPcd.getPcdItemType().toString(), spdPcd.getDatumType()+"", defaultVal, moduleSa);\r
             }\r
             \r
         }\r
         catch (Exception e){\r
-            e.printStackTrace();\r
+            \r
+            throw e; \r
         }\r
         \r
     }\r
     \r
     private PcdDeclarationsDocument.PcdDeclarations.PcdEntry LookupPcdDeclaration (PcdCodedDocument.PcdCoded.PcdEntry msaPcd, PackageIdentification[] depPkgs) {\r
         \r
-        Map<String, XmlObject> m = new HashMap<String, XmlObject>();\r
         PcdDeclarationsDocument.PcdDeclarations.PcdEntry spdPcd = null;\r
         for (int i = 0; i < depPkgs.length; ++i) {\r
-            m.put("PackageSurfaceArea", GlobalData.getPackageXmlObject(depPkgs[i]));\r
-            SurfaceAreaQuery.setDoc(m);\r
-            XmlObject[] xo = SurfaceAreaQuery.getSpdPcdDeclarations();\r
+\r
+            XmlObject[] xo = SurfaceAreaQuery.getSpdPcdDeclarations(depPkgs[i]);\r
             if (xo == null) {\r
                 continue;\r
             }\r
@@ -488,18 +1132,36 @@ public class FpdFileContents {
         return null;\r
     }\r
     \r
-    private ModuleSADocument.ModuleSA genModuleSA (ModuleIdentification mi) {\r
-        PackageIdentification pi = GlobalData.getPackageForModule(mi);\r
+    private ModuleSADocument.ModuleSA genModuleSA (ModuleIdentification mi, String arch) {\r
+        PackageIdentification pi = WorkspaceProfile.getPackageForModule(mi);\r
         ModuleSADocument.ModuleSA msa = getfpdFrameworkModules().addNewModuleSA();\r
+        XmlCursor cursor = msa.newCursor();\r
+        try{\r
+            String comment = "Mod: " + mi.getName() + " Type: " + SurfaceAreaQuery.getModuleType(mi) + " Path: "\r
+                            + mi.getPath().substring(System.getenv("WORKSPACE").length() + 1);\r
+            cursor.insertComment(comment);\r
+        }\r
+        catch(Exception e){\r
+            e.printStackTrace();\r
+        }\r
+        finally { \r
+            cursor.dispose();\r
+        }\r
         msa.setModuleGuid(mi.getGuid());\r
         msa.setModuleVersion(mi.getVersion());\r
         msa.setPackageGuid(pi.getGuid());\r
         msa.setPackageVersion(pi.getVersion());\r
+        if (arch != null) {\r
+            Vector<String> v = new Vector<String>();\r
+            v.add(arch);\r
+            msa.setSupArchList(v); \r
+        }\r
         \r
         return msa;\r
     }\r
     \r
-    private void genPcdData (String cName, Object token, String tsGuid, String itemType, String dataType, String defaultVal, ModuleSADocument.ModuleSA moduleSa) {\r
+    private void genPcdData (String cName, Object token, String tsGuid, String itemType, String dataType, String defaultVal, ModuleSADocument.ModuleSA moduleSa) \r
+    throws PcdItemTypeConflictException, PcdValueMalFormed{\r
         if (moduleSa.getPcdBuildDefinition() == null){\r
             moduleSa.addNewPcdBuildDefinition();\r
         }\r
@@ -511,39 +1173,18 @@ public class FpdFileContents {
         if (pcdConsumer == null) {\r
             pcdConsumer = new ArrayList<String>();\r
         }\r
+        //\r
+        // Using existing Pcd type, if this pcd already exists in other ModuleSA\r
+        //\r
+        if (pcdConsumer.size() > 0) {\r
+            String[] valPart = pcdConsumer.get(0).split(" ");\r
+            itemType = valPart[5];\r
+        }\r
         String listValue = moduleSa.getModuleGuid() + " " + moduleSa.getModuleVersion() \r
-        + " " + moduleSa.getPackageGuid() + " " + moduleSa.getPackageVersion() \r
+        + " " + moduleSa.getPackageGuid() + " " + moduleSa.getPackageVersion() + " " + listToString(moduleSa.getSupArchList())\r
         + " " + itemType;\r
         pcdConsumer.add(listValue);\r
         dynPcdMap.put(cName + " " + tsGuid, pcdConsumer);\r
-        //\r
-        // Special dynamic type, if this pcd already exists in other ModuleSA\r
-        //\r
-        if (itemType.equals("DYNAMIC")) {\r
-            \r
-            ListIterator li = pcdConsumer.listIterator();\r
-            while(li.hasNext()) {\r
-                String value = li.next().toString();\r
-                String[] valuePart= value.split(" ");\r
-                if (!valuePart[4].equals("DYNAMIC")) {\r
-                    //ToDo error for same pcd, other type than dynamic\r
-                    pcdConsumer.remove(listValue);\r
-                    return;\r
-                }\r
-            }\r
-        }\r
-        else {\r
-            ListIterator li = pcdConsumer.listIterator();\r
-            while(li.hasNext()) {\r
-                String value = li.next().toString();\r
-                String[] valuePart= value.split(" ");\r
-                if (valuePart[4].equals("DYNAMIC")) {\r
-                    //ToDo error for same pcd, other type than non-dynamic\r
-                    pcdConsumer.remove(listValue);\r
-                    return;\r
-                }\r
-            }\r
-        }\r
         \r
         PcdBuildDefinitionDocument.PcdBuildDefinition.PcdData fpdPcd = moduleSa.getPcdBuildDefinition().addNewPcdData();\r
         fpdPcd.setCName(cName);\r
@@ -552,6 +1193,51 @@ public class FpdFileContents {
         fpdPcd.setDatumType(PcdDataTypes.Enum.forString(dataType));\r
         fpdPcd.setItemType(PcdItemTypes.Enum.forString(itemType));\r
         \r
+        if (defaultVal != null){\r
+            fpdPcd.setValue(defaultVal);\r
+        }\r
+        else {\r
+            if (dataType.equals("UINT8") || dataType.equals("UINT16") || dataType.equals("UINT32") || dataType.equals("UINT64")) {\r
+                fpdPcd.setValue("0");\r
+            }\r
+            if (dataType.equals("BOOLEAN")){\r
+                fpdPcd.setValue("FALSE");\r
+            }\r
+            if (dataType.equals("VOID*")) {\r
+                fpdPcd.setValue("");\r
+            }\r
+        }\r
+        //\r
+        // Using existing pcd value, if this pcd already exists in other moduleSa.\r
+        //\r
+        if (defaultPcdValue.get(cName + " " + tsGuid) == null) {\r
+            defaultPcdValue.put(cName + " " + tsGuid, fpdPcd.getValue());\r
+        }\r
+        else {\r
+            fpdPcd.setValue(defaultPcdValue.get(cName + " " + tsGuid));\r
+        }\r
+        \r
+        if (dataType.equals("UINT8")){\r
+            fpdPcd.setMaxDatumSize(1);\r
+        }\r
+        if (dataType.equals("UINT16")) {\r
+            fpdPcd.setMaxDatumSize(2);\r
+        }\r
+        if (dataType.equals("UINT32")) {\r
+            fpdPcd.setMaxDatumSize(4);\r
+        }\r
+        if (dataType.equals("UINT64")){\r
+            fpdPcd.setMaxDatumSize(8);\r
+        }\r
+        if (dataType.equals("BOOLEAN")){\r
+            fpdPcd.setMaxDatumSize(1);\r
+        }\r
+        if (dataType.equals("VOID*")) {\r
+            int maxSize = setMaxSizeForPointer(fpdPcd.getValue());\r
+            fpdPcd.setMaxDatumSize(maxSize);\r
+        }\r
+        \r
+        \r
         if (itemType.equals("DYNAMIC") || itemType.equals("DYNAMIC_EX")) {\r
             ArrayList<String> al = LookupDynamicPcdBuildDefinition(cName + " " + tsGuid);\r
             //\r
@@ -562,44 +1248,10 @@ public class FpdFileContents {
                 addDynamicPcdBuildData(cName, token, tsGuid, itemType, dataType, defaultVal);\r
             }\r
         }\r
-        else {\r
-            if (defaultVal != null){\r
-                fpdPcd.setValue(defaultVal);\r
-            }\r
-            else {\r
-                if (dataType.equals("UINT8") || dataType.equals("UINT16") || dataType.equals("UINT32") || dataType.equals("UINT64")) {\r
-                    fpdPcd.setValue("0");\r
-                }\r
-                if (dataType.equals("BOOLEAN")){\r
-                    fpdPcd.setValue("false");\r
-                }\r
-                if (dataType.equals("VOID*")) {\r
-                    fpdPcd.setValue("");\r
-                }\r
-            }\r
-            if (dataType.equals("UINT8")){\r
-                fpdPcd.setMaxDatumSize(1);\r
-            }\r
-            if (dataType.equals("UINT16")) {\r
-                fpdPcd.setMaxDatumSize(2);\r
-            }\r
-            if (dataType.equals("UINT32")) {\r
-                fpdPcd.setMaxDatumSize(4);\r
-            }\r
-            if (dataType.equals("UINT64")){\r
-                fpdPcd.setMaxDatumSize(8);\r
-            }\r
-            if (dataType.equals("BOOLEAN")){\r
-                fpdPcd.setMaxDatumSize(1);\r
-            }\r
-            if (dataType.equals("VOID*")) {\r
-                int maxSize = setMaxSizeForPointer(fpdPcd.getValue());\r
-                fpdPcd.setMaxDatumSize(maxSize);\r
-            }\r
-        }\r
+        \r
     }\r
     \r
-    private int setMaxSizeForPointer(String datum) {\r
+    public int setMaxSizeForPointer(String datum) throws PcdValueMalFormed{\r
         if (datum == null) {\r
             return 0;\r
         }\r
@@ -619,6 +1271,7 @@ public class FpdFileContents {
                 (end   > datum.length())||\r
                 ((start == end) && (datum.length() > 0))) {\r
                 //ToDo Error handling here\r
+                throw new PcdValueMalFormed (datum);\r
             }\r
 \r
             strValue    = datum.substring(start + 1, end);\r
@@ -629,7 +1282,7 @@ public class FpdFileContents {
             if ((start > end)           || \r
                 (end   > datum.length())||\r
                 ((start == end) && (datum.length() > 0))) {\r
-                \r
+                throw new PcdValueMalFormed (datum);\r
             }\r
             strValue    = datum.substring(start + 1, end);\r
             return strValue.length();\r
@@ -649,8 +1302,8 @@ public class FpdFileContents {
                 \r
                 if (value > 0xFF) {\r
 //                   "[FPD file error] The datum type of PCD %s in %s is VOID*, "+\r
-//                   "it is byte array in fact. But the element of %s exceed the byte range",\r
-                                                    \r
+//                   "it must be a byte array. But the element of %s exceed the byte range",\r
+                    throw new PcdValueMalFormed (datum);                               \r
                 }\r
             }\r
             return strValueArray.length;\r
@@ -662,7 +1315,7 @@ public class FpdFileContents {
 //            "2) ANSIC string: like \"xxx\";\r\n"+\r
 //            "3) Byte array: like {0x2, 0x45, 0x23}\r\n"+\r
 //            "but the datum in seems does not following above format!",\r
-              return -1;                             \r
+            throw new PcdValueMalFormed (datum);\r
             \r
         }\r
     }\r
@@ -675,18 +1328,22 @@ public class FpdFileContents {
     \r
     private ArrayList<String> LookupPlatformPcdData(String pcdKey) {\r
         \r
-        return dynPcdMap.get("pcdKey");\r
+        return dynPcdMap.get(pcdKey);\r
     }\r
     \r
     public int getDynamicPcdBuildDataCount() {\r
-        if (getfpdDynPcdBuildDefs().getPcdBuildDataList() == null) {\r
+        if (getfpdDynPcdBuildDefs().getPcdBuildDataList() == null || getfpdDynPcdBuildDefs().getPcdBuildDataList().size() == 0) {\r
+            removeElement(getfpdDynPcdBuildDefs());\r
+            fpdDynPcdBuildDefs = null;\r
             return 0;\r
         }\r
         return getfpdDynPcdBuildDefs().getPcdBuildDataList().size();\r
     }\r
     \r
     public void getDynamicPcdBuildData(String[][] saa) {\r
-        if (getfpdDynPcdBuildDefs().getPcdBuildDataList() == null) {\r
+        if (getfpdDynPcdBuildDefs().getPcdBuildDataList() == null || getfpdDynPcdBuildDefs().getPcdBuildDataList().size() == 0) {\r
+            removeElement(getfpdDynPcdBuildDefs());\r
+            fpdDynPcdBuildDefs = null;\r
             return ;\r
         }\r
         List<DynamicPcdBuildDefinitionsDocument.DynamicPcdBuildDefinitions.PcdBuildData> l = getfpdDynPcdBuildDefs().getPcdBuildDataList();\r
@@ -704,7 +1361,8 @@ public class FpdFileContents {
         }\r
     }\r
     \r
-    private void addDynamicPcdBuildData(String cName, Object token, String tsGuid, String itemType, String dataType, String defaultVal) {\r
+    public void addDynamicPcdBuildData(String cName, Object token, String tsGuid, String itemType, String dataType, String defaultVal) \r
+    throws PcdValueMalFormed{\r
         DynamicPcdBuildDefinitionsDocument.DynamicPcdBuildDefinitions.PcdBuildData dynPcdData = getfpdDynPcdBuildDefs().addNewPcdBuildData();\r
         dynPcdData.setItemType(PcdItemTypes.Enum.forString(itemType));\r
         dynPcdData.setCName(cName);\r
@@ -759,19 +1417,28 @@ public class FpdFileContents {
         }\r
     }\r
     \r
-    private void removeDynamicPcdBuildData(String cName, String tsGuid) {\r
-        XmlObject o = getfpdDynPcdBuildDefs();\r
+    public void removeDynamicPcdBuildData(String cName, String tsGuid) {\r
+        XmlObject o = fpdRoot.getDynamicPcdBuildDefinitions();\r
+        if (o == null) {\r
+            return;\r
+        }\r
         \r
         XmlCursor cursor = o.newCursor();\r
         if (cursor.toFirstChild()) {\r
-            DynamicPcdBuildDefinitionsDocument.DynamicPcdBuildDefinitions.PcdBuildData pcdBuildData = \r
-                (DynamicPcdBuildDefinitionsDocument.DynamicPcdBuildDefinitions.PcdBuildData)cursor.getObject();\r
-            while (!(pcdBuildData.getCName().equals(cName) && pcdBuildData.getTokenSpaceGuidCName().equals(tsGuid))) {\r
-                cursor.toNextSibling();\r
-                pcdBuildData = (DynamicPcdBuildDefinitionsDocument.DynamicPcdBuildDefinitions.PcdBuildData)cursor.getObject();\r
+            do {\r
+                DynamicPcdBuildDefinitionsDocument.DynamicPcdBuildDefinitions.PcdBuildData pcdBuildData = \r
+                    (DynamicPcdBuildDefinitionsDocument.DynamicPcdBuildDefinitions.PcdBuildData)cursor.getObject();\r
+                if (pcdBuildData.getCName().equals(cName) && pcdBuildData.getTokenSpaceGuidCName().equals(tsGuid)) {\r
+                    \r
+                    if (getDynamicPcdBuildDataCount() == 1) {\r
+                        cursor.toParent();\r
+                    }\r
+                    cursor.removeXml();\r
+                    cursor.dispose();\r
+                    return;\r
+                }\r
             }\r
-            \r
-            cursor.removeXml();\r
+            while (cursor.toNextSibling());\r
         }\r
         cursor.dispose();\r
     }\r
@@ -779,7 +1446,8 @@ public class FpdFileContents {
     // Get the Sku Info count of ith dyn pcd element.\r
     //\r
     public int getDynamicPcdSkuInfoCount(int i){\r
-        if (getfpdDynPcdBuildDefs().getPcdBuildDataList() == null || getfpdDynPcdBuildDefs().getPcdBuildDataList().size() == 0) {\r
+        if (fpdRoot.getDynamicPcdBuildDefinitions() == null || fpdRoot.getDynamicPcdBuildDefinitions().getPcdBuildDataList() == null \r
+                        || fpdRoot.getDynamicPcdBuildDefinitions().getPcdBuildDataList().size() == 0) {\r
             return 0;\r
         }\r
         \r
@@ -803,6 +1471,8 @@ public class FpdFileContents {
     \r
     public void getDynamicPcdSkuInfos(int i, String[][] saa){\r
         if (getfpdDynPcdBuildDefs().getPcdBuildDataList() == null || getfpdDynPcdBuildDefs().getPcdBuildDataList().size() == 0) {\r
+            removeElement(getfpdDynPcdBuildDefs());\r
+            fpdDynPcdBuildDefs = null;\r
             return;\r
         }\r
         \r
@@ -840,6 +1510,8 @@ public class FpdFileContents {
     public String getDynamicPcdBuildDataValue(int i){\r
         String value = null;\r
         if (getfpdDynPcdBuildDefs().getPcdBuildDataList() == null || getfpdDynPcdBuildDefs().getPcdBuildDataList().size() == 0) {\r
+            removeElement(getfpdDynPcdBuildDefs());\r
+            fpdDynPcdBuildDefs = null;\r
             return value;\r
         }\r
         \r
@@ -863,6 +1535,8 @@ public class FpdFileContents {
     public String getDynamicPcdBuildDataVpdOffset(int i){\r
         String vpdOffset = null;\r
         if (getfpdDynPcdBuildDefs().getPcdBuildDataList() == null || getfpdDynPcdBuildDefs().getPcdBuildDataList().size() == 0) {\r
+            removeElement(getfpdDynPcdBuildDefs());\r
+            fpdDynPcdBuildDefs = null;\r
             return vpdOffset;\r
         }\r
         \r
@@ -885,6 +1559,8 @@ public class FpdFileContents {
     \r
     public void removeDynamicPcdBuildDataSkuInfo(int i) {\r
         if (getfpdDynPcdBuildDefs().getPcdBuildDataList() == null || getfpdDynPcdBuildDefs().getPcdBuildDataList().size() == 0) {\r
+            removeElement(getfpdDynPcdBuildDefs());\r
+            fpdDynPcdBuildDefs = null;\r
             return;\r
         }\r
         \r
@@ -911,9 +1587,9 @@ public class FpdFileContents {
     //\r
     public void genDynamicPcdBuildDataSkuInfo(String id, String varName, String varGuid, String varOffset, \r
                                               String hiiDefault, String vpdOffset, String value, int i) {\r
-        if (getfpdDynPcdBuildDefs().getPcdBuildDataList() == null || getfpdDynPcdBuildDefs().getPcdBuildDataList().size() == 0) {\r
-            return;\r
-        }\r
+//        if (getfpdDynPcdBuildDefs().getPcdBuildDataList() == null || getfpdDynPcdBuildDefs().getPcdBuildDataList().size() == 0) {\r
+//            return;\r
+//        }\r
         \r
         XmlCursor cursor = getfpdDynPcdBuildDefs().newCursor();\r
         if (cursor.toFirstChild()) {\r
@@ -940,9 +1616,9 @@ public class FpdFileContents {
     \r
     public void updateDynamicPcdBuildDataSkuInfo(String id, String varName, String varGuid, String varOffset, \r
                                                  String hiiDefault, String vpdOffset, String value, int i){\r
-        if (getfpdDynPcdBuildDefs().getPcdBuildDataList() == null || getfpdDynPcdBuildDefs().getPcdBuildDataList().size() == 0) {\r
-            return;\r
-        }\r
+//        if (getfpdDynPcdBuildDefs().getPcdBuildDataList() == null || getfpdDynPcdBuildDefs().getPcdBuildDataList().size() == 0) {\r
+//            return;\r
+//        }\r
         \r
         XmlCursor cursor = getfpdDynPcdBuildDefs().newCursor();\r
         if (cursor.toFirstChild()) {\r
@@ -972,15 +1648,6 @@ public class FpdFileContents {
         }\r
     }\r
     \r
-    public void removePcdDataFromLibraryInstance(String moduleKey, String libInstanceKey){\r
-        ModuleSADocument.ModuleSA moduleSa = getModuleSA(moduleKey);\r
-        //\r
-        //  should better maintain pcd from lib instance only, but maintain all is acceptable now. \r
-        //\r
-        maintainDynPcdMap(moduleSa.getPcdBuildDefinition(), libInstanceKey);\r
-        \r
-    }\r
-    \r
     public BuildOptionsDocument.BuildOptions getfpdBuildOpts() {\r
         if (fpdBuildOpts == null) {\r
             fpdBuildOpts = fpdRoot.addNewBuildOptions();\r
@@ -988,6 +1655,153 @@ public class FpdFileContents {
         return fpdBuildOpts;\r
     }\r
     \r
+    public void genBuildOptionsUserExtensions(String fvName, String outputFileName, Vector<String[]> includeModules) {\r
+        QName elementFvName = new QName (xmlNs, "FvName");\r
+        QName elementIncludeModules = new QName(xmlNs, "IncludeModules");\r
+        QName elementInfFileName = new QName(xmlNs, "InfFileName");\r
+        QName elementModule = new QName(xmlNs, "Module");\r
+        \r
+        UserExtensionsDocument.UserExtensions userExts = getfpdBuildOpts().addNewUserExtensions();\r
+        userExts.setUserID("IMAGES");\r
+        userExts.setIdentifier(new BigInteger("1"));\r
+        XmlCursor cursor = userExts.newCursor();\r
+        cursor.toEndToken();\r
+        \r
+        cursor.beginElement(elementFvName);\r
+        cursor.insertChars(fvName);\r
+        cursor.toNextToken();\r
+        \r
+        cursor.beginElement(elementInfFileName);\r
+        cursor.insertChars(fvName + ".inf");\r
+        cursor.toNextToken();\r
+        \r
+        cursor.beginElement(elementIncludeModules);\r
+        for (int i = 0; i < includeModules.size(); ++i) {\r
+            cursor.beginElement(elementModule);\r
+            cursor.insertAttributeWithValue("ModuleGuid", includeModules.get(i)[0]);\r
+            cursor.insertAttributeWithValue("BaseName", includeModules.get(i)[1]);\r
+            cursor.toEndToken();\r
+            cursor.toNextToken();\r
+        }\r
+        cursor.dispose();\r
+    }\r
+    \r
+    public int getUserExtsIncModCount (String fvName) {\r
+        if (getfpdBuildOpts().getUserExtensionsList() == null) {\r
+            return -1;\r
+        }\r
+        ListIterator<UserExtensionsDocument.UserExtensions> li = getfpdBuildOpts().getUserExtensionsList().listIterator();\r
+        QName elementIncludeModules = new QName(xmlNs, "IncludeModules");\r
+        while (li.hasNext()) {\r
+            UserExtensionsDocument.UserExtensions ues = li.next();\r
+            if (!ues.getUserID().equals("IMAGES")) {\r
+                continue;\r
+            }\r
+            XmlCursor cursor = ues.newCursor();\r
+            cursor.toFirstChild();\r
+            String elementName = cursor.getTextValue();\r
+            if (elementName.equals(fvName)) {\r
+                cursor.toNextSibling(elementIncludeModules);\r
+                if (cursor.toFirstChild()) {\r
+                    int i = 1;\r
+                    for (i = 1; cursor.toNextSibling(); ++i);\r
+                    cursor.dispose();\r
+                    return i;\r
+                }\r
+                cursor.dispose();\r
+                return 0;\r
+            }\r
+            cursor.dispose();\r
+        }\r
+        return -1;\r
+    }\r
+    \r
+    public void getUserExtsIncMods(String fvName, String[][] saa) {\r
+        if (getfpdBuildOpts().getUserExtensionsList() == null) {\r
+            return;\r
+        }\r
+        \r
+        XmlCursor cursor = getfpdBuildOpts().newCursor();\r
+        QName elementUserExts = new QName (xmlNs, "UserExtensions");\r
+        QName attribUserId = new QName ("UserID");\r
+        QName elementFvName = new QName (xmlNs, "FvName");\r
+        QName elementIncludeModules = new QName(xmlNs, "IncludeModules");\r
+        QName attribModuleGuid = new QName("ModuleGuid");\r
+        QName attribBaseName = new QName("BaseName");\r
+        \r
+        if (cursor.toChild(elementUserExts)) {\r
+            do {\r
+                cursor.push();\r
+                if (cursor.getAttributeText(attribUserId).equals("IMAGES")) {\r
+                    cursor.toChild(elementFvName);\r
+                    String elementName = cursor.getTextValue();\r
+                    if (elementName.equals(fvName)) {\r
+                        cursor.toNextSibling(elementIncludeModules);\r
+                        if (cursor.toFirstChild()) {\r
+                            int i = 0;\r
+                            do {\r
+                                saa[i][0] = cursor.getAttributeText(attribModuleGuid);\r
+                                saa[i][1] = cursor.getAttributeText(attribBaseName);\r
+                                ++i;\r
+                            }while (cursor.toNextSibling());\r
+                        }\r
+                        break;\r
+                    }\r
+                }\r
+                cursor.pop();\r
+            }while (cursor.toNextSibling(elementUserExts));\r
+        }\r
+        cursor.dispose();\r
+        \r
+    }\r
+    \r
+    public void updateBuildOptionsUserExtensions (String oldFvName, String newFvName) {\r
+        if (getfpdBuildOpts().getUserExtensionsList() == null) {\r
+            return;\r
+        }\r
+        ListIterator<UserExtensionsDocument.UserExtensions> li = getfpdBuildOpts().getUserExtensionsList().listIterator();\r
+        while (li.hasNext()) {\r
+            UserExtensionsDocument.UserExtensions ues = li.next();\r
+            if (!ues.getUserID().equals("IMAGES")) {\r
+                continue;\r
+            }\r
+            XmlCursor cursor = ues.newCursor();\r
+            cursor.toFirstChild();\r
+            String elementName = cursor.getTextValue();\r
+            if (elementName.equals(oldFvName)) {\r
+                cursor.setTextValue(newFvName);\r
+            }\r
+            cursor.dispose();\r
+        }\r
+        \r
+    }\r
+    \r
+    public void removeBuildOptionsUserExtensions (String fvName) {\r
+        if (getfpdBuildOpts().getUserExtensionsList() == null) {\r
+            return;\r
+        }\r
+        \r
+        ListIterator<UserExtensionsDocument.UserExtensions> li = getfpdBuildOpts().getUserExtensionsList().listIterator();\r
+        while (li.hasNext()) {\r
+            UserExtensionsDocument.UserExtensions ues = li.next();\r
+            if (!ues.getUserID().equals("IMAGES")) {\r
+                continue;\r
+            }\r
+            XmlCursor cursor = ues.newCursor();\r
+            cursor.toFirstChild();\r
+            String elementName = cursor.getTextValue();\r
+            if (elementName.equals(fvName)) {\r
+                cursor.toParent();\r
+                cursor.removeXml();\r
+                cursor.dispose();\r
+                return;\r
+            }\r
+            cursor.dispose();\r
+        }\r
+        \r
+    }\r
+    \r
+    \r
     public void genBuildOptionsUserDefAntTask (String id, String fileName, String execOrder) {\r
         UserDefinedAntTasksDocument.UserDefinedAntTasks udats = getfpdBuildOpts().getUserDefinedAntTasks();\r
         if (udats == null) {\r
@@ -1000,12 +1814,20 @@ public class FpdFileContents {
     \r
     private void setBuildOptionsUserDefAntTask(String id, String fileName, String execOrder, AntTaskDocument.AntTask at) {\r
         at.setId(new Integer(id));\r
+        XmlCursor cursor = at.newCursor();\r
         if (fileName != null){\r
             at.setFilename(fileName);\r
         }\r
+        else if (cursor.toChild(xmlNs, "Filename")) {\r
+            cursor.removeXml();\r
+        }\r
         if (execOrder != null) {\r
             at.setAntCmdOptions(execOrder);\r
         }\r
+        else if (cursor.toChild(xmlNs, "AntCmdOptions")) {\r
+            cursor.removeXml();\r
+        }\r
+        cursor.dispose();\r
     }\r
     \r
     public void removeBuildOptionsUserDefAntTask(int i) {\r
@@ -1019,6 +1841,10 @@ public class FpdFileContents {
                 cursor.toNextSibling();\r
             }\r
             cursor.removeXml();\r
+            if (getBuildOptionsUserDefAntTaskCount() == 0) {\r
+                cursor.toParent();\r
+                cursor.removeXml();\r
+            }\r
         }\r
         cursor.dispose();\r
     }\r
@@ -1070,37 +1896,542 @@ public class FpdFileContents {
             ++i;\r
         }\r
     }\r
-    public void genBuildOptionsOpt(String buildTargets, String toolChain, String tagName, String toolCmd, String archList, String contents) {\r
+    public void genBuildOptionsOpt(Vector<Object> buildTargets, String toolChain, String tagName, String toolCmd, Vector<Object> archList, String contents) {\r
         OptionsDocument.Options opts = getfpdBuildOpts().getOptions();\r
         if (opts == null) {\r
             opts = getfpdBuildOpts().addNewOptions();\r
         }\r
-        OptionDocument.Option opt = opts.addNewOption();\r
-        setBuildOptionsOpt(buildTargets, toolChain, tagName, toolCmd, archList, contents, opt);\r
+        OptionDocument.Option opt = opts.addNewOption();\r
+        setBuildOptionsOpt(buildTargets, toolChain, tagName, toolCmd, archList, contents, opt);\r
+    }\r
+    \r
+    private void setBuildOptionsOpt(Vector<Object> buildTargets, String toolChain, String tagName, String toolCmd, Vector<Object> archList, String contents, OptionDocument.Option opt){\r
+        opt.setStringValue(contents);\r
+        \r
+        opt.setBuildTargets(buildTargets);\r
+        opt.setToolChainFamily(toolChain);\r
+        opt.setTagName(tagName);\r
+        opt.setToolCode(toolCmd);\r
+        \r
+        if (archList != null) {\r
+            opt.setSupArchList(archList);\r
+        }\r
+        else {\r
+            if (opt.isSetSupArchList()) {\r
+                opt.unsetSupArchList();\r
+            }\r
+        }\r
+    }\r
+    \r
+    public void removeBuildOptionsOpt(int i){\r
+    \r
+        XmlObject o = getfpdBuildOpts().getOptions();\r
+        if (o == null) {\r
+            return;\r
+        }\r
+        \r
+        XmlCursor cursor = o.newCursor();\r
+        if (cursor.toFirstChild()) {\r
+            for (int j = 0; j < i; ++j) {\r
+                cursor.toNextSibling();\r
+            }\r
+            cursor.removeXml();\r
+            if (getBuildOptionsOptCount() == 0) {\r
+                cursor.toParent();\r
+                cursor.removeXml();\r
+            }\r
+        }\r
+        cursor.dispose();\r
+    }\r
+    \r
+    public void updateBuildOptionsOpt(int i, Vector<Object> buildTargets, String toolChain, String tagName, String toolCmd, Vector<Object> archList, String contents) {\r
+        XmlObject o = getfpdBuildOpts().getOptions();\r
+        if (o == null) {\r
+            return;\r
+        }\r
+        \r
+        XmlCursor cursor = o.newCursor();\r
+        if (cursor.toFirstChild()) {\r
+            for (int j = 0; j < i; ++j) {\r
+                cursor.toNextSibling();\r
+            }\r
+            OptionDocument.Option opt = (OptionDocument.Option)cursor.getObject();\r
+            setBuildOptionsOpt(buildTargets, toolChain, tagName, toolCmd, archList, contents, opt);\r
+        }\r
+        cursor.dispose();\r
+    }\r
+    \r
+    public int getBuildOptionsOptCount(){\r
+        if (getfpdBuildOpts().getOptions() == null || getfpdBuildOpts().getOptions().getOptionList() == null) {\r
+            return 0;\r
+        }\r
+        return getfpdBuildOpts().getOptions().getOptionList().size();\r
+    }\r
+    \r
+    public void getBuildOptionsOpts(String[][] saa) {\r
+        if (getfpdBuildOpts().getOptions() == null || getfpdBuildOpts().getOptions().getOptionList() == null) {\r
+            return ;\r
+        }\r
+        \r
+        List<OptionDocument.Option> lOpt = getfpdBuildOpts().getOptions().getOptionList();\r
+        ListIterator li = lOpt.listIterator();\r
+        int i = 0;\r
+        while(li.hasNext()) {\r
+            OptionDocument.Option opt = (OptionDocument.Option)li.next();\r
+            if (opt.getBuildTargets() != null) {\r
+                saa[i][0] = listToString(opt.getBuildTargets());\r
+            }\r
+            saa[i][1] = opt.getToolChainFamily();\r
+            if (opt.getSupArchList() != null){\r
+                saa[i][2] = listToString(opt.getSupArchList());\r
+\r
+            }\r
+            saa[i][3] = opt.getToolCode();\r
+            saa[i][4] = opt.getTagName();\r
+            saa[i][5] = opt.getStringValue();\r
+             \r
+            ++i;\r
+        }\r
+    }\r
+    \r
+    public void genBuildOptionsFfs(String ffsKey, String type) {\r
+        BuildOptionsDocument.BuildOptions.Ffs ffs = getfpdBuildOpts().addNewFfs();\r
+        ffs.setFfsKey(ffsKey);\r
+        if (type != null) {\r
+            ffs.addNewSections().setEncapsulationType(type);\r
+        }\r
+    }\r
+    \r
+    public void updateBuildOptionsFfsSectionsType(int i, String type) {\r
+        BuildOptionsDocument.BuildOptions.Ffs ffs = getfpdBuildOpts().addNewFfs();\r
+        if (type != null) {\r
+            ffs.addNewSections().setEncapsulationType(type);\r
+        }\r
+    }\r
+    \r
+    public void genBuildOptionsFfsAttribute(int i, String name, String value) {\r
+        BuildOptionsDocument.BuildOptions.Ffs ffs = getFfs(i);\r
+        BuildOptionsDocument.BuildOptions.Ffs.Attribute attrib = ffs.addNewAttribute();\r
+        attrib.setName(name);\r
+        attrib.setValue(value);\r
+    }\r
+    \r
+    /**update jth attribute of ith ffs.\r
+     * @param i\r
+     * @param j\r
+     */\r
+    public void updateBuildOptionsFfsAttribute(int i, int j, String name, String value){\r
+        BuildOptionsDocument.BuildOptions.Ffs ffs = getFfs(i);\r
+        XmlCursor cursor = ffs.newCursor();\r
+        QName qAttrib = new QName(xmlNs, "Attribute");\r
+        if (cursor.toChild(qAttrib)) {\r
+            for (int k = 0; k < j; ++k) {\r
+                cursor.toNextSibling(qAttrib);\r
+            }\r
+            BuildOptionsDocument.BuildOptions.Ffs.Attribute attrib = (BuildOptionsDocument.BuildOptions.Ffs.Attribute)cursor.getObject();\r
+            attrib.setName(name);\r
+            attrib.setValue(value);\r
+        }\r
+        cursor.dispose();\r
+    }\r
+    \r
+    public void removeBuildOptionsFfsAttribute(int i, int j){\r
+        BuildOptionsDocument.BuildOptions.Ffs ffs = getFfs(i);\r
+        XmlCursor cursor = ffs.newCursor();\r
+        QName qAttrib = new QName(xmlNs, "Attribute");\r
+        if (cursor.toChild(qAttrib)) {\r
+            for (int k = 0; k < j; ++k) {\r
+                cursor.toNextSibling(qAttrib);\r
+            }\r
+            cursor.removeXml();\r
+        }\r
+        cursor.dispose();\r
+    }\r
+    \r
+    public void genBuildOptionsFfsSectionsSection(int i, String sectionType) {\r
+        BuildOptionsDocument.BuildOptions.Ffs ffs = getFfs(i);\r
+        if (ffs == null) {\r
+            return;\r
+        }\r
+        BuildOptionsDocument.BuildOptions.Ffs.Sections sections = ffs.getSections();\r
+        \r
+        if (sections == null){\r
+            sections = ffs.addNewSections();\r
+        }\r
+        sections.addNewSection().setSectionType(EfiSectionType.Enum.forString(sectionType));\r
+    }\r
+    \r
+    public void removeBuildOptionsFfsSectionsSection(int i, int j) {\r
+        BuildOptionsDocument.BuildOptions.Ffs ffs = getFfs(i);\r
+        BuildOptionsDocument.BuildOptions.Ffs.Sections sections = ffs.getSections();\r
+        if (sections == null) {\r
+            return;\r
+        }\r
+        XmlCursor cursor = sections.newCursor();\r
+        QName qSection = new QName(xmlNs, "Section");\r
+        if (cursor.toChild(qSection)) {\r
+            for (int k = 0; k < j; ++k) {\r
+                cursor.toNextSibling(qSection);\r
+            }\r
+            cursor.removeXml();\r
+        }\r
+        cursor.dispose();\r
+    }\r
+    \r
+    public void updateBuildOptionsFfsSectionsSection(int i, int j, String type){\r
+        BuildOptionsDocument.BuildOptions.Ffs ffs = getFfs(i);\r
+        BuildOptionsDocument.BuildOptions.Ffs.Sections sections = ffs.getSections();\r
+        if (sections == null) {\r
+            return;\r
+        }\r
+        XmlCursor cursor = sections.newCursor();\r
+        QName qSection = new QName(xmlNs, "Section");\r
+        if (cursor.toChild(qSection)) {\r
+            for (int k = 0; k < j; ++k) {\r
+                cursor.toNextSibling(qSection);\r
+            }\r
+            BuildOptionsDocument.BuildOptions.Ffs.Sections.Section section = (BuildOptionsDocument.BuildOptions.Ffs.Sections.Section)cursor.getObject();\r
+            section.setSectionType(EfiSectionType.Enum.forString(type));\r
+        }\r
+        cursor.dispose();\r
+    } \r
+    \r
+    public void genBuildOptionsFfsSectionsSections(int i, String encapType) {\r
+        BuildOptionsDocument.BuildOptions.Ffs ffs = getFfs(i);\r
+        if (ffs == null) {\r
+            return;\r
+        }\r
+        BuildOptionsDocument.BuildOptions.Ffs.Sections sections = ffs.getSections();\r
+        \r
+        if (sections == null){\r
+            sections = ffs.addNewSections();\r
+        }\r
+        sections.addNewSections().setEncapsulationType(encapType);\r
+    }\r
+    \r
+    public void removeBuildOptionsFfsSectionsSections(int i, int j) {\r
+        BuildOptionsDocument.BuildOptions.Ffs ffs = getFfs(i);\r
+        BuildOptionsDocument.BuildOptions.Ffs.Sections sections = ffs.getSections();\r
+        if (sections == null) {\r
+            return;\r
+        }\r
+        XmlCursor cursor = sections.newCursor();\r
+        QName qSections = new QName(xmlNs, "Sections");\r
+        if (cursor.toChild(qSections)) {\r
+            for (int k = 0; k < j; ++k) {\r
+                cursor.toNextSibling(qSections);\r
+            }\r
+            cursor.removeXml();\r
+        }\r
+        cursor.dispose();\r
+    }\r
+    \r
+    public void updateBuildOptionsFfsSectionsSections(int i, int j, String type) {\r
+        BuildOptionsDocument.BuildOptions.Ffs ffs = getFfs(i);\r
+        BuildOptionsDocument.BuildOptions.Ffs.Sections sections = ffs.getSections();\r
+        if (sections == null) {\r
+            return;\r
+        }\r
+        XmlCursor cursor = sections.newCursor();\r
+        QName qSections = new QName(xmlNs, "Sections");\r
+        if (cursor.toChild(qSections)) {\r
+            for (int k = 0; k < j; ++k) {\r
+                cursor.toNextSibling(qSections);\r
+            }\r
+            BuildOptionsDocument.BuildOptions.Ffs.Sections.Sections2 sections2 = (BuildOptionsDocument.BuildOptions.Ffs.Sections.Sections2)cursor.getObject();\r
+            sections2.setEncapsulationType(type);\r
+        }\r
+        cursor.dispose();\r
+    }\r
+    \r
+    public void genBuildOptionsFfsSectionsSectionsSection(int i, int j, String type) {\r
+        BuildOptionsDocument.BuildOptions.Ffs ffs = getFfs(i);\r
+        if (ffs == null) {\r
+            return;\r
+        }\r
+        BuildOptionsDocument.BuildOptions.Ffs.Sections sections = ffs.getSections();\r
+        XmlCursor cursor = sections.newCursor();\r
+        QName qSections = new QName(xmlNs, "Sections");\r
+        if (cursor.toChild(qSections)){\r
+            for (int k = 0; k < j; ++k) {\r
+                cursor.toNextSibling(qSections);\r
+            }\r
+            BuildOptionsDocument.BuildOptions.Ffs.Sections.Sections2 sections2 = (BuildOptionsDocument.BuildOptions.Ffs.Sections.Sections2)cursor.getObject();\r
+            sections2.addNewSection().setSectionType(EfiSectionType.Enum.forString(type));\r
+        }\r
+        cursor.dispose();\r
+    }\r
+    \r
+    public void removeBuildOptionsFfsSectionsSectionsSection(int i, int j, int k) {\r
+        BuildOptionsDocument.BuildOptions.Ffs ffs = getFfs(i);\r
+        BuildOptionsDocument.BuildOptions.Ffs.Sections sections = ffs.getSections();\r
+        if (sections == null) {\r
+            return;\r
+        }\r
+        XmlCursor cursor = sections.newCursor();\r
+        QName qSections = new QName(xmlNs, "Sections");\r
+        if (cursor.toChild(qSections)) {\r
+            for (int l = 0; l < j; ++l) {\r
+                cursor.toNextSibling(qSections);\r
+            }\r
+            if (cursor.toFirstChild()) {\r
+                int m = 0;\r
+                for (; m < k; ++m) {\r
+                    cursor.toNextSibling();\r
+                }\r
+                cursor.removeXml();\r
+                if (m == 0) {\r
+                    cursor.toParent();\r
+                    cursor.removeXml();\r
+                }\r
+            }\r
+        }\r
+        cursor.dispose();\r
+    }\r
+    \r
+    public void updateBuildOptionsFfsSectionsSectionsSection(int i, int j, int k, String type) {\r
+        BuildOptionsDocument.BuildOptions.Ffs ffs = getFfs(i);\r
+        BuildOptionsDocument.BuildOptions.Ffs.Sections sections = ffs.getSections();\r
+        if (sections == null) {\r
+            return;\r
+        }\r
+        XmlCursor cursor = sections.newCursor();\r
+        QName qSections = new QName(xmlNs, "Sections");\r
+        if (cursor.toChild(qSections)) {\r
+            for (int l = 0; l < j; ++l) {\r
+                cursor.toNextSibling(qSections);\r
+            }\r
+            if (cursor.toFirstChild()) {\r
+                for (int m = 0; m < k; ++m) {\r
+                    cursor.toNextSibling();\r
+                }\r
+                BuildOptionsDocument.BuildOptions.Ffs.Sections.Sections2.Section section = (BuildOptionsDocument.BuildOptions.Ffs.Sections.Sections2.Section)cursor.getObject();\r
+                section.setSectionType(EfiSectionType.Enum.forString(type));\r
+            }\r
+        }\r
+        cursor.dispose();\r
+    }\r
+    \r
+    public void getBuildOptionsFfsSectionsSectionsSection(int i, int j, ArrayList<String> al) {\r
+        BuildOptionsDocument.BuildOptions.Ffs ffs = getFfs(i);\r
+        if (ffs == null) {\r
+            return;\r
+        }\r
+        BuildOptionsDocument.BuildOptions.Ffs.Sections sections = ffs.getSections();\r
+        XmlCursor cursor = sections.newCursor();\r
+        QName qSections = new QName(xmlNs, "Sections");\r
+        if (cursor.toChild(qSections)){\r
+            for (int k = 0; k < j; ++k) {\r
+                cursor.toNextSibling(qSections);\r
+            }\r
+            BuildOptionsDocument.BuildOptions.Ffs.Sections.Sections2 sections2 = (BuildOptionsDocument.BuildOptions.Ffs.Sections.Sections2)cursor.getObject();\r
+            if (sections2.getSectionList() == null){\r
+                cursor.dispose();\r
+                return;\r
+            }\r
+            ListIterator<BuildOptionsDocument.BuildOptions.Ffs.Sections.Sections2.Section> li = sections2.getSectionList().listIterator();\r
+            while(li.hasNext()) {\r
+                BuildOptionsDocument.BuildOptions.Ffs.Sections.Sections2.Section section = li.next();\r
+                if (section.isSetSectionType()) {\r
+                    al.add(section.getSectionType().toString());\r
+                }\r
+                \r
+            }\r
+        }\r
+        cursor.dispose();\r
+        \r
+    }\r
+    \r
+    public int getBuildOptionsFfsCount(){\r
+        if (getfpdBuildOpts().getFfsList() == null) {\r
+            return 0;\r
+        }\r
+        return getfpdBuildOpts().getFfsList().size();\r
+    }\r
+    \r
+    public void getBuildOptionsFfsKey(String[][] saa) {\r
+        if (getfpdBuildOpts().getFfsList() == null) {\r
+            return;\r
+        }\r
+        ListIterator<BuildOptionsDocument.BuildOptions.Ffs> li = getfpdBuildOpts().getFfsList().listIterator();\r
+        int i = 0;\r
+        while(li.hasNext()){\r
+            BuildOptionsDocument.BuildOptions.Ffs ffs = li.next();\r
+            saa[i][0] = ffs.getFfsKey();\r
+            ++i;\r
+        }\r
+    }\r
+    \r
+    public void updateBuildOptionsFfsKey(int i, String key) {\r
+        BuildOptionsDocument.BuildOptions.Ffs ffs = getFfs(i);\r
+        ffs.setFfsKey(key);\r
+    }\r
+    \r
+    /**Get ith FFS key and contents.\r
+     * @param saa\r
+     */\r
+    public void getBuildOptionsFfs(int i, String[] sa, LinkedHashMap<String, String> ffsAttribMap, ArrayList<String> firstLevelSections, ArrayList<String> firstLevelSection) {\r
+        BuildOptionsDocument.BuildOptions.Ffs ffs = getFfs(i);\r
+     \r
+        if (ffs != null) {\r
+         \r
+            sa[0] = ffs.getFfsKey();\r
+            if (ffs.getSections() != null) {\r
+                if(ffs.getSections().getEncapsulationType() != null){\r
+                    sa[1] = ffs.getSections().getEncapsulationType();\r
+                }\r
+                if (ffs.getSections().getSectionList() != null){\r
+                    ListIterator<BuildOptionsDocument.BuildOptions.Ffs.Sections.Section> li = ffs.getSections().getSectionList().listIterator();\r
+                    while (li.hasNext()) {\r
+                        firstLevelSection.add(li.next().getSectionType().toString());\r
+                    }\r
+                }\r
+                if (ffs.getSections().getSectionsList() != null) {\r
+                    ListIterator<BuildOptionsDocument.BuildOptions.Ffs.Sections.Sections2> li = ffs.getSections().getSectionsList().listIterator();\r
+                    while(li.hasNext()) {\r
+                        firstLevelSections.add(li.next().getEncapsulationType());\r
+                    }\r
+                }\r
+            }\r
+            if (ffs.getAttributeList() != null) {\r
+                ListIterator<BuildOptionsDocument.BuildOptions.Ffs.Attribute> li = ffs.getAttributeList().listIterator();\r
+                while(li.hasNext()) {\r
+                    BuildOptionsDocument.BuildOptions.Ffs.Attribute attrib = li.next();\r
+                    ffsAttribMap.put(attrib.getName(), attrib.getValue());\r
+                }\r
+                \r
+            }\r
+        }\r
+\r
+        \r
+    }\r
+    \r
+    private BuildOptionsDocument.BuildOptions.Ffs getFfs(int i) {\r
+        XmlObject o = getfpdBuildOpts();\r
+        BuildOptionsDocument.BuildOptions.Ffs ffs = null;\r
+        \r
+        XmlCursor cursor = o.newCursor();\r
+        QName qFfs = new QName(xmlNs, "Ffs");\r
+        if (cursor.toChild(qFfs)) {\r
+            for (int j = 0; j < i; ++j) {\r
+                cursor.toNextSibling(qFfs);\r
+            }\r
+            ffs = (BuildOptionsDocument.BuildOptions.Ffs)cursor.getObject();\r
+        }\r
+        cursor.dispose();\r
+        return ffs;\r
+    }\r
+    \r
+    public void removeBuildOptionsFfs(int i) {\r
+        BuildOptionsDocument.BuildOptions.Ffs ffs = getFfs(i);\r
+        if (ffs == null){\r
+            return;\r
+        }\r
+        \r
+        XmlCursor cursor = ffs.newCursor();\r
+        cursor.removeXml();\r
+        cursor.dispose();\r
+    }\r
+    \r
+    \r
+    \r
+    public PlatformDefinitionsDocument.PlatformDefinitions getfpdPlatformDefs(){\r
+        if (fpdPlatformDefs == null){\r
+            fpdPlatformDefs = fpdRoot.addNewPlatformDefinitions();\r
+        }\r
+        return fpdPlatformDefs;\r
+    }\r
+    \r
+    public void getPlatformDefsSupportedArchs(Vector<Object> archs){\r
+        if (getfpdPlatformDefs().getSupportedArchitectures() == null) {\r
+            return;\r
+        }\r
+        ListIterator li = getfpdPlatformDefs().getSupportedArchitectures().listIterator();\r
+        while(li.hasNext()) {\r
+            archs.add(li.next());\r
+        }\r
+    }\r
+    \r
+    public void setPlatformDefsSupportedArchs(Vector<Object> archs) {\r
+        if (archs != null) {\r
+            getfpdPlatformDefs().setSupportedArchitectures(archs);\r
+        }\r
+//        else {\r
+//            XmlCursor cursor = getfpdPlatformDefs().newCursor();\r
+//            if (cursor.toChild(xmlNs, "SupportedArchitectures")) {\r
+//                cursor.removeXml();\r
+//            }\r
+//            cursor.dispose();\r
+//        }\r
+    }\r
+    \r
+    public void getPlatformDefsBuildTargets(Vector<Object> targets) {\r
+        if (getfpdPlatformDefs().getBuildTargets() == null) {\r
+            return;\r
+        }\r
+        ListIterator li = getfpdPlatformDefs().getBuildTargets().listIterator();\r
+        while(li.hasNext()) {\r
+            targets.add(li.next());\r
+        }\r
+    }\r
+    \r
+    public void setPlatformDefsBuildTargets(Vector<Object> targets) {\r
+        getfpdPlatformDefs().setBuildTargets(targets);\r
+    }\r
+    \r
+    public void genPlatformDefsSkuInfo(String id, String name) {\r
+        SkuInfoDocument.SkuInfo skuInfo = null;\r
+        if (getfpdPlatformDefs().getSkuInfo() == null) {\r
+            skuInfo = getfpdPlatformDefs().addNewSkuInfo();\r
+        }\r
+        skuInfo = getfpdPlatformDefs().getSkuInfo();\r
+        if (skuInfo.getUiSkuNameList() == null || skuInfo.getUiSkuNameList().size() == 0) {\r
+            SkuInfoDocument.SkuInfo.UiSkuName skuName = skuInfo.addNewUiSkuName();\r
+            skuName.setSkuID(new BigInteger("0"));\r
+            skuName.setStringValue("DEFAULT");\r
+        }\r
+        if (id.equals("0")) {\r
+            return;\r
+        }\r
+        SkuInfoDocument.SkuInfo.UiSkuName skuName = skuInfo.addNewUiSkuName();\r
+        skuName.setSkuID(new BigInteger(id));\r
+        skuName.setStringValue(name);\r
     }\r
     \r
-    private void setBuildOptionsOpt(String buildTargets, String toolChain, String tagName, String toolCmd, String archList, String contents, OptionDocument.Option opt){\r
-        opt.setStringValue(contents);\r
-//        opt.setBuildTargets(buildTargets);\r
-        opt.setToolChainFamily(toolChain);\r
-        opt.setTagName(tagName);\r
-        opt.setToolCode(toolCmd);\r
-        String[] s = archList.split(" ");\r
-        ArrayList<String> al = new ArrayList<String>();\r
-        for (int i = 0; i < s.length; ++i) {\r
-            al.add(s[i]);\r
+    public int getPlatformDefsSkuInfoCount(){\r
+        if (getfpdPlatformDefs().getSkuInfo() == null || getfpdPlatformDefs().getSkuInfo().getUiSkuNameList() == null) {\r
+            return 0;\r
         }\r
-        opt.setSupArchList(al);\r
+        return getfpdPlatformDefs().getSkuInfo().getUiSkuNameList().size();\r
     }\r
     \r
-    public void removeBuildOptionsOpt(int i){\r
+    public void getPlatformDefsSkuInfos(String[][] saa){\r
+        if (getfpdPlatformDefs().getSkuInfo() == null || getfpdPlatformDefs().getSkuInfo().getUiSkuNameList() == null) {\r
+            if (getfpdDynPcdBuildDefs().getPcdBuildDataList() == null) {\r
+                removeElement(getfpdDynPcdBuildDefs());\r
+                fpdDynPcdBuildDefs = null;\r
+            }\r
+            return ;\r
+        }\r
+        \r
+        List<SkuInfoDocument.SkuInfo.UiSkuName> l = getfpdPlatformDefs().getSkuInfo().getUiSkuNameList();\r
+        ListIterator<SkuInfoDocument.SkuInfo.UiSkuName> li = l.listIterator();\r
+        int i = 0;\r
+        while(li.hasNext()) {\r
+            SkuInfoDocument.SkuInfo.UiSkuName sku = li.next();\r
+            saa[i][0] = sku.getSkuID()+"";\r
+            saa[i][1] = sku.getStringValue();\r
+            ++i;\r
+        }\r
+    }\r
     \r
-        XmlObject o = getfpdBuildOpts().getOptions();\r
-        if (o == null) {\r
-            return;\r
+    public void removePlatformDefsSkuInfo(int i) {\r
+        SkuInfoDocument.SkuInfo skuInfo = getfpdPlatformDefs().getSkuInfo();\r
+        if (skuInfo == null || i == 0) {\r
+            return ;\r
         }\r
         \r
-        XmlCursor cursor = o.newCursor();\r
+        XmlCursor cursor = skuInfo.newCursor();\r
         if (cursor.toFirstChild()) {\r
             for (int j = 0; j < i; ++j) {\r
                 cursor.toNextSibling();\r
@@ -1110,64 +2441,50 @@ public class FpdFileContents {
         cursor.dispose();\r
     }\r
     \r
-    public void updateBuildOptionsOpt(int i, String buildTargets, String toolChain, String tagName, String toolCmd, String archList, String contents) {\r
-        XmlObject o = getfpdBuildOpts().getOptions();\r
-        if (o == null) {\r
-            return;\r
+    public void updatePlatformDefsSkuInfo(int i, String id, String name) {\r
+        SkuInfoDocument.SkuInfo skuInfo = getfpdPlatformDefs().getSkuInfo();\r
+        if (skuInfo == null || i == 0) {\r
+            return ;\r
         }\r
         \r
-        XmlCursor cursor = o.newCursor();\r
+        XmlCursor cursor = skuInfo.newCursor();\r
         if (cursor.toFirstChild()) {\r
             for (int j = 0; j < i; ++j) {\r
                 cursor.toNextSibling();\r
             }\r
-            OptionDocument.Option opt = (OptionDocument.Option)cursor.getObject();\r
-            setBuildOptionsOpt(buildTargets, toolChain, tagName, toolCmd, archList, contents, opt);\r
+            SkuInfoDocument.SkuInfo.UiSkuName sku = (SkuInfoDocument.SkuInfo.UiSkuName)cursor.getObject();\r
+            sku.setSkuID(new BigInteger(id));\r
+            sku.setStringValue(name);\r
         }\r
         cursor.dispose();\r
     }\r
     \r
-    public int getBuildOptionsOptCount(){\r
-        if (getfpdBuildOpts().getOptions() == null || getfpdBuildOpts().getOptions().getOptionList() == null) {\r
-            return 0;\r
+    public String getPlatformDefsInterDir(){\r
+        if (getfpdPlatformDefs().getIntermediateDirectories() == null) {\r
+            return null;\r
         }\r
-        return getfpdBuildOpts().getOptions().getOptionList().size();\r
+        return getfpdPlatformDefs().getIntermediateDirectories().toString();\r
     }\r
     \r
-    public void getBuildOptionsOpts(String[][] saa) {\r
-        if (getfpdBuildOpts().getOptions() == null || getfpdBuildOpts().getOptions().getOptionList() == null) {\r
-            return ;\r
-        }\r
-        \r
-        List<OptionDocument.Option> lOpt = getfpdBuildOpts().getOptions().getOptionList();\r
-        ListIterator li = lOpt.listIterator();\r
-        int i = 0;\r
-        while(li.hasNext()) {\r
-            OptionDocument.Option opt = (OptionDocument.Option)li.next();\r
-//            saa[i][0] = opt.getBuildTargets();\r
-            saa[i][1] = opt.getToolChainFamily();\r
-            if (opt.getSupArchList() != null){\r
-                Object[] archs = opt.getSupArchList().toArray();\r
-                saa[i][2] = " ";\r
-                for (int j = 0; j < archs.length; ++j){\r
-                    saa[i][2] += archs[j];\r
-                    saa[i][2] += " ";\r
-                }\r
-                saa[i][2] = saa[i][2].trim();\r
-            }\r
-            saa[i][3] = opt.getToolCode();\r
-            saa[i][4] = opt.getTagName();\r
-            saa[i][5] = opt.getStringValue();\r
-             \r
-            ++i;\r
-        }\r
+    public void setPlatformDefsInterDir(String interDir){\r
+        getfpdPlatformDefs().setIntermediateDirectories(IntermediateOutputType.Enum.forString(interDir));\r
     }\r
     \r
-    public PlatformDefinitionsDocument.PlatformDefinitions getfpdPlatformDefs(){\r
-        if (fpdPlatformDefs == null){\r
-            fpdPlatformDefs = fpdRoot.addNewPlatformDefinitions();\r
+    public String getPlatformDefsOutputDir() {\r
+        return getfpdPlatformDefs().getOutputDirectory();\r
+    }\r
+    \r
+    public void setPlatformDefsOutputDir(String outputDir) {\r
+        if (outputDir != null && outputDir.length() > 0) {\r
+            getfpdPlatformDefs().setOutputDirectory(outputDir);\r
+        }\r
+        else{\r
+            XmlCursor cursor = getfpdPlatformDefs().newCursor();\r
+            if (cursor.toChild(new QName(xmlNs, "OutputDirectory"))) {\r
+                cursor.removeXml();\r
+            }\r
+            cursor.dispose();\r
         }\r
-        return fpdPlatformDefs;\r
     }\r
     \r
     public FlashDocument.Flash getfpdFlash() {\r
@@ -1195,8 +2512,6 @@ public class FpdFileContents {
         return fdf.getStringValue();\r
     }\r
     \r
-    \r
-    \r
     public void genFvImagesNameValue(String name, String value) {\r
       \r
         FvImagesDocument.FvImages fi = getfpdFlash().getFvImages();\r
@@ -1275,6 +2590,43 @@ public class FpdFileContents {
         }\r
     }\r
     \r
+    public void getFvImagesFvImageFvImageNames (Vector<String> vImageNames) {\r
+        FvImagesDocument.FvImages fis = getfpdFlash().getFvImages();\r
+        if (fis == null || fis.getFvImageList() == null) {\r
+            return;\r
+        }\r
+        \r
+        ListIterator<FvImagesDocument.FvImages.FvImage> li = fis.getFvImageList().listIterator();\r
+        while (li.hasNext()) {\r
+            FvImagesDocument.FvImages.FvImage fi = li.next();\r
+            if (fi.getType().toString().equals("ImageName")) {\r
+                vImageNames.addAll(fi.getFvImageNamesList());\r
+                return;\r
+            }\r
+        }\r
+    }\r
+    \r
+    public void AddFvImageFvImageNames (String[] fvNames) {\r
+        FvImagesDocument.FvImages fis = getfpdFlash().getFvImages();\r
+        if (fis == null || fis.getFvImageList() == null) {\r
+            genFvImagesFvImage (fvNames, "ImageName", null);\r
+            return;\r
+        }\r
+        \r
+        ListIterator<FvImagesDocument.FvImages.FvImage> li = fis.getFvImageList().listIterator();\r
+        while (li.hasNext()) {\r
+            FvImagesDocument.FvImages.FvImage fi = li.next();\r
+            if (fi.getType().toString().equals("ImageName")) {\r
+                for (int i = 0; i < fvNames.length; ++i) {\r
+                    fi.addFvImageNames(fvNames[i]);\r
+                }\r
+                return;\r
+            }\r
+        }\r
+        genFvImagesFvImage (fvNames, "ImageName", null);\r
+        \r
+    }\r
+    \r
     public void genFvImagesFvImage(String[] names, String types, Map<String, String> options) {\r
       \r
         FvImagesDocument.FvImages fis = null;\r
@@ -1334,6 +2686,52 @@ public class FpdFileContents {
         cursor.dispose();\r
     }\r
     \r
+    /**\r
+     * @param oldFvName\r
+     * @param newFvName The New FV Name. If null, remove the old FvImageNames entry.\r
+     */\r
+    public void updateFvImageNameAll (String oldFvName, String newFvName) {\r
+        if (getfpdFlash().getFvImages() == null || getfpdFlash().getFvImages().getFvImageList() == null) {\r
+            return;\r
+        }\r
+        ListIterator<FvImagesDocument.FvImages.FvImage> li = getfpdFlash().getFvImages().getFvImageList().listIterator();\r
+        while (li.hasNext()) {\r
+            FvImagesDocument.FvImages.FvImage fi = li.next();\r
+            updateFvImageNamesInFvImage (fi, oldFvName, newFvName);\r
+        }\r
+    }\r
+    \r
+    /**\r
+     * @param fi\r
+     * @param oldFvName The FV Name to be replaced.\r
+     * @param newFvName The New FV Name. If null, remove the old FvImageNames entry.\r
+     */\r
+    public void updateFvImageNamesInFvImage (FvImagesDocument.FvImages.FvImage fi, String oldFvName, String newFvName) {\r
+        QName qFvImageNames = new QName(xmlNs, "FvImageNames");\r
+        XmlCursor cursor = fi.newCursor();\r
+        \r
+        if (cursor.toChild(qFvImageNames)) {\r
+            do {\r
+                if (cursor.getTextValue().equals(oldFvName)){\r
+                    if (newFvName != null) {\r
+                        cursor.setTextValue(newFvName);\r
+                    }\r
+                    else {\r
+                        if (fi.getFvImageNamesList().size() == 1) {\r
+                            removeElement(fi);\r
+                            break;\r
+                        }\r
+                        else {\r
+                            cursor.removeXml();\r
+                        }\r
+                    }\r
+                }\r
+            }while (cursor.toNextSibling(qFvImageNames));\r
+        }\r
+        \r
+        cursor.dispose();\r
+    }\r
+    \r
     public void updateFvImagesFvImage(int i, String[] names, String types, Map<String, String> options){\r
            \r
         XmlObject o = getfpdFlash().getFvImages();\r
@@ -1374,18 +2772,50 @@ public class FpdFileContents {
         cursor.dispose();\r
     }\r
     \r
-    public int getFvImagesFvImageCount() {\r
+    public int getFvImagesFvImageCount(String type) {\r
         \r
         if (getfpdFlash().getFvImages() == null || getfpdFlash().getFvImages().getFvImageList() == null) {\r
             return 0;\r
         }\r
-        return getfpdFlash().getFvImages().getFvImageList().size();\r
+        List<FvImagesDocument.FvImages.FvImage> l = getfpdFlash().getFvImages().getFvImageList();\r
+        ListIterator li = l.listIterator();\r
+        int i = 0;\r
+        while(li.hasNext()) {\r
+            FvImagesDocument.FvImages.FvImage fi = (FvImagesDocument.FvImages.FvImage)li.next();\r
+            if (!fi.getType().toString().equals(type) && !type.equals("ALL")) {\r
+                continue;\r
+            }\r
+            \r
+            ++i;\r
+        }\r
+        \r
+        return i;\r
     }\r
     \r
-    /**Only Get Fv image setting - name and type.\r
+    public Vector<FvImagesDocument.FvImages.FvImage> getFvImagesFvImageWithName (String fvName, String type) {\r
+        Vector<FvImagesDocument.FvImages.FvImage> vFvImage = new Vector<FvImagesDocument.FvImages.FvImage>();\r
+        if (getfpdFlash().getFvImages() == null || getfpdFlash().getFvImages().getFvImageList() == null) {\r
+            return vFvImage;\r
+        }\r
+        List<FvImagesDocument.FvImages.FvImage> l = getfpdFlash().getFvImages().getFvImageList();\r
+        ListIterator li = l.listIterator();\r
+        while(li.hasNext()) {\r
+            FvImagesDocument.FvImages.FvImage fi = (FvImagesDocument.FvImages.FvImage)li.next();\r
+            if (!fi.getType().toString().equals(type) && !type.equals("ALL")) {\r
+                continue;\r
+            }\r
+            if (fi.getFvImageNamesList().contains(fvName)) {\r
+                vFvImage.add(fi);\r
+            }\r
+        }\r
+        \r
+        return vFvImage;\r
+    }\r
+    /**\r
      * @param saa\r
+     * @param type "ALL" means all FvImage types: ImageName, Options, Attributes, Components.\r
      */\r
-    public void getFvImagesFvImages(String[][] saa) {\r
+    public void getFvImagesFvImages(String[][] saa, String type) {\r
     \r
         if (getfpdFlash().getFvImages() == null) {\r
             return;\r
@@ -1398,6 +2828,9 @@ public class FpdFileContents {
         int i = 0;\r
         while(li.hasNext()) {\r
             FvImagesDocument.FvImages.FvImage fi = (FvImagesDocument.FvImages.FvImage)li.next();\r
+            if (!fi.getType().toString().equals(type) && !type.equals("ALL")) {\r
+                continue;\r
+            }\r
             //\r
             // get FvImageNames array, space separated\r
             //\r
@@ -1416,6 +2849,108 @@ public class FpdFileContents {
         }\r
     }\r
     \r
+    /**Add name-value pair to FvImage element with type.\r
+     * @param fvName FV name to add name-value pair.\r
+     * @param type FvImage attribute.\r
+     * @param name\r
+     * @param value\r
+     */\r
+    public void setTypedNamedFvImageNameValue (String fvName, String type, String name, String value) {\r
+        if (getfpdFlash().getFvImages() == null) {\r
+            return;\r
+        }\r
+        List<FvImagesDocument.FvImages.FvImage> l = getfpdFlash().getFvImages().getFvImageList();\r
+        if (l == null) {\r
+            return;\r
+        }\r
+        ListIterator li = l.listIterator();\r
+        while(li.hasNext()) {\r
+            FvImagesDocument.FvImages.FvImage fi = (FvImagesDocument.FvImages.FvImage)li.next();\r
+            if (!fi.getType().toString().equals(type) && !type.equals("ALL")) {\r
+                continue;\r
+            }\r
+            if (!fi.getFvImageNamesList().contains(fvName)) {\r
+                continue;\r
+            }\r
+            setFvImagesFvImageNameValue (fi, name, value, null);\r
+        }\r
+    }\r
+    \r
+    /**Add to all FvImage elements with type, the name-value pair.\r
+     * @param type\r
+     * @param name\r
+     * @param value\r
+     */\r
+    public void setTypedFvImageNameValue (String type, String name, String value) {\r
+        if (getfpdFlash().getFvImages() == null) {\r
+            return;\r
+        }\r
+        List<FvImagesDocument.FvImages.FvImage> l = getfpdFlash().getFvImages().getFvImageList();\r
+        if (l == null) {\r
+            return;\r
+        }\r
+        ListIterator li = l.listIterator();\r
+        while(li.hasNext()) {\r
+            FvImagesDocument.FvImages.FvImage fi = (FvImagesDocument.FvImages.FvImage)li.next();\r
+            if (!fi.getType().toString().equals(type) && !type.equals("ALL")) {\r
+                continue;\r
+            }\r
+            setFvImagesFvImageNameValue (fi, name, value, null);\r
+        }\r
+    }\r
+    \r
+    /**Add to FvImage the name-value pair, or replace old name with newName, or generate new name-value pair if not exists before.\r
+     * @param fi\r
+     * @param name\r
+     * @param value\r
+     * @param newName\r
+     */\r
+    public void setFvImagesFvImageNameValue (FvImagesDocument.FvImages.FvImage fi, String name, String value, String newName) {\r
+        if (fi.getFvImageOptions() == null || fi.getFvImageOptions().getNameValueList() == null) {\r
+            return;\r
+        }\r
+        \r
+        XmlCursor cursor = fi.getFvImageOptions().newCursor();\r
+        if (cursor.toFirstChild()) {\r
+            do {\r
+                FvImagesDocument.FvImages.FvImage.FvImageOptions.NameValue nv = (FvImagesDocument.FvImages.FvImage.FvImageOptions.NameValue)cursor.getObject();\r
+                if (nv.getName().equals(name)) {\r
+                    nv.setValue(value);\r
+                    if (newName != null) {\r
+                        nv.setName(newName);\r
+                    }\r
+                    cursor.dispose();\r
+                    return;\r
+                }\r
+            }while (cursor.toNextSibling());\r
+        }\r
+        \r
+        FvImagesDocument.FvImages.FvImage.FvImageOptions.NameValue nv = fi.getFvImageOptions().addNewNameValue();\r
+        nv.setName(name);\r
+        nv.setValue(value);\r
+        if (newName != null) {\r
+            nv.setName(newName);\r
+        }\r
+        cursor.dispose();\r
+    }\r
+    \r
+    public void getFvImagesFvImageOptions (String fvName, Map<String, String> m) {\r
+        Vector<FvImagesDocument.FvImages.FvImage> vFvImage = getFvImagesFvImageWithName (fvName, "Options");\r
+        for (int i = 0; i < vFvImage.size(); ++i) {\r
+            FvImagesDocument.FvImages.FvImage fi = vFvImage.get(i);\r
+            if (fi == null || fi.getFvImageOptions() == null || fi.getFvImageOptions().getNameValueList() == null) {\r
+                continue;\r
+            }\r
+\r
+            ListIterator<FvImagesDocument.FvImages.FvImage.FvImageOptions.NameValue> li = fi.getFvImageOptions()\r
+                                                                                            .getNameValueList()\r
+                                                                                            .listIterator();\r
+            while (li.hasNext()) {\r
+                FvImagesDocument.FvImages.FvImage.FvImageOptions.NameValue nv = li.next();\r
+                m.put(nv.getName(), nv.getValue());\r
+            }\r
+        }\r
+    }\r
     /**Get FvImage Options for FvImage i\r
      * @param i the ith FvImage\r
      */\r
@@ -1450,30 +2985,10 @@ public class FpdFileContents {
         if (fpdHdr == null) {\r
             fpdHdr = fpdRoot.addNewPlatformHeader();\r
         }\r
-        genPlatformDefsSkuInfo("0", "DEFAULT");\r
+        \r
         return fpdHdr;\r
     }\r
     \r
-    public void genPlatformDefsSkuInfo(String id, String name) {\r
-        SkuInfoDocument.SkuInfo skuInfo = null;\r
-        if (getfpdPlatformDefs().getSkuInfo() == null) {\r
-            skuInfo = getfpdPlatformDefs().addNewSkuInfo();\r
-        }\r
-        skuInfo = getfpdPlatformDefs().getSkuInfo();\r
-        if (skuInfo.getUiSkuNameList() == null || skuInfo.getUiSkuNameList().size() == 0) {\r
-            SkuInfoDocument.SkuInfo.UiSkuName skuName = skuInfo.addNewUiSkuName();\r
-            skuName.setSkuID(new BigInteger("0"));\r
-            skuName.setStringValue("DEFAULT");\r
-        }\r
-        if (id.equals("0")) {\r
-            return;\r
-        }\r
-        SkuInfoDocument.SkuInfo.UiSkuName skuName = skuInfo.addNewUiSkuName();\r
-        skuName.setSkuID(new BigInteger(id));\r
-        skuName.setStringValue(name);\r
-            \r
-        \r
-    }\r
     public String getFpdHdrPlatformName() {\r
         return getFpdHdr().getPlatformName();\r
     }\r
@@ -1516,7 +3031,7 @@ public class FpdFileContents {
     \r
     public String getFpdHdrSpec() {\r
 \r
-        return "FRAMEWORK_BUILD_PACKAGING_SPECIFICATION 0x00000052";\r
+        return "FRAMEWORK_BUILD_PACKAGING_SPECIFICATION   0x00000052";\r
 //        return getFpdHdr().getSpecification();\r
     }\r
     \r
@@ -1562,7 +3077,7 @@ public class FpdFileContents {
     }\r
     \r
     public void setFpdHdrSpec(String s){\r
-        s = "FRAMEWORK_BUILD_PACKAGING_SPECIFICATION 0x00000052";\r
+        s = "FRAMEWORK_BUILD_PACKAGING_SPECIFICATION   0x00000052";\r
         getFpdHdr().setSpecification(s);\r
     }\r
     /**\r
@@ -1586,7 +3101,7 @@ public class FpdFileContents {
 \r
     }\r
     \r
-    private String listToString(List<String> l) {\r
+    private String listToString(List l) {\r
         if (l == null) {\r
             return null;\r
         }\r
@@ -1598,4 +3113,62 @@ public class FpdFileContents {
         }\r
         return s.trim();\r
     }\r
+    \r
+    private void removeElement(XmlObject o) {\r
+        XmlCursor cursor = o.newCursor();\r
+        cursor.removeXml();\r
+        cursor.dispose();\r
+    }\r
+}\r
+\r
+class PcdItemTypeConflictException extends Exception {\r
+\r
+    /**\r
+     * \r
+     */\r
+    private static final long serialVersionUID = 1L;\r
+    private String details = null;\r
+    \r
+    PcdItemTypeConflictException(String pcdName, String info){\r
+        ModuleIdentification mi = WorkspaceProfile.getModuleId(info);\r
+        details = pcdName + " ItemType Conflicts with " + mi.getName() + " in Pkg " + mi.getPackageId().getName();\r
+    }\r
+    \r
+    public String getMessage() {\r
+        return details;\r
+    }\r
+}\r
+\r
+class PcdDeclNotFound extends Exception {\r
+\r
+    /**\r
+     * \r
+     */\r
+    private static final long serialVersionUID = 1L;\r
+    private String details = null;\r
+    \r
+    PcdDeclNotFound(String info) {\r
+        details = "PcdDeclNotFound: " + info;\r
+    }\r
+    \r
+    public String getMessage() {\r
+        return details;\r
+    }\r
+}\r
+\r
+class PcdValueMalFormed extends Exception {\r
+\r
+    /**\r
+     * \r
+     */\r
+    private static final long serialVersionUID = 1L;\r
+    private String details = null;\r
+    \r
+    PcdValueMalFormed(String info) {\r
+        details = "PcdValueMalFormed: " + info;\r
+    }\r
+    \r
+    public String getMessage() {\r
+        return details;\r
+    }\r
 }\r