]> git.proxmox.com Git - mirror_edk2.git/blame - Tools/Source/FrameworkTasks/org/tianocore/framework/tasks/ZeroDebugDataTask.java
Add follows warpped tianotools to frameworktask:
[mirror_edk2.git] / Tools / Source / FrameworkTasks / org / tianocore / framework / tasks / ZeroDebugDataTask.java
CommitLineData
a15bb0d3 1/** @file\r
2 ZeroDebugDataTask class.\r
3\r
4 ZeroDebugDataTask is used to call ZeroDebugData.exe to remove debug data.\r
5 \r
6 \r
7 Copyright (c) 2006, Intel Corporation\r
8 All rights reserved. This program and the accompanying materials\r
9 are licensed and made available under the terms and conditions of the BSD License\r
10 which accompanies this distribution. The full text of the license may be found at\r
11 http://opensource.org/licenses/bsd-license.php\r
12 \r
13 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
14 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
15\r
16 **/\r
17package org.tianocore.framework.tasks;\r
18\r
19import java.io.File;\r
20\r
21import org.apache.tools.ant.Task;\r
22import org.apache.tools.ant.Project;\r
23import org.apache.tools.ant.BuildException;\r
24import org.apache.tools.ant.taskdefs.Execute;\r
25import org.apache.tools.ant.taskdefs.LogStreamHandler;\r
26import org.apache.tools.ant.types.Commandline;\r
27import org.tianocore.logger.EdkLog;\r
28\r
29/**\r
30 ZeroDebugDataTask class.\r
31\r
32 ZeroDebugDataTask is used to call ZeroDebugData.exe to remove debug data.\r
33**/\r
34public class ZeroDebugDataTask extends Task implements EfiDefine {\r
35 // /\r
36 // / input PE file\r
37 // /\r
38 private String peFile = "";\r
39\r
40 // /\r
41 // / output file\r
42 // /\r
43 private String outputFile = "DebugData.dat";\r
44\r
45 // /\r
46 // / output directory, this variable is added by jave wrap\r
47 // /\r
48 private String outputDir = "";\r
49\r
50\r
51 /**\r
52 * execute\r
53 * \r
54 * ZeroDebugDataTask execute function is to assemble tool command line & execute\r
55 * tool command line\r
56 * \r
57 * @throws BuidException\r
58 */\r
59 public void execute() throws BuildException {\r
60\r
61 Project project = this.getOwningTarget().getProject();\r
62 //\r
63 // set Logger\r
64 //\r
65 FrameworkLogger logger = new FrameworkLogger(project, "zerodebugdata");\r
66 EdkLog.setLogLevel(project.getProperty("env.LOGLEVEL"));\r
67 EdkLog.setLogger(logger);\r
68 //\r
69 // absolute path of efi tools\r
70 //\r
71 String path = project.getProperty("env.FRAMEWORK_TOOLS_PATH");\r
72 String command;\r
73 String argument;\r
74 if (path == null) {\r
75 command = "ZeroDebugData";\r
76 } else {\r
77 command = path + File.separatorChar + "ZeroDebugData";\r
78 }\r
79 //\r
80 // argument of tools\r
81 //\r
82 File file = new File(outputFile);\r
83 if (!file.isAbsolute() && (!this.outputDir.equalsIgnoreCase(""))) {\r
84 argument = this.peFile + " " + outputDir + File.separatorChar\r
85 + outputFile;\r
86 } else {\r
87 argument = this.peFile + " " + outputFile;\r
88 }\r
89 //\r
90 // return value of fwimage execution\r
91 //\r
92 int revl = -1;\r
93\r
94 try {\r
95 Commandline cmdline = new Commandline();\r
96 cmdline.setExecutable(command);\r
97 cmdline.createArgument().setLine(argument);\r
98\r
99 LogStreamHandler streamHandler = new LogStreamHandler(this,\r
100 Project.MSG_INFO, Project.MSG_WARN);\r
101 Execute runner = new Execute(streamHandler, null);\r
102\r
103 runner.setAntRun(project);\r
104 runner.setCommandline(cmdline.getCommandline());\r
105 //\r
106 // Set debug log information.\r
107 //\r
108 EdkLog.log(EdkLog.EDK_INFO, Commandline.toString(cmdline.getCommandline()));\r
109 \r
110 revl = runner.execute();\r
111 \r
112 if (EFI_SUCCESS == revl) {\r
113 //\r
114 // command execution success\r
115 //\r
116 EdkLog.log(EdkLog.EDK_INFO,"ZeroDebug succeeded!");\r
117 } else {\r
118 //\r
119 // command execution fail\r
120 //\r
121 EdkLog.log(EdkLog.EDK_ERROR, "ZeroDebug failed. (error="\r
122 + Integer.toHexString(revl) + ")");\r
123 throw new BuildException("ZeroDebug failed. (error="\r
124 + Integer.toHexString(revl) + ")");\r
125\r
126 }\r
127 } catch (Exception e) {\r
128 throw new BuildException(e.getMessage());\r
129 }\r
130 }\r
131\r
132 /**\r
133 * getPeFile\r
134 * \r
135 * This function is to get class member "inputFile".\r
136 * \r
137 * @return string of input file name.\r
138 */\r
139 public String getPeFile() {\r
140 return this.peFile;\r
141 }\r
142\r
143 /**\r
144 * setPeFile\r
145 * \r
146 * This function is to set class member "peFile".\r
147 * \r
148 * @param peFile\r
149 * string of input file name.\r
150 */\r
151 public void setPeFile(String peFile) {\r
152 this.peFile = peFile;\r
153 }\r
154\r
155 /**\r
156 * getOutputFile\r
157 * \r
158 * This function is to get class member "outputFile"\r
159 * \r
160 * @return outputFile string of output file name.\r
161 */\r
162 public String getOutputFile() {\r
163 return outputFile;\r
164 }\r
165\r
166 /**\r
167 * setOutputFile\r
168 * \r
169 * This function is to set class member "outputFile"\r
170 * \r
171 * @param outputFile\r
172 * string of output file name.\r
173 */\r
174 public void setOutputFile(String outputFile) {\r
175 this.outputFile = outputFile;\r
176 }\r
177\r
178 /**\r
179 * getOutputDir\r
180 * \r
181 * This function is to get class member "outputDir"\r
182 * \r
183 * @return outputDir string of output directory.\r
184 */\r
185 public String getOutputDir() {\r
186 return outputDir;\r
187 }\r
188\r
189 /**\r
190 * setOutputDir\r
191 * \r
192 * This function is to set class member "outputDir"\r
193 * \r
194 * @param outputDir\r
195 * string of output directory.\r
196 */\r
197 public void setOutputDir(String outputDir) {\r
198 this.outputDir = outputDir;\r
199 }\r
200}\r