]> git.proxmox.com Git - mirror_edk2.git/blobdiff - Tools/Source/MigrationTools/org/tianocore/migration/ModuleReader.java
Add EntryPointLib class once ImageEntryPoint is found in inf file.
[mirror_edk2.git] / Tools / Source / MigrationTools / org / tianocore / migration / ModuleReader.java
index e67b0d167bc33d23c54aa11a0bcc8cd205c7b071..41c27a680f4cc6dc494d085a02ad374ec7c39983 100644 (file)
@@ -18,18 +18,19 @@ import java.util.regex.*;
 \r
 import org.tianocore.*;\r
 \r
-public final class ModuleReader {\r
-    private static ModuleInfo mi;\r
+public final class ModuleReader implements Common.ForDoAll {\r
+       private static final ModuleReader modulereader = new ModuleReader();\r
+    private ModuleInfo mi;\r
+    private final CommentLaplace commentlaplace = new CommentLaplace();\r
     \r
     private static final Pattern ptninfequation = Pattern.compile("([^\\s]*)\\s*=\\s*([^\\s]*)");\r
     private static final Pattern ptnsection = Pattern.compile("\\[([^\\[\\]]*)\\]([^\\[\\]]*)\\n", Pattern.MULTILINE);\r
     private static final Pattern ptnfilename = Pattern.compile("[^\\s]+");\r
     \r
-    public static final void ModuleScan(ModuleInfo m) throws Exception {\r
-        mi = m;\r
-\r
+    public final void ModuleScan() throws Exception {\r
         Common.toDoAll(mi.modulepath, ModuleInfo.class.getMethod("enroll", String.class), mi, null, Common.FILE);\r
 \r
+        // inf&msa\r
         String filename = null;\r
         if (mi.msaorinf.isEmpty()) {\r
             MigrationTool.ui.println("No INF nor MSA file found!");\r
@@ -47,13 +48,12 @@ public final class ModuleReader {
         } else if (filename.contains(".msa")) {\r
             readMsa(filename);\r
         }\r
+        // inf&msa\r
 \r
-        CommentOutNonLocalHFile();\r
-        parsePreProcessedSourceCode();\r
-\r
+        preProcessModule();\r
     }\r
     \r
-    private static final void readMsa(String name) throws Exception {\r
+    private final void readMsa(String name) throws Exception {\r
         ModuleSurfaceAreaDocument msadoc = ModuleSurfaceAreaDocument.Factory.parse(new File(mi.modulepath + File.separator + name));\r
         ModuleSurfaceAreaDocument.ModuleSurfaceArea msa = msadoc.getModuleSurfaceArea();\r
         MsaHeaderDocument.MsaHeader msaheader = msa.getMsaHeader();\r
@@ -73,7 +73,7 @@ public final class ModuleReader {
         }\r
     }\r
     \r
-    private static final void readInf(String name) throws Exception {\r
+    private final void readInf(String name) throws Exception {\r
         System.out.println("\nParsing INF file: " + name);\r
         String wholeline;\r
         Matcher mtrinfequation;\r
@@ -97,11 +97,12 @@ public final class ModuleReader {
                     }\r
                 }\r
             }\r
-            if (mtrsection.group(1).matches("nmake.common")) {\r
+            if (mtrsection.group(1).contains("nmake.")) {\r
                 mtrinfequation = ptninfequation.matcher(mtrsection.group(2));\r
                 while (mtrinfequation.find()) {\r
                     if (mtrinfequation.group(1).matches("IMAGE_ENTRY_POINT")) {\r
                         mi.entrypoint = mtrinfequation.group(2);\r
+                        mi.hashrequiredr9libs.add("EntryPointLib");\r
                     }\r
                     if (mtrinfequation.group(1).matches("DPX_SOURCE")) {\r
                         if (!mi.localmodulesources.contains(mtrinfequation.group(2))) {\r
@@ -113,57 +114,63 @@ public final class ModuleReader {
             if (mtrsection.group(1).contains("sources.")) {\r
                 mtrfilename = ptnfilename.matcher(mtrsection.group(2));\r
                 while (mtrfilename.find()) {\r
+                       mi.infsources.add(mtrfilename.group());\r
                     if (!mi.localmodulesources.contains(mtrfilename.group())) {\r
-                        MigrationTool.ui.println("Source File Missing! : " + mtrfilename.group());\r
+                        MigrationTool.ui.println("Warn: Source File Missing! : " + mtrfilename.group());\r
                     }\r
                 }\r
             }\r
+            if (mtrsection.group(1).matches("includes.")) {\r
+                mtrfilename = ptnfilename.matcher(mtrsection.group(2));\r
+                while (mtrfilename.find()) {\r
+                       mi.infincludes.add(mtrfilename.group());\r
+                }\r
+            }\r
         }\r
     }\r
     \r
-    // add '//' to all non-local include lines\r
-    private static final void CommentOutNonLocalHFile() throws IOException {\r
-        BufferedReader rd;\r
-        String line;\r
-        String curFile;\r
-        PrintWriter outfile;\r
+    private final void preProcessModule() throws Exception {\r
+       // according to .inf file, add extraordinary includes and sourcefiles\r
+        Common.dirCopy(mi.modulepath, mi.modulepath + File.separator + "temp");        // collect all Laplace.namechange to here???\r
+        \r
+       if (!mi.infincludes.isEmpty()) {\r
+            Iterator<String> it = mi.infincludes.iterator();\r
+            String tempincludename = null;\r
+               while (it.hasNext()) {\r
+                       tempincludename = it.next();\r
+                       if (tempincludename.contains("..")) {\r
+                               Matcher mtr = Common.PTNSEPARATER.matcher(tempincludename);\r
+                               if (mtr.find() && !mtr.group(2).matches(".")) {\r
+                                       Common.oneLevelDirCopy(mi.modulepath.replaceAll(Common.STRSEPARATER, "$1") + File.separator + mtr.group(2), mi.modulepath + File.separator + "temp", ".h");\r
+                               } else {\r
+                                       Common.oneLevelDirCopy(mi.modulepath.replaceAll(Common.STRSEPARATER, "$1"), mi.modulepath + File.separator + "temp", ".h");\r
+                               }\r
+                       }\r
+               }\r
+       }\r
+       if (!mi.infsources.isEmpty()) {\r
+            Iterator<String> it = mi.infsources.iterator();\r
+            String tempsourcename = null;\r
+            while (it.hasNext()) {\r
+               tempsourcename = it.next();\r
+               if (tempsourcename.contains("..")) {\r
+                       Common.ensureDir(mi.modulepath + File.separator + "temp" + File.separator + "MT_Parent_Sources");\r
+                               Matcher mtr = Common.PTNSEPARATER.matcher(tempsourcename);\r
+                               if (mtr.find()) {\r
+                                       Common.fileCopy(mi.modulepath.replaceAll(Common.STRSEPARATER, "$1") + File.separator + mtr.group(2), mi.modulepath + File.separator + "temp" + File.separator + "MT_Parent_Sources" + File.separator + mtr.group(2));\r
+                               }\r
+               }\r
+            }\r
+       }\r
 \r
-        Pattern ptninclude = Pattern.compile("[\"<](.*[.]h)[\">]");\r
-        Matcher mtrinclude;\r
+        //CommentOutNonLocalHFile();\r
+        Common.toDoAll(mi.modulepath + File.separator + "temp", this, Common.FILE);\r
+        \r
+        parsePreProcessedSourceCode();\r
 \r
-        Iterator<String> ii = mi.localmodulesources.iterator();\r
-        while ( ii.hasNext() ) {\r
-            curFile = ii.next();\r
-            rd = new BufferedReader(new FileReader(mi.modulepath + File.separator + curFile));\r
-            Common.ensureDir(mi.modulepath + File.separator + "temp" + File.separator + curFile);\r
-            outfile = new PrintWriter(new BufferedWriter(new FileWriter(mi.modulepath + File.separator + "temp" + File.separator + curFile)));\r
-            \r
-            /*\r
-            if (curFile.contains(".dxs")) {\r
-                if (mi.moduletype.contains("PEI")) {\r
-                    \r
-                } else {\r
-                    \r
-                }\r
-            }\r
-            */\r
-            while ((line = rd.readLine()) != null) {\r
-                if (line.contains("#include")) {\r
-                    mtrinclude = ptninclude.matcher(line);\r
-                    if (mtrinclude.find() && mi.localmodulesources.contains(mtrinclude.group(1))) {\r
-                    } else {\r
-                        line = MigrationTool.MIGRATIONCOMMENT + line;\r
-                    }\r
-                }\r
-                outfile.append(line + '\n');\r
-            }\r
-            outfile.flush();\r
-            outfile.close();\r
-            \r
-        }\r
     }\r
 \r
-    private static final void parsePreProcessedSourceCode() throws Exception {\r
+    private final void parsePreProcessedSourceCode() throws Exception {\r
         //Cl cl = new Cl(modulepath);\r
         //cl.execute("Fat.c");\r
         //cl.generateAll(preprocessedccodes);\r
@@ -272,4 +279,54 @@ public final class ModuleReader {
             }\r
         }\r
     }\r
+    \r
+    public class CommentLaplace extends Common.Laplace {\r
+        public String operation(String wholeline) {\r
+               StringBuffer wholebuffer = new StringBuffer();\r
+               String templine = null;\r
+            Pattern ptnincludefile = Pattern.compile("[\"<](.*[.]h)[\">]");\r
+            Pattern ptninclude = Pattern.compile("#include\\s*(.*)");\r
+            Matcher mtrinclude = ptninclude.matcher(wholeline);\r
+            Matcher mtrincludefile = null;\r
+            while (mtrinclude.find()) {\r
+               mtrincludefile = ptnincludefile.matcher(mtrinclude.group(1));\r
+               if (mtrincludefile.find() && mi.localmodulesources.contains(mtrincludefile.group(1))) {\r
+                       templine = mtrinclude.group();\r
+               } else {\r
+                       templine = MigrationTool.MIGRATIONCOMMENT + mtrinclude.group();\r
+               }\r
+               mtrinclude.appendReplacement(wholebuffer, templine);\r
+            }\r
+            mtrinclude.appendTail(wholebuffer);\r
+            return wholebuffer.toString();\r
+        }\r
+        \r
+        public boolean recognize(String filename) {\r
+               return filename.contains(".c") || filename.contains(".h");\r
+        }\r
+        \r
+        public String namechange(String oldname) {\r
+               return oldname;\r
+        }\r
+    }\r
+\r
+    //-----------------------------------ForDoAll-----------------------------------//\r
+    public void run(String filepath) throws Exception {\r
+       String name = mi.modulepath + File.separator + "temp" + File.separator + filepath.replace(mi.modulepath + File.separator + "temp" + File.separator, "");\r
+       commentlaplace.transform(name, name);\r
+    }\r
+\r
+    public boolean filter(File dir) {\r
+        return true;\r
+    }\r
+    //-----------------------------------ForDoAll-----------------------------------//\r
+    \r
+    public final void setModuleInfo(ModuleInfo m) {\r
+       mi = m;\r
+    }\r
+    \r
+    public static final void aimAt(ModuleInfo mi) throws Exception {\r
+       modulereader.setModuleInfo(mi);\r
+       modulereader.ModuleScan();\r
+    }\r
 }\r