]> git.proxmox.com Git - mirror_edk2.git/blobdiff - Tools/Source/FrameworkWizard/src/org/tianocore/frameworkwizard/platform/ui/FpdFileContents.java
1.change GlobalData to WorkspaceProfile.
[mirror_edk2.git] / Tools / Source / FrameworkWizard / src / org / tianocore / frameworkwizard / platform / ui / FpdFileContents.java
index 2b1cffe8909f5299e4999bf2040d3208940666f2..a11a63598e606fe55739cf96a4f496afa7d74248 100644 (file)
@@ -57,7 +57,8 @@ 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
@@ -88,6 +89,8 @@ public class FpdFileContents {
     \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
      */\r
@@ -329,19 +332,19 @@ public class FpdFileContents {
         int libCount = getLibraryInstancesCount(moduleKey);\r
         String[][] saaLib = new String[libCount][5];\r
         getLibraryInstances(moduleKey, saaLib);\r
-        ModuleIdentification mi = GlobalData.getModuleId(moduleKey);\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 (GlobalData.pcdInMsa(saaModuleSaPcd[i][0], saaModuleSaPcd[i][1], mi)){\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 = GlobalData.getModuleId(libKey);\r
+                    ModuleIdentification libMi = WorkspaceProfile.getModuleId(libKey);\r
                     vMi.add(libMi);\r
-                    if (GlobalData.pcdInMsa(saaModuleSaPcd[i][0], saaModuleSaPcd[i][1], libMi)) {\r
+                    if (WorkspaceProfile.pcdInMsa(saaModuleSaPcd[i][0], saaModuleSaPcd[i][1], libMi)) {\r
                         continue nextPcd;\r
                     }\r
                 }\r
@@ -358,7 +361,7 @@ public class FpdFileContents {
         try {\r
        \r
             for (int i = 0; i < vMi.size(); ++i) {\r
-                ModuleSurfaceAreaDocument.ModuleSurfaceArea msa = (ModuleSurfaceAreaDocument.ModuleSurfaceArea) GlobalData\r
+                ModuleSurfaceAreaDocument.ModuleSurfaceArea msa = (ModuleSurfaceAreaDocument.ModuleSurfaceArea) WorkspaceProfile\r
                                                                                                                           .getModuleXmlObject(vMi\r
                                                                                                                                                  .get(i));\r
                 if (msa.getPcdCoded() == null || msa.getPcdCoded().getPcdEntryList() == null) {\r
@@ -428,6 +431,7 @@ public class FpdFileContents {
         }\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
@@ -516,6 +520,7 @@ public class FpdFileContents {
                         pcdData.setMaxDatumSize(new Integer(maxSize));\r
                     }\r
                     pcdData.setValue(value);\r
+                    defaultPcdValue.put(cName + " " + tsGuid, value);\r
                     break;\r
                 }\r
             }\r
@@ -533,7 +538,7 @@ public class FpdFileContents {
     public boolean getPcdBuildDataInfo(ModuleIdentification mi, String cName, String tsGuid, String[] sa) throws Exception{\r
         try {\r
            \r
-            ModuleSurfaceAreaDocument.ModuleSurfaceArea msa = (ModuleSurfaceAreaDocument.ModuleSurfaceArea)GlobalData.getModuleXmlObject(mi);\r
+            ModuleSurfaceAreaDocument.ModuleSurfaceArea msa = (ModuleSurfaceAreaDocument.ModuleSurfaceArea)WorkspaceProfile.getModuleXmlObject(mi);\r
             if (msa.getPcdCoded() == null) {\r
                 return false;\r
             }\r
@@ -586,7 +591,7 @@ public class FpdFileContents {
      */\r
     public void removePcdData(String moduleKey, ModuleIdentification consumer) {\r
         try {\r
-            ModuleSurfaceAreaDocument.ModuleSurfaceArea msa = (ModuleSurfaceAreaDocument.ModuleSurfaceArea)GlobalData.getModuleXmlObject(consumer);\r
+            ModuleSurfaceAreaDocument.ModuleSurfaceArea msa = (ModuleSurfaceAreaDocument.ModuleSurfaceArea)WorkspaceProfile.getModuleXmlObject(consumer);\r
             if (msa.getPcdCoded() == null) {\r
                 return;\r
             }\r
@@ -704,7 +709,7 @@ public class FpdFileContents {
         XmlCursor cursor = instance.newCursor();\r
         try{\r
             String comment = "Pkg: " + pn + " Mod: " + mn \r
-                + " Path: " + GlobalData.getMsaFile(libMi).getPath().substring(System.getenv("WORKSPACE").length() + 1);\r
+                + " Path: " + WorkspaceProfile.getMsaFile(libMi).getPath().substring(System.getenv("WORKSPACE").length() + 1);\r
             cursor.insertComment(comment);\r
         }\r
         catch (Exception e){\r
@@ -888,7 +893,7 @@ public class FpdFileContents {
                 moduleSa = genModuleSA(mi, arch);\r
             }\r
             \r
-            ModuleSurfaceAreaDocument.ModuleSurfaceArea msa = (ModuleSurfaceAreaDocument.ModuleSurfaceArea)GlobalData.getModuleXmlObject(mi);\r
+            ModuleSurfaceAreaDocument.ModuleSurfaceArea msa = (ModuleSurfaceAreaDocument.ModuleSurfaceArea)WorkspaceProfile.getModuleXmlObject(mi);\r
             if (msa.getPcdCoded() == null) {\r
                 return;\r
             }\r
@@ -932,7 +937,7 @@ public class FpdFileContents {
         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
+            m.put("PackageSurfaceArea", WorkspaceProfile.getPackageXmlObject(depPkgs[i]));\r
             SurfaceAreaQuery.setDoc(m);\r
             XmlObject[] xo = SurfaceAreaQuery.getSpdPcdDeclarations();\r
             if (xo == null) {\r
@@ -958,12 +963,12 @@ public class FpdFileContents {
     }\r
     \r
     private ModuleSADocument.ModuleSA genModuleSA (ModuleIdentification mi, String arch) {\r
-        PackageIdentification pi = GlobalData.getPackageForModule(mi);\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: " + mi.getModuleType() + " Path: "\r
-                            + GlobalData.getMsaFile(mi).getPath().substring(System.getenv("WORKSPACE").length() + 1);\r
+                            + WorkspaceProfile.getMsaFile(mi).getPath().substring(System.getenv("WORKSPACE").length() + 1);\r
             cursor.insertComment(comment);\r
         }\r
         catch(Exception e){\r
@@ -998,41 +1003,19 @@ 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() + " " + 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
-        /* Comment out Item type checking temporarily.\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[5].equals("DYNAMIC")) {\r
-                    //ToDo error for same pcd, other type than dynamic\r
-                    pcdConsumer.remove(listValue);\r
-                    throw new PcdItemTypeConflictException(cName, value);\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[5].equals("DYNAMIC")) {\r
-                    //ToDo error for same pcd, other type than non-dynamic\r
-                    pcdConsumer.remove(listValue);\r
-                    throw new PcdItemTypeConflictException(cName, value);\r
-                }\r
-            }\r
-        }\r
-        */\r
+        \r
         PcdBuildDefinitionDocument.PcdBuildDefinition.PcdData fpdPcd = moduleSa.getPcdBuildDefinition().addNewPcdData();\r
         fpdPcd.setCName(cName);\r
         fpdPcd.setToken(token);\r
@@ -1054,6 +1037,16 @@ public class FpdFileContents {
                 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
@@ -1085,44 +1078,7 @@ public class FpdFileContents {
                 addDynamicPcdBuildData(cName, token, tsGuid, itemType, dataType, defaultVal);\r
             }\r
         }\r
-        else {\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
-            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
     \r
     public int setMaxSizeForPointer(String datum) throws PcdValueMalFormed{\r
@@ -1529,6 +1485,92 @@ public class FpdFileContents {
         return fpdBuildOpts;\r
     }\r
     \r
+    public void genBuildOptionsUserExtensions(String fvName, String infName, String outputFileName, String[][] includeModules) {\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("FvName");\r
+        cursor.insertChars(fvName);\r
+        cursor.toNextToken();\r
+        \r
+        cursor.beginElement("InfFileName");\r
+        cursor.insertChars(infName);\r
+        cursor.toNextToken();\r
+        \r
+        cursor.beginElement("IncludeModules");\r
+        for (int i = 0; i < includeModules.length; ++i) {\r
+            cursor.beginElement("Module");\r
+            cursor.insertAttributeWithValue("ModuleGuid", includeModules[i][0]);\r
+            cursor.insertAttributeWithValue("BaseName", includeModules[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
+        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(new QName("", "IncludeModules"));\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
+        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.toNextSibling(new QName("", "IncludeModules"));\r
+                if (cursor.toFirstChild()) {\r
+                    int i = 0;\r
+                    do {\r
+                        saa[i][0] = cursor.getAttributeText(new QName("ModuleGuid"));\r
+                        saa[i][1] = cursor.getAttributeText(new QName("BaseName"));\r
+                        ++i;\r
+                    }while (cursor.toNextSibling());\r
+                }\r
+                cursor.dispose();\r
+                return;\r
+            }\r
+            cursor.dispose();\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
@@ -2637,7 +2679,7 @@ class PcdItemTypeConflictException extends Exception {
     private String details = null;\r
     \r
     PcdItemTypeConflictException(String pcdName, String info){\r
-        ModuleIdentification mi = GlobalData.getModuleId(info);\r
+        ModuleIdentification mi = WorkspaceProfile.getModuleId(info);\r
         details = pcdName + " ItemType Conflicts with " + mi.getName() + " in Pkg " + mi.getPackage().getName();\r
     }\r
     \r