2 CreateMtFileTask class.
4 CreateMtFileTask is used to call CreateMtFile.exe to create MT file.
7 Copyright (c) 2006, Intel Corporation
8 All rights reserved. This program and the accompanying materials
9 are licensed and made available under the terms and conditions of the BSD License
10 which accompanies this distribution. The full text of the license may be found at
11 http://opensource.org/licenses/bsd-license.php
13 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
14 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
17 package org
.tianocore
.framework
.tasks
;
21 import org
.apache
.tools
.ant
.Task
;
22 import org
.apache
.tools
.ant
.Project
;
23 import org
.apache
.tools
.ant
.BuildException
;
24 import org
.apache
.tools
.ant
.taskdefs
.Execute
;
25 import org
.apache
.tools
.ant
.taskdefs
.LogStreamHandler
;
26 import org
.apache
.tools
.ant
.types
.Commandline
;
28 import org
.tianocore
.common
.logger
.EdkLog
;
31 CreateMtFileTask class.
33 CreateMtFileTask is used to call CreateMtFile.exe to create MT file.
35 public class CreateMtFileTask
extends Task
implements EfiDefine
{
39 private String toolName
="CreateMtFile";
43 private String fileSize
= "";
48 private String outputFile
= "";
51 /// output directory, this variable is added by jave wrap
53 private String outputDir
= "";
58 * StripTask execute function is to assemble tool command line & execute
61 * @throws BuidException
63 public void execute() throws BuildException
{
65 Project project
= this.getOwningTarget().getProject();
69 FrameworkLogger logger
= new FrameworkLogger(project
, "createmtfile");
70 EdkLog
.setLogLevel(project
.getProperty("env.LOGLEVEL"));
71 EdkLog
.setLogger(logger
);
73 // absolute path of efi tools
75 String path
= project
.getProperty("env.FRAMEWORK_TOOLS_PATH");
81 command
= path
+ File
.separatorChar
+ toolName
;
86 File file
= new File(outputFile
);
87 if (!file
.isAbsolute() && (!this.outputDir
.equalsIgnoreCase(""))) {
88 argument
= outputDir
+ File
.separatorChar
+ outputFile
+ " " + this.fileSize
;
91 argument
= outputFile
+ " " + this.fileSize
;
94 // return value of fwimage execution
99 Commandline cmdline
= new Commandline();
100 cmdline
.setExecutable(command
);
101 cmdline
.createArgument().setLine(argument
);
103 LogStreamHandler streamHandler
= new LogStreamHandler(this,
104 Project
.MSG_INFO
, Project
.MSG_WARN
);
105 Execute runner
= new Execute(streamHandler
, null);
107 runner
.setAntRun(project
);
108 runner
.setCommandline(cmdline
.getCommandline());
110 // Set debug log information.
112 EdkLog
.log(EdkLog
.EDK_VERBOSE
, Commandline
.toString(cmdline
.getCommandline()));
113 EdkLog
.log(EdkLog
.EDK_INFO
, (new File(this.outputFile
)).getName());
114 revl
= runner
.execute();
116 if (EFI_SUCCESS
== revl
) {
118 // command execution success
120 EdkLog
.log(EdkLog
.EDK_VERBOSE
, "CreateMtFile succeeded!");
123 // command execution fail
125 EdkLog
.log(EdkLog
.EDK_INFO
, "ERROR = " + Integer
.toHexString(revl
));
126 throw new BuildException("CreateMtFile failed!");
128 } catch (Exception e
) {
129 throw new BuildException(e
.getMessage());
136 * This function is to get class member "fileSize".
138 * @return fileSize string of file size.
140 public String
getFileSize() {
141 return this.fileSize
;
147 * This function is to set class member "fileSize".
150 * string of file size value.
152 public void setFileSize(String fileSize
) {
153 this.fileSize
= fileSize
;
159 * This function is to get class member "outputFile"
161 * @return outputFile string of output file name.
163 public String
getOutputFile() {
170 * This function is to set class member "outputFile"
173 * string of output file name.
175 public void setOutputFile(String outputFile
) {
176 this.outputFile
= outputFile
;
182 * This function is to get class member "outputDir"
184 * @return outputDir string of output directory.
186 public String
getOutputDir() {
193 * This function is to set class member "outputDir"
196 * string of output directory.
198 public void setOutputDir(String outputDir
) {
199 this.outputDir
= outputDir
;