]> git.proxmox.com Git - mirror_edk2.git/commitdiff
add .. support
authoralfred <alfred@6f19259b-4bc3-4df7-8a09-765794883524>
Thu, 14 Sep 2006 08:09:54 +0000 (08:09 +0000)
committeralfred <alfred@6f19259b-4bc3-4df7-8a09-765794883524>
Thu, 14 Sep 2006 08:09:54 +0000 (08:09 +0000)
git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@1534 6f19259b-4bc3-4df7-8a09-765794883524

Tools/Source/MigrationTools/org/tianocore/migration/Common.java
Tools/Source/MigrationTools/org/tianocore/migration/FirstPanel.java
Tools/Source/MigrationTools/org/tianocore/migration/MigrationTool.java
Tools/Source/MigrationTools/org/tianocore/migration/ModuleInfo.java
Tools/Source/MigrationTools/org/tianocore/migration/ModuleReader.java
Tools/Source/MigrationTools/org/tianocore/migration/SourceFileReplacer.java

index 2f10521238c739f6df55cc155c9745a2a2560062..0ca7ca8cb3a16eebfb2203930bfb809e92d65749 100644 (file)
@@ -22,8 +22,8 @@ public final class Common {
     public static final int FILE = 1;\r
     public static final int DIR = 2;\r
     \r
-    public static final String strseparate = "(.*)\\\\([^\\\\]*)";\r
-    public static final Pattern ptnseparate = Pattern.compile("(.*)\\\\([^\\\\]*)");\r
+    public static final String STRSEPARATER = "(.*)\\\\([^\\\\]*)";\r
+    public static final Pattern PTNSEPARATER = Pattern.compile("(.*)\\\\([^\\\\]*)");\r
 \r
     //-------------------------------------regex------------------------------------------//\r
     \r
@@ -53,6 +53,7 @@ public final class Common {
         while ((line = rd.readLine()) != null) {\r
             wholefile.append(line + "\n");\r
         }\r
+        rd.close();\r
         return wholefile.toString();\r
     }\r
 \r
@@ -64,6 +65,10 @@ public final class Common {
         outfile.close();\r
     }\r
 \r
+    public static final void fileCopy(String src, String des) throws Exception {\r
+       string2file(file2string(src), des);\r
+    }\r
+    \r
     //-----------------------------------file&string---------------------------------------//\r
 \r
     //--------------------------------------dir--------------------------------------------//\r
@@ -76,7 +81,7 @@ public final class Common {
     */\r
     public static final void ensureDir(String objFileWhole) {\r
         File tempdir;\r
-        Matcher mtrseparate = ptnseparate.matcher(objFileWhole);\r
+        Matcher mtrseparate = PTNSEPARATER.matcher(objFileWhole);\r
         if (mtrseparate.find()) {\r
             tempdir = new File(mtrseparate.group(1));\r
             if (!tempdir.exists()) tempdir.mkdirs();\r
@@ -98,7 +103,7 @@ public final class Common {
     }\r
     \r
     public static final String dirCopy_(String src) throws Exception {\r
-        Matcher mtrseparate = Common.ptnseparate.matcher(src);\r
+        Matcher mtrseparate = Common.PTNSEPARATER.matcher(src);\r
         if (mtrseparate.find()) {\r
             dirCopy(src, mtrseparate.group(1) + File.separator + "_" + mtrseparate.group(2));\r
         }\r
@@ -109,16 +114,28 @@ public final class Common {
         String[] list = new File(src).list();\r
         File test;\r
 \r
+        ensureDir(des);\r
         for (int i = 0 ; i < list.length ; i++) {\r
             test = new File(src + File.separator + list[i]);\r
             if (test.isDirectory()) {\r
                 dirCopy(src + File.separator + list[i], des + File.separator + list[i]);\r
             } else {\r
-                ensureDir(des + File.separator + list[i]);\r
+                //ensureDir(des + File.separator + list[i]);\r
                 string2file(file2string(src + File.separator + list[i]), des + File.separator + list[i]);\r
             }\r
         }\r
     }\r
+    \r
+    public static final void oneLevelDirCopy(String src, String des, String type) throws Exception {\r
+       String[] list = new File(src).list();\r
+       \r
+       ensureDir(des);\r
+       for (int i = 0; i < list.length; i++) {\r
+               if (list[i].contains(type)) {\r
+                string2file(file2string(src + File.separator + list[i]), des + File.separator + list[i]);\r
+               }\r
+       }\r
+    }\r
 \r
     //--------------------------------------dir--------------------------------------------//\r
 \r
index 95266fc42f4c14896a40092ecc0fcbfaa2554b87..5acf56f60f11ab164479745513c7f5e764c128b8 100644 (file)
@@ -180,7 +180,7 @@ public final class FirstPanel extends JPanel implements ActionListener, ItemList
         }\r
         if ( e.getSource() == goButton ) {\r
             try {\r
-                logfile = new PrintWriter(new BufferedWriter(new FileWriter(startpath.replaceAll(Common.strseparate, "$1") + File.separator + "migration.log")));\r
+                logfile = new PrintWriter(new BufferedWriter(new FileWriter(startpath.replaceAll(Common.STRSEPARATER, "$1") + File.separator + "migration.log")));\r
                 MigrationTool.startMigrateAll(startpath);\r
                 logfile.flush();\r
                 logfile.close();\r
index edb6a95a34b7f91c0ce79442545bef6813e7c24f..7a37484914af705264ecf9a1da7fcd44e2aca088 100644 (file)
@@ -31,7 +31,7 @@ public class MigrationTool {
 \r
     private static final void mainFlow(ModuleInfo mi) throws Exception {\r
 \r
-        ModuleReader.ModuleScan(mi);\r
+        ModuleReader.aimAt(mi);\r
         \r
         //MigrationTool.ui.yesOrNo("go on replace?");\r
         SourceFileReplacer.fireAt(mi);    // some adding library actions are taken here,so it must be put before "MsaWriter"\r
@@ -76,7 +76,7 @@ public class MigrationTool {
 \r
     private static final String assignOutPutPath(String inputpath) {\r
         if (MigrationTool.defaultoutput) {\r
-            return inputpath.replaceAll(Common.strseparate, "$1");\r
+            return inputpath.replaceAll(Common.STRSEPARATER, "$1");\r
         } else {\r
             return MigrationTool.ui.getFilepath("Please choose where to place the output module", JFileChooser.DIRECTORIES_ONLY);\r
         }\r
index 791ccd23fa720538779255d1202d2ef6cca1b17a..912e31ced9fdf4eea8ac839ca20e3f37d07fe470 100644 (file)
@@ -34,6 +34,8 @@ public final class ModuleInfo {
     public final Set<String> localmodulesources = new HashSet<String>();        //contains both .c and .h\r
     public final Set<String> preprocessedccodes = new HashSet<String>();\r
     public final Set<String> msaorinf = new HashSet<String>();                //only a little, hash may be too big for this\r
+    public final Set<String> infincludes = new HashSet<String>();\r
+    public final Set<String> infsources = new HashSet<String>();\r
     \r
     public final Set<String> hashfuncc = new HashSet<String>();\r
     public final Set<String> hashfuncd = new HashSet<String>();\r
index a7f97a975d28e39230d2ceafefbb07ddc3f778c4..a0a53d668cc594acf3c0c91291ac3e97a51a3a39 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
@@ -113,48 +113,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.common")) {\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");\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
-            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
@@ -263,4 +278,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
index 4ff8ebe52494f6ee3267c2622165d991f47b363b..bce108f934177c6883d594f635af1fd6d95bbad1 100644 (file)
@@ -104,7 +104,6 @@ public final class SourceFileReplacer implements Common.ForDoAll {
     \r
     private class CLaplace extends Common.Laplace {\r
         public  String operation(String wholeline) {\r
-            boolean addr8 = false;\r
             // remove EFI_DRIVER_ENTRY_POINT\r
             wholeline = wholeline.replaceAll("(EFI_[A-Z]+_ENTRY_POINT\\s*\\(\\s*" + mi.entrypoint + "\\s*\\)\\s*;)", MigrationTool.MIGRATIONCOMMENT + " $1");\r
             // redefine module entry point for some self-relocated modules\r
@@ -390,7 +389,7 @@ public final class SourceFileReplacer implements Common.ForDoAll {
     \r
     //-----------------------------------ForDoAll-----------------------------------//\r
     public void run(String filepath) throws Exception {\r
-        String inname = filepath.replace(mi.modulepath + File.separator, "");\r
+        String inname = filepath.replace(mi.modulepath + File.separator + "temp" + File.separator, "");\r
         String tempinpath = mi.modulepath + File.separator + "temp" + File.separator;\r
         String tempoutpath = MigrationTool.ModuleInfoMap.get(mi) + File.separator + "Migration_" + mi.modulename + File.separator;\r
 \r
@@ -418,7 +417,7 @@ public final class SourceFileReplacer implements Common.ForDoAll {
         Laplaces.add(new CLaplace());\r
         Laplaces.add(new IdleLaplace());\r
         \r
-        Common.toDoAll(mi.localmodulesources, this);\r
+        Common.toDoAll(mi.modulepath + File.separator + "temp", this, Common.FILE);\r
         \r
         if (!mi.hashr8only.isEmpty()) {\r
             addr8only();\r