mirror of https://github.com/acidanthera/audk.git
Added outputDir attribute to support generating FV file in specified directory
git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@273 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
parent
f76fd83e6f
commit
d05003bed6
|
@ -14,7 +14,6 @@
|
||||||
|
|
||||||
**/
|
**/
|
||||||
package org.tianocore.framework.tasks;
|
package org.tianocore.framework.tasks;
|
||||||
import java.io.File;
|
|
||||||
|
|
||||||
import org.apache.tools.ant.BuildException;
|
import org.apache.tools.ant.BuildException;
|
||||||
import org.apache.tools.ant.Project;
|
import org.apache.tools.ant.Project;
|
||||||
|
@ -23,6 +22,16 @@ import org.apache.tools.ant.taskdefs.Execute;
|
||||||
import org.apache.tools.ant.taskdefs.LogStreamHandler;
|
import org.apache.tools.ant.taskdefs.LogStreamHandler;
|
||||||
import org.apache.tools.ant.types.Commandline;
|
import org.apache.tools.ant.types.Commandline;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.InputStream;
|
||||||
|
import java.io.InputStreamReader;
|
||||||
|
import java.lang.ProcessBuilder;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.LinkedList;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
GenFvImageTask
|
GenFvImageTask
|
||||||
|
|
||||||
|
@ -30,6 +39,10 @@ import org.apache.tools.ant.types.Commandline;
|
||||||
|
|
||||||
**/
|
**/
|
||||||
public class GenFvImageTask extends Task implements EfiDefine{
|
public class GenFvImageTask extends Task implements EfiDefine{
|
||||||
|
///
|
||||||
|
/// tool name
|
||||||
|
///
|
||||||
|
static final private String toolName = "GenFvImage";
|
||||||
///
|
///
|
||||||
/// The name of input inf file
|
/// The name of input inf file
|
||||||
///
|
///
|
||||||
|
@ -38,6 +51,14 @@ public class GenFvImageTask extends Task implements EfiDefine{
|
||||||
/// The target architecture.
|
/// The target architecture.
|
||||||
///
|
///
|
||||||
private String arch="";
|
private String arch="";
|
||||||
|
///
|
||||||
|
/// Output directory
|
||||||
|
///
|
||||||
|
private String outputDir = ".";
|
||||||
|
///
|
||||||
|
/// argument list
|
||||||
|
///
|
||||||
|
LinkedList<String> argList = new LinkedList<String>();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
execute
|
execute
|
||||||
|
@ -48,68 +69,45 @@ public class GenFvImageTask extends Task implements EfiDefine{
|
||||||
public void execute() throws BuildException {
|
public void execute() throws BuildException {
|
||||||
Project project = this.getOwningTarget().getProject();
|
Project project = this.getOwningTarget().getProject();
|
||||||
String path = project.getProperty("env.Framework_Tools_Path");
|
String path = project.getProperty("env.Framework_Tools_Path");
|
||||||
String command = "";
|
|
||||||
|
|
||||||
if (path == null) {
|
if (path == null) {
|
||||||
path = "";
|
path = "";
|
||||||
} else {
|
} else {
|
||||||
path = path + File.separatorChar;
|
path += File.separatorChar;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (arch.equalsIgnoreCase("")){
|
if (arch != null && arch.length() > 0) {
|
||||||
command = path + "GenFvImage";
|
argList.addFirst(path + toolName + "_" + arch);
|
||||||
}
|
|
||||||
if (arch.equalsIgnoreCase("ia32")){
|
|
||||||
command = path + "GenFvImage_IA32";
|
|
||||||
}
|
|
||||||
if (arch.equalsIgnoreCase("x64")){
|
|
||||||
command = path + "GenFvImage_X64";
|
|
||||||
}
|
|
||||||
if (arch.equalsIgnoreCase("ipf")){
|
|
||||||
command = path + "GenFvImage_IPF";
|
|
||||||
}
|
|
||||||
String argument = infFile;
|
|
||||||
|
|
||||||
try {
|
|
||||||
|
|
||||||
Commandline commandLine = new Commandline();
|
|
||||||
commandLine.setExecutable(command);
|
|
||||||
commandLine.createArgument().setLine(argument);
|
|
||||||
|
|
||||||
LogStreamHandler streamHandler = new LogStreamHandler(this,
|
|
||||||
Project.MSG_INFO,
|
|
||||||
Project.MSG_WARN);
|
|
||||||
//
|
|
||||||
// create a execute object and set it's commandline
|
|
||||||
//
|
|
||||||
Execute runner = new Execute(streamHandler,null);
|
|
||||||
runner.setAntRun(project);
|
|
||||||
runner.setCommandline(commandLine.getCommandline());
|
|
||||||
System.out.println(Commandline.toString(commandLine.getCommandline()));
|
|
||||||
|
|
||||||
int revl = -1;
|
|
||||||
//
|
|
||||||
// user execute class call external programs - GenFvImage
|
|
||||||
//
|
|
||||||
revl = runner.execute();
|
|
||||||
//
|
|
||||||
// execute command line success!
|
|
||||||
//
|
|
||||||
if (EFI_SUCCESS == revl){
|
|
||||||
System.out.println("GenFvImage succeeded!");
|
|
||||||
} else {
|
} else {
|
||||||
|
argList.addFirst(path + toolName);
|
||||||
//
|
|
||||||
// execute command line failed!
|
|
||||||
//
|
|
||||||
throw new BuildException("GenFvImage failed !(error =" +
|
|
||||||
Integer.toHexString(revl) + ")");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
///
|
||||||
|
/// lauch the program
|
||||||
|
///
|
||||||
|
ProcessBuilder pb = new ProcessBuilder(argList);
|
||||||
|
pb.directory(new File(outputDir));
|
||||||
|
int exitCode = 0;
|
||||||
|
try {
|
||||||
|
Process cmdProc = pb.start();
|
||||||
|
InputStreamReader cmdOut = new InputStreamReader(cmdProc.getInputStream());
|
||||||
|
char[] buf = new char[1024];
|
||||||
|
|
||||||
|
exitCode = cmdProc.waitFor();
|
||||||
|
if (exitCode != 0) {
|
||||||
|
int len = cmdOut.read(buf, 0, 1024);
|
||||||
|
log(new String(buf, 0, len), Project.MSG_ERR);
|
||||||
|
} else {
|
||||||
|
log("GenFvImage - DONE!", Project.MSG_VERBOSE);
|
||||||
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
System.out.println(e.getMessage());
|
throw new BuildException(e.getMessage());
|
||||||
|
} finally {
|
||||||
|
if (exitCode != 0) {
|
||||||
|
throw new BuildException("GenFvImage: failed to generate FV file!");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
}
|
||||||
/**
|
/**
|
||||||
getInfFile
|
getInfFile
|
||||||
|
|
||||||
|
@ -128,7 +126,9 @@ public class GenFvImageTask extends Task implements EfiDefine{
|
||||||
@param infFile name of infFile
|
@param infFile name of infFile
|
||||||
**/
|
**/
|
||||||
public void setInfFile(String infFile) {
|
public void setInfFile(String infFile) {
|
||||||
this.infFile = "-I " + infFile;
|
this.infFile = infFile;
|
||||||
|
argList.add("-I");
|
||||||
|
argList.add(infFile);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -151,4 +151,26 @@ public class GenFvImageTask extends Task implements EfiDefine{
|
||||||
public void setArch(String arch) {
|
public void setArch(String arch) {
|
||||||
this.arch = arch;
|
this.arch = arch;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
getOutputDir
|
||||||
|
|
||||||
|
This function is to get output directory.
|
||||||
|
|
||||||
|
@return Path of output directory.
|
||||||
|
**/
|
||||||
|
public String getOutputDir() {
|
||||||
|
return outputDir;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
setOutputDir
|
||||||
|
|
||||||
|
This function is to set output directory.
|
||||||
|
|
||||||
|
@param outputDir The output direcotry.
|
||||||
|
**/
|
||||||
|
public void setOutputDir(String outputDir) {
|
||||||
|
this.outputDir = outputDir;
|
||||||
|
}
|
||||||
}
|
}
|
Loading…
Reference in New Issue