]> git.proxmox.com Git - mirror_edk2.git/blobdiff - Tools/Source/FrameworkTasks/org/tianocore/framework/tasks/FwImageTask.java
1) Changed ToolArg class to abstract generic arguments of a tool
[mirror_edk2.git] / Tools / Source / FrameworkTasks / org / tianocore / framework / tasks / FwImageTask.java
index 13df297fa616ae1729c4102161683d1c2f4d51a8..b17e7fbf12f9fc5ed01565beca82540dc29e150b 100644 (file)
@@ -25,29 +25,34 @@ import org.apache.tools.ant.taskdefs.Execute;
 import org.apache.tools.ant.taskdefs.LogStreamHandler;\r
 import org.apache.tools.ant.types.Commandline;\r
 \r
+import org.tianocore.common.logger.EdkLog;\r
+\r
 /**\r
   FwImageTask class.\r
 \r
   FwImageTask is used to call FwImage.ext to generate the FwImage.\r
 **/\r
-public class FwImageTask extends Task implements EfiDefine{\r
-    ///\r
-    /// time&data\r
-    ///\r
-    private String time = "";\r
-    ///\r
-    /// input PE image\r
-    ///\r
-    private String peImage = "";\r
-    private String peImageName = "";\r
-    ///\r
-    /// output EFI image\r
-    ///\r
-    private String outImage = "";\r
-    ///\r
-    /// component type\r
-    ///\r
-    private String componentType = "";\r
+public class FwImageTask extends Task implements EfiDefine {\r
+    //\r
+    // fwimage tool name\r
+    // \r
+    private static String toolName = "FwImage";\r
+    //\r
+    // time&data\r
+    //\r
+    private ToolArg time = new ToolArg();\r
+    //\r
+    // input PE image\r
+    //\r
+    private FileArg peImage = new FileArg();\r
+    //\r
+    // output EFI image\r
+    //\r
+    private FileArg outImage = new FileArg();\r
+    //\r
+    // component type\r
+    //\r
+    private ToolArg componentType = new ToolArg();\r
 \r
     /**\r
      * assemble tool command line & execute tool command line\r
@@ -71,14 +76,14 @@ public class FwImageTask extends Task implements EfiDefine{
         String path = project.getProperty("env.FRAMEWORK_TOOLS_PATH");\r
         String command;\r
         if (path == null) {\r
-            command = "FwImage";\r
+            command = toolName;\r
         } else {\r
-            command = path + "/" + "FwImage";\r
+            command = path + "/" + toolName;\r
         }\r
         //\r
         // argument of tools\r
         //\r
-        String argument = time + componentType + peImage + outImage;\r
+        String argument = "" + time + componentType + peImage + outImage;\r
         //\r
         // return value of fwimage execution\r
         //\r
@@ -96,16 +101,17 @@ public class FwImageTask extends Task implements EfiDefine{
             runner.setAntRun(project);\r
             runner.setCommandline(cmdline.getCommandline());\r
 \r
-            log(Commandline.toString(cmdline.getCommandline()), Project.MSG_VERBOSE);\r
-            log(this.peImageName);\r
+            EdkLog.log(this, EdkLog.EDK_VERBOSE, Commandline.toString(cmdline.getCommandline()));\r
+            EdkLog.log(this, peImage.toFileList() + " => " + outImage.toFileList());\r
+\r
             revl = runner.execute();\r
             if (EFI_SUCCESS == revl) {\r
-                log("FwImage succeeded!", Project.MSG_VERBOSE);\r
+                EdkLog.log(this, EdkLog.EDK_VERBOSE, "FwImage succeeded!");\r
             } else {\r
                 //\r
                 // command execution fail\r
                 //\r
-                log("ERROR = " + Integer.toHexString(revl));\r
+                EdkLog.log(this, "ERROR = " + Integer.toHexString(revl));\r
                 throw new BuildException("FwImage failed!");\r
             }\r
         } catch (Exception e) {\r
@@ -121,7 +127,7 @@ public class FwImageTask extends Task implements EfiDefine{
       @param time            string of time\r
     **/\r
     public void setTime(String time) {\r
-        this.time = " -t " + time;\r
+        this.time.setArg(" -t ", time);\r
     }\r
 \r
     /**\r
@@ -131,7 +137,7 @@ public class FwImageTask extends Task implements EfiDefine{
       @return time          string of time\r
     **/\r
     public String getTime() {\r
-        return this.time;\r
+        return this.time.getValue();\r
     }\r
 \r
     /**\r
@@ -141,7 +147,7 @@ public class FwImageTask extends Task implements EfiDefine{
       @return                name of PE image\r
     **/\r
     public String getPeImage() {\r
-        return this.peImage;\r
+        return this.peImage.getValue();\r
     }\r
 \r
     /**\r
@@ -151,8 +157,7 @@ public class FwImageTask extends Task implements EfiDefine{
       @param  peImage        name of PE image\r
     **/\r
     public void setPeImage(String peImage) {\r
-        this.peImageName = (new File(peImage)).getName();\r
-        this.peImage = " " + peImage;\r
+        this.peImage.setArg(" ", peImage);\r
     }\r
 \r
     /**\r
@@ -162,7 +167,7 @@ public class FwImageTask extends Task implements EfiDefine{
       @return                 name of output EFI image\r
     **/\r
     public String getOutImage() {\r
-        return this.outImage;\r
+        return this.outImage.getValue();\r
     }\r
 \r
     /**\r
@@ -172,7 +177,7 @@ public class FwImageTask extends Task implements EfiDefine{
       @param outImage         name of output EFI image\r
     **/\r
     public void setOutImage(String outImage) {\r
-        this.outImage = " " + outImage;\r
+        this.outImage.setArg(" ", outImage);\r
     }\r
 \r
     /**\r
@@ -183,7 +188,7 @@ public class FwImageTask extends Task implements EfiDefine{
       @return                 string of componentType\r
     **/\r
     public String getComponentType() {\r
-        return this.componentType;\r
+        return this.componentType.getValue();\r
     }\r
 \r
     /**\r
@@ -193,6 +198,6 @@ public class FwImageTask extends Task implements EfiDefine{
       @param  componentType   string of component type\r
     **/\r
     public void setComponentType(String componentType) {\r
-        this.componentType = " " + componentType;\r
+        this.componentType.setArg(" ", componentType);\r
     }\r
 }\r