]> git.proxmox.com Git - mirror_edk2.git/blobdiff - Tools/Source/MigrationTools/org/tianocore/migration/MsaWriter.java
remodel 1
[mirror_edk2.git] / Tools / Source / MigrationTools / org / tianocore / migration / MsaWriter.java
index 25d959f67a2560a8b88a2d21fc4f94faf4b4f987..f79843337c4a32fab4822708a3ec3ac584d962b7 100644 (file)
@@ -20,15 +20,15 @@ import org.tianocore.SupportedArchitectures.Enum;
 import org.apache.xmlbeans.*;\r
 \r
 public class MsaWriter {\r
-       MsaWriter(String path, ModuleInfo moduleinfo, Database database) {\r
+       MsaWriter(String path, String outpath, ModuleInfo moduleinfo) {\r
                modulepath = path;\r
+               outputpath = outpath;\r
                mi = moduleinfo;\r
-               db = database;\r
        }\r
 \r
        private String modulepath;\r
+       private String outputpath;\r
        private ModuleInfo mi;\r
-       private Database db;\r
        \r
        private ModuleSurfaceAreaDocument msadoc = ModuleSurfaceAreaDocument.Factory.newInstance();\r
        \r
@@ -36,9 +36,9 @@ public class MsaWriter {
        private MsaHeaderDocument.MsaHeader msaheader = msa.addNewMsaHeader();\r
        private ModuleDefinitionsDocument.ModuleDefinitions md = msa.addNewModuleDefinitions();\r
        private SourceFilesDocument.SourceFiles sourcefiles = msa.addNewSourceFiles();  //found local .h files are not written\r
-       private GuidsDocument.Guids guids = msa.addNewGuids();\r
-       private ProtocolsDocument.Protocols protocols = msa.addNewProtocols();\r
-       private PPIsDocument.PPIs ppis = msa.addNewPPIs();\r
+       private GuidsDocument.Guids guids;\r
+       private ProtocolsDocument.Protocols protocols;\r
+       private PPIsDocument.PPIs ppis;\r
        private PackageDependenciesDocument.PackageDependencies pd = msa.addNewPackageDependencies();\r
        private LibraryClassDefinitionsDocument.LibraryClassDefinitions libclassdefs = msa.addNewLibraryClassDefinitions();\r
        private ExternsDocument.Externs externs = msa.addNewExterns();\r
@@ -51,6 +51,31 @@ public class MsaWriter {
                return answer;\r
        }\r
        \r
+       private void addSourceFiles (String name) {                                             // furthur modification needed\r
+               List<Enum> arch = new ArrayList<Enum>();\r
+               FilenameDocument.Filename filename;\r
+               filename = sourcefiles.addNewFilename();\r
+               filename.setStringValue(name);\r
+               \r
+               if (name.contains("x64" + File.separator)) {                            // filename ???\r
+                       arch.add(SupportedArchitectures.X_64);\r
+                       System.out.println("x64" + File.separator);\r
+                       filename.setSupArchList(arch);\r
+               } else if (name.contains("Ia32" + File.separator)) {            // filename ???\r
+                       arch.add(SupportedArchitectures.IA_32);\r
+                       System.out.println("Ia32" + File.separator);\r
+                       filename.setSupArchList(arch);\r
+               } else if (name.contains("Ipf" + File.separator)) {                     // filename ???\r
+                       arch.add(SupportedArchitectures.IPF);\r
+                       System.out.println("Ipf" + File.separator);\r
+                       filename.setSupArchList(arch);\r
+               } else if (name.contains("Ebc" + File.separator)) {                     // filename ???\r
+                       arch.add(SupportedArchitectures.EBC);\r
+                       System.out.println("Ebc" + File.separator);\r
+                       filename.setSupArchList(arch);\r
+               }\r
+       }\r
+       \r
        private ModuleSurfaceAreaDocument fulfillMsadoc() throws Exception {\r
                Iterator<String> it;\r
                String temp;\r
@@ -58,12 +83,12 @@ public class MsaWriter {
                if (mi.modulename != null) {\r
                        msaheader.setModuleName(mi.modulename);\r
                } else {\r
-                       msaheader.setModuleName(mi.modulename = Query("ModuleName Not Found . Please Input ModuleName"));\r
+                       msaheader.setModuleName(mi.modulename = Query("Module Name Not Found!  Please Input ModuleName"));\r
                }\r
                if (mi.guidvalue != null) {\r
                        msaheader.setGuidValue(mi.guidvalue);\r
                } else {\r
-                       msaheader.setGuidValue(mi.guidvalue = Query("GuidValue Not Found . Please Input GuidValue"));\r
+                       msaheader.setGuidValue(mi.guidvalue = Query("Guid Value Not Found!  Please Input Guid Value"));\r
                }\r
                if (mi.moduletype != null) {\r
                        if (mi.moduletype.contains("PEI")) {\r
@@ -72,12 +97,13 @@ public class MsaWriter {
                                msaheader.setModuleType(ModuleTypeDef.Enum.forString("DXE_DRIVER"));\r
                        }\r
                } else {\r
-                       msaheader.setModuleType(ModuleTypeDef.Enum.forString(mi.moduletype = Query("GuidValue Not Found . Please Input GuidValue")));\r
+                       msaheader.setModuleType(ModuleTypeDef.Enum.forString(mi.moduletype = Query("Guid Value Not Found!  Please Input Guid Value")));\r
                }\r
+\r
                msaheader.setCopyright("Copyright (c) 2006, Intel Corporation");\r
                msaheader.setVersion("1.0");\r
                msaheader.setAbstract("Component name for module " + mi.modulename);\r
-               msaheader.setDescription("FIX ME!");                                                    //???\r
+               msaheader.setDescription("FIX ME!");\r
                msaheader.addNewLicense().setStringValue("All rights reserved.\n" +\r
                                "      This software and associated documentation (if any) is furnished\n" +\r
                                "      under a license and may only be used or copied in accordance\n" +\r
@@ -86,6 +112,7 @@ public class MsaWriter {
                                "      reproduced, stored in a retrieval system, or transmitted in any\n" +\r
                                "      form or by any means without the express written consent of\n" +\r
                                "      Intel Corporation.");\r
+               msaheader.setSpecification("FRAMEWORK_BUILD_PACKAGING_SPECIFICATION   0x00000052");\r
                \r
                List<Enum> arch = new ArrayList<Enum>();\r
                arch.add(SupportedArchitectures.IA_32);\r
@@ -103,30 +130,39 @@ public class MsaWriter {
                \r
                it = mi.localmodulesources.iterator();\r
                while (it.hasNext()) {\r
-                       sourcefiles.addNewFilename().setStringValue(it.next());\r
+                       addSourceFiles(it.next());\r
                }\r
-               it = mi.protocol.iterator();\r
-               while (it.hasNext()) {\r
-                       if ((temp = it.next()) != null) {\r
-                               ProtocolsDocument.Protocols.Protocol pr = protocols.addNewProtocol();\r
-                               pr.setProtocolCName(temp);\r
-                               pr.setUsage(UsageTypes.ALWAYS_CONSUMED);\r
+               if (!mi.protocol.isEmpty()) {\r
+                       protocols = msa.addNewProtocols();\r
+                       it = mi.protocol.iterator();\r
+                       while (it.hasNext()) {\r
+                               if ((temp = it.next()) != null) {\r
+                                       ProtocolsDocument.Protocols.Protocol pr = protocols.addNewProtocol();\r
+                                       pr.setProtocolCName(temp);\r
+                                       pr.setUsage(UsageTypes.ALWAYS_CONSUMED);\r
+                               }\r
                        }\r
                }\r
-               it = mi.ppi.iterator();\r
-               while (it.hasNext()) {\r
-                       if ((temp = it.next()) != null) {\r
-                               PPIsDocument.PPIs.Ppi pp = ppis.addNewPpi();\r
-                               pp.setPpiCName(temp);\r
-                               pp.setUsage(UsageTypes.ALWAYS_CONSUMED);\r
+               if (!mi.ppi.isEmpty()) {\r
+                       ppis = msa.addNewPPIs();\r
+                       it = mi.ppi.iterator();\r
+                       while (it.hasNext()) {\r
+                               if ((temp = it.next()) != null) {\r
+                                       PPIsDocument.PPIs.Ppi pp = ppis.addNewPpi();\r
+                                       pp.setPpiCName(temp);\r
+                                       pp.setUsage(UsageTypes.ALWAYS_CONSUMED);\r
+                               }\r
                        }\r
                }\r
-               it = mi.guid.iterator();\r
-               while (it.hasNext()) {\r
-                       if ((temp = it.next()) != null) {\r
-                               GuidsDocument.Guids.GuidCNames gcn = guids.addNewGuidCNames();\r
-                               gcn.setGuidCName(temp);\r
-                               gcn.setUsage(UsageTypes.ALWAYS_CONSUMED);\r
+               if (!mi.guid.isEmpty()) {\r
+                       guids = msa.addNewGuids();\r
+                       it = mi.guid.iterator();\r
+                       while (it.hasNext()) {\r
+                               if ((temp = it.next()) != null) {\r
+                                       GuidsDocument.Guids.GuidCNames gcn = guids.addNewGuidCNames();\r
+                                       gcn.setGuidCName(temp);\r
+                                       gcn.setUsage(UsageTypes.ALWAYS_CONSUMED);\r
+                               }\r
                        }\r
                }\r
                it = mi.hashrequiredr9libs.iterator();\r
@@ -149,8 +185,9 @@ public class MsaWriter {
         options.setSavePrettyPrintIndent(2);\r
         options.setUseDefaultNamespace();\r
         \r
-               BufferedWriter bw = new BufferedWriter(new FileWriter(modulepath + File.separator + "result" + File.separator + mi.modulename + ".msa"));\r
+               BufferedWriter bw = new BufferedWriter(new FileWriter(outputpath + File.separator + "Migration_" + mi.modulename + File.separator + mi.modulename + ".msa"));\r
                fulfillMsadoc().save(bw, options);\r
+               //MsaTreeEditor.init(mi, ui, msadoc);\r
                bw.flush();\r
                bw.close();\r
        }\r