Add Arch Check for single module build. To Fix T167 & T224.

git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@1404 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
wuyizhong 2006-08-30 03:11:48 +00:00
parent 52ee46a69b
commit 3790e93c7e
2 changed files with 36 additions and 7 deletions

View File

@ -342,7 +342,8 @@ public class GenBuildTask extends Ant {
//
FpdParserTask fpdParser = new FpdParserTask();
fpdParser.setProject(getProject());
fpdParser.parseFpdFile(platformId.getFpdFile());
fpdParser.parseFpdFile(platformId.getFpdFile(), moduleId);
PropertyManager.setProperty("ARCH", fpdParser.getAllArchForModule(moduleId));
//
// Prepare for Platform related common properties

View File

@ -305,18 +305,21 @@ public class FpdParserTask extends Task {
@throws BuildException
FPD file is not valid.
**/
public void parseFpdFile(File fpdFile) throws BuildException {
public void parseFpdFile(File fpdFile, ModuleIdentification singleModuleId) throws BuildException {
this.fpdFile = fpdFile;
parseFpdFile();
parseFpdFile(singleModuleId);
}
private void parseFpdFile() throws BuildException {
parseFpdFile(null);
}
/**
Parse FPD file.
@throws BuildException
FPD file is not valid.
**/
private void parseFpdFile() throws BuildException {
private void parseFpdFile(ModuleIdentification singleModuleId) throws BuildException {
try {
XmlObject doc = XmlObject.Factory.parse(fpdFile);
@ -356,7 +359,7 @@ public class FpdParserTask extends Task {
//
// Parse all list modules SA
//
parseModuleSAFiles();
parseModuleSAFiles(singleModuleId);
//
// TBD. Deal PCD and BuildOption related Info
@ -381,7 +384,7 @@ public class FpdParserTask extends Task {
/**
Parse all modules listed in FPD file.
**/
private void parseModuleSAFiles() throws EdkException{
private void parseModuleSAFiles(ModuleIdentification singleModuleId) throws EdkException{
Map<FpdModuleIdentification, Map<String, XmlObject>> moduleSAs = SurfaceAreaQuery.getFpdModules();
//
@ -392,10 +395,21 @@ public class FpdParserTask extends Task {
while (iter.hasNext()) {
FpdModuleIdentification fpdModuleId = (FpdModuleIdentification) iter.next();
//
// If is stand-alone module build, just parse this module, pass others
//
if (singleModuleId != null) {
//
// pass others modules
//
if ( ! fpdModuleId.getModule().equals(singleModuleId)) {
continue ;
}
}
//
// Judge if Module is existed?
// TBD
GlobalData.registerFpdModuleSA(fpdModuleId, moduleSAs.get(fpdModuleId));
//
@ -558,4 +572,18 @@ public class FpdParserTask extends Task {
public void setType(String type) {
this.type = type;
}
public String getAllArchForModule(ModuleIdentification moduleId) {
String archs = "";
Iterator<FpdModuleIdentification> iter = outfiles.keySet().iterator();
while (iter.hasNext()) {
FpdModuleIdentification fpdModuleId = iter.next();
if (fpdModuleId.getModule().equals(moduleId)) {
archs += fpdModuleId.getArch() + " ";
}
}
return archs;
}
}