]> git.proxmox.com Git - mirror_edk2.git/blame_incremental - Tools/Source/GenBuild/org/tianocore/build/global/GlobalData.java
moved exception and logger classes to org.tianocore.common package
[mirror_edk2.git] / Tools / Source / GenBuild / org / tianocore / build / global / GlobalData.java
... / ...
CommitLineData
1/** @file\r
2 GlobalData class.\r
3\r
4 GlobalData provide initializing, instoring, querying and update global data.\r
5 It is a bridge to intercommunicate between multiple component, such as AutoGen,\r
6 PCD and so on.\r
7\r
8Copyright (c) 2006, Intel Corporation\r
9All rights reserved. This program and the accompanying materials\r
10are licensed and made available under the terms and conditions of the BSD License\r
11which accompanies this distribution. The full text of the license may be found at\r
12http://opensource.org/licenses/bsd-license.php\r
13\r
14THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
15WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
16**/\r
17package org.tianocore.build.global;\r
18\r
19import java.io.File;\r
20import java.util.HashMap;\r
21import java.util.HashSet;\r
22import java.util.Iterator;\r
23import java.util.List;\r
24import java.util.Map;\r
25import java.util.Set;\r
26import java.util.logging.Logger;\r
27\r
28import org.apache.tools.ant.BuildException;\r
29import org.apache.xmlbeans.XmlObject;\r
30\r
31import org.tianocore.common.exception.EdkException;\r
32import org.tianocore.common.logger.EdkLog;\r
33import org.tianocore.pcd.entity.MemoryDatabaseManager;\r
34import org.tianocore.DbPathAndFilename;\r
35import org.tianocore.FrameworkDatabaseDocument;\r
36import org.tianocore.ModuleSurfaceAreaDocument;\r
37import org.tianocore.ModuleSurfaceAreaDocument.ModuleSurfaceArea;\r
38import org.tianocore.build.id.FpdModuleIdentification;\r
39import org.tianocore.build.id.ModuleIdentification;\r
40import org.tianocore.build.id.PackageIdentification;\r
41import org.tianocore.build.id.PlatformIdentification;\r
42import org.tianocore.build.toolchain.ToolChainAttribute;\r
43import org.tianocore.build.toolchain.ToolChainConfig;\r
44import org.tianocore.build.toolchain.ToolChainElement;\r
45import org.tianocore.build.toolchain.ToolChainInfo;\r
46import org.tianocore.build.toolchain.ToolChainKey;\r
47import org.tianocore.build.toolchain.ToolChainMap;\r
48\r
49/**\r
50 GlobalData provide initializing, instoring, querying and update global data.\r
51 It is a bridge to intercommunicate between multiple component, such as AutoGen,\r
52 PCD and so on.\r
53\r
54 <p>Note that all global information are initialized incrementally. All data will\r
55 parse and record only of necessary during build time. </p>\r
56\r
57 @since GenBuild 1.0\r
58**/\r
59public class GlobalData {\r
60\r
61 public static Logger log = Logger.getAnonymousLogger();\r
62\r
63 ///\r
64 /// Record current WORKSPACE Directory\r
65 ///\r
66 private static String workspaceDir = "";\r
67\r
68 ///\r
69 /// Be used to ensure Global data will be initialized only once.\r
70 ///\r
71 private static boolean globalFlag = false;\r
72\r
73 ///\r
74 /// Framework Database information: package list and platform list\r
75 ///\r
76 private static Set<PackageIdentification> packageList = new HashSet<PackageIdentification>();\r
77\r
78 private static Set<PlatformIdentification> platformList = new HashSet<PlatformIdentification>();\r
79\r
80 ///\r
81 /// Every detail SPD informations: Module list, Library class definition,\r
82 /// Package header file, GUID/PPI/Protocol definitions\r
83 ///\r
84 private static final Map<PackageIdentification, Spd> spdTable = new HashMap<PackageIdentification, Spd>();\r
85\r
86 ///\r
87 /// Build informations are divided into three parts:\r
88 /// 1. From MSA 2. From FPD 3. From FPD' ModuleSA\r
89 ///\r
90 private static Map<ModuleIdentification, Map<String, XmlObject>> nativeMsa = new HashMap<ModuleIdentification, Map<String, XmlObject>>();\r
91\r
92 private static Map<FpdModuleIdentification, Map<String, XmlObject>> fpdModuleSA= new HashMap<FpdModuleIdentification, Map<String, XmlObject>>();\r
93\r
94 private static XmlObject fpdBuildOptions;\r
95\r
96 private static XmlObject fpdDynamicPcds;\r
97\r
98 ///\r
99 /// Parsed modules list\r
100 ///\r
101 private static Map<FpdModuleIdentification, Map<String, XmlObject>> parsedModules = new HashMap<FpdModuleIdentification, Map<String, XmlObject>>();\r
102\r
103 ///\r
104 /// built modules list with ARCH, TARGET, TOOLCHAIN\r
105 ///\r
106 private static Set<FpdModuleIdentification> builtModules = new HashSet<FpdModuleIdentification>();\r
107\r
108 ///\r
109 /// PCD memory database stored all PCD information which collected from FPD,MSA and SPD.\r
110 ///\r
111 private static final MemoryDatabaseManager pcdDbManager = new MemoryDatabaseManager();\r
112\r
113 ///\r
114 /// build target + tool chain family/tag name + arch + command types + command options\r
115 ///\r
116 ///\r
117 /// Tool Chain Data\r
118 /// toolsDef - build tool program information\r
119 /// fpdBuildOption - all modules's build options for tool tag or tool chain families\r
120 /// moduleSaBuildOption - build options for a specific module\r
121 ///\r
122 private static ToolChainConfig toolsDef;\r
123\r
124 private static ToolChainInfo toolChainInfo;\r
125 private static ToolChainInfo toolChainEnvInfo;\r
126 private static ToolChainInfo toolChainPlatformInfo;\r
127\r
128 private static ToolChainMap platformToolChainOption;\r
129 private static ToolChainMap platformToolChainFamilyOption;\r
130\r
131 private static Map<FpdModuleIdentification, ToolChainMap> moduleToolChainOption = new HashMap<FpdModuleIdentification, ToolChainMap>();\r
132 private static Map<FpdModuleIdentification, ToolChainMap> moduleToolChainFamilyOption = new HashMap<FpdModuleIdentification, ToolChainMap>();\r
133\r
134 /**\r
135 Parse framework database (DB) and all SPD files listed in DB to initialize\r
136 the environment for next build. This method will only be executed only once\r
137 in the whole build process.\r
138\r
139 @param workspaceDatabaseFile the file name of framework database\r
140 @param workspaceDir current workspace directory path\r
141 @throws BuildException\r
142 Framework Dababase or SPD or MSA file is not valid\r
143 **/\r
144 public synchronized static void initInfo(String workspaceDatabaseFile, String workspaceDir, String toolsDefFilename ) throws BuildException {\r
145 //\r
146 // ensure this method will be revoked only once\r
147 //\r
148 if (globalFlag) {\r
149 return;\r
150 }\r
151 globalFlag = true;\r
152\r
153 //\r
154 // Backup workspace directory. It will be used by other method\r
155 //\r
156 GlobalData.workspaceDir = workspaceDir.replaceAll("(\\\\)", "/");\r
157\r
158 //\r
159 // Parse tools definition file\r
160 //\r
161 //\r
162 // If ToolChain has been set up before, do nothing.\r
163 // CONF dir + tools definition file name\r
164 //\r
165 File toolsDefFile = new File(workspaceDir + File.separatorChar + toolsDefFilename);\r
166 System.out.println("Using tool definiton file [" + toolsDefFile.getPath() + "].");\r
167 toolsDef = new ToolChainConfig(toolsDefFile);\r
168\r
169 //\r
170 // Parse Framework Database\r
171 //\r
172 File dbFile = new File(workspaceDir + File.separatorChar + workspaceDatabaseFile);\r
173 try {\r
174 FrameworkDatabaseDocument db = (FrameworkDatabaseDocument) XmlObject.Factory.parse(dbFile);\r
175 //\r
176 // validate FrameworkDatabaseFile\r
177 //\r
178 if (! db.validate()) {\r
179 throw new BuildException("Framework Database file [" + dbFile.getPath() + "] format is invalid!");\r
180 }\r
181 //\r
182 // Get package list\r
183 //\r
184 if (db.getFrameworkDatabase().getPackageList() != null ) {\r
185 List<DbPathAndFilename> packages = db.getFrameworkDatabase().getPackageList().getFilenameList();\r
186 Iterator<DbPathAndFilename> iter = packages.iterator();\r
187 while (iter.hasNext()) {\r
188 String fileName = iter.next().getStringValue();\r
189 Spd spd = new Spd(new File(workspaceDir + File.separatorChar + fileName));\r
190 packageList.add(spd.getPackageId());\r
191 spdTable.put(spd.getPackageId(), spd);\r
192 }\r
193 }\r
194\r
195 //\r
196 // Get platform list\r
197 //\r
198 if (db.getFrameworkDatabase().getPlatformList() != null) {\r
199 List<DbPathAndFilename> platforms = db.getFrameworkDatabase().getPlatformList().getFilenameList();\r
200 Iterator<DbPathAndFilename> iter = platforms.iterator();\r
201 while (iter.hasNext()) {\r
202 String fileName = iter.next().getStringValue();\r
203 File fpdFile = new File(workspaceDir + File.separatorChar + fileName);\r
204 if ( ! fpdFile.exists() ) {\r
205 throw new BuildException("Platform file [" + fpdFile.getPath() + "] not exists. ");\r
206 }\r
207 XmlObject fpdDoc = XmlObject.Factory.parse(fpdFile);\r
208 //\r
209 // Verify FPD file, if is invalid, throw Exception\r
210 //\r
211 if (! fpdDoc.validate()) {\r
212 throw new BuildException("Framework Platform Surface Area file [" + fpdFile.getPath() + "] format is invalid!");\r
213 }\r
214 //\r
215 // We can change Map to XmlObject\r
216 //\r
217 //\r
218 // TBD check SPD or FPD is existed in FS\r
219 //\r
220 Map<String, XmlObject> fpdDocMap = new HashMap<String, XmlObject>();\r
221 fpdDocMap.put("PlatformSurfaceArea", fpdDoc);\r
222 SurfaceAreaQuery.setDoc(fpdDocMap);\r
223 PlatformIdentification platformId = SurfaceAreaQuery.getFpdHeader();\r
224 platformId.setFpdFile(fpdFile);\r
225 platformList.add(platformId);\r
226 }\r
227 }\r
228 } catch (Exception e) {\r
229 throw new BuildException("Parse WORKSPACE Database file [" + dbFile.getPath() + "] Error.\n" + e.getMessage());\r
230 }\r
231 }\r
232\r
233 /**\r
234 Get the current WORKSPACE Directory.\r
235\r
236 @return current workspace directory\r
237 **/\r
238 public synchronized static String getWorkspacePath() {\r
239 return workspaceDir;\r
240 }\r
241\r
242\r
243 /**\r
244 Get the MSA file name with absolute path\r
245 */\r
246 public synchronized static File getMsaFile(ModuleIdentification moduleId) throws BuildException {\r
247 File msaFile = null;\r
248 //\r
249 // TBD. Do only when package is null.\r
250 //\r
251 Iterator iter = packageList.iterator();\r
252 while (iter.hasNext()) {\r
253 PackageIdentification packageId = (PackageIdentification)iter.next();\r
254 Spd spd = spdTable.get(packageId);\r
255 msaFile = spd.getModuleFile(moduleId);\r
256 if (msaFile != null ) {\r
257 break ;\r
258 }\r
259 }\r
260 if (msaFile == null){\r
261 throw new BuildException("Can't find Module [" + moduleId.getName() + "] in any SPD package!");\r
262 }\r
263 else {\r
264 return msaFile;\r
265 }\r
266 }\r
267\r
268 public synchronized static PackageIdentification getPackageForModule(ModuleIdentification moduleId) {\r
269 //\r
270 // If package already defined in module\r
271 //\r
272 if (moduleId.getPackage() != null) {\r
273 return moduleId.getPackage();\r
274 }\r
275\r
276 PackageIdentification packageId = null;\r
277 Iterator iter = packageList.iterator();\r
278 while (iter.hasNext()) {\r
279 packageId = (PackageIdentification)iter.next();\r
280 moduleId.setPackage(packageId);\r
281 Spd spd = spdTable.get(packageId);\r
282 if (spd.getModuleFile(moduleId) != null ) {\r
283 break ;\r
284 }\r
285 }\r
286 if (packageId == null){\r
287 throw new BuildException("Can't find Module [" + moduleId.getName() + "] in any SPD package!");\r
288 }\r
289 else {\r
290 return packageId;\r
291 }\r
292 }\r
293\r
294 /**\r
295 Difference between build and parse: ToolChain and Target\r
296 **/\r
297 public synchronized static boolean isModuleBuilt(FpdModuleIdentification moduleId) {\r
298 return builtModules.contains(moduleId);\r
299 }\r
300\r
301 public synchronized static void registerBuiltModule(FpdModuleIdentification fpdModuleId) {\r
302 builtModules.add(fpdModuleId);\r
303 }\r
304\r
305\r
306 public synchronized static void registerFpdModuleSA(FpdModuleIdentification fpdModuleId, Map<String, XmlObject> doc) {\r
307 Map<String, XmlObject> result = new HashMap<String, XmlObject>();\r
308 Set keySet = doc.keySet();\r
309 Iterator iter = keySet.iterator();\r
310 while (iter.hasNext()){\r
311 String key = (String)iter.next();\r
312 XmlObject item = cloneXmlObject(doc.get(key), true);\r
313 result.put(key, item);\r
314 }\r
315 fpdModuleSA.put(fpdModuleId, result);\r
316 }\r
317\r
318 public synchronized static boolean hasFpdModuleSA(FpdModuleIdentification fpdModuleId) {\r
319 return fpdModuleSA.containsKey(fpdModuleId);\r
320 }\r
321\r
322 /**\r
323 Query overrided module surface area information. If current is Package\r
324 or Platform build, also include the information from FPD file.\r
325\r
326 <p>Note that surface area parsing is incremental. That means the method will\r
327 only parse the MSA and MBD files if necessary. </p>\r
328\r
329 @param moduleName the base name of the module\r
330 @return the overrided module surface area information\r
331 @throws BuildException\r
332 MSA or MBD is not valid\r
333 **/\r
334 public synchronized static Map<String, XmlObject> getDoc(FpdModuleIdentification fpdModuleId) throws BuildException {\r
335 if (parsedModules.containsKey(fpdModuleId)) {\r
336 return parsedModules.get(fpdModuleId);\r
337 }\r
338 Map<String, XmlObject> doc = new HashMap<String, XmlObject>();\r
339 ModuleIdentification moduleId = fpdModuleId.getModule();\r
340 //\r
341 // First part: get the MSA files info\r
342 //\r
343 doc.putAll(getNativeMsa(moduleId));\r
344\r
345 //\r
346 // Second part: put build options\r
347 //\r
348 doc.put("BuildOptions", fpdBuildOptions);\r
349\r
350 //\r
351 // Third part: get Module info from FPD, such as Library instances, PCDs\r
352 //\r
353 if (fpdModuleSA.containsKey(fpdModuleId)){\r
354 //\r
355 // merge module info in FPD to final Doc\r
356 // For Library Module, do nothing here\r
357 //\r
358 doc.putAll(fpdModuleSA.get(fpdModuleId));\r
359 }\r
360 parsedModules.put(fpdModuleId, doc);\r
361 return doc;\r
362 }\r
363\r
364 public synchronized static Map<String, XmlObject> getDoc(ModuleIdentification moduleId, String arch) throws BuildException {\r
365 FpdModuleIdentification fpdModuleId = new FpdModuleIdentification(moduleId, arch);\r
366 return getDoc(fpdModuleId);\r
367 }\r
368 /**\r
369 Query the native MSA information with module base name.\r
370\r
371 <p>Note that MSA parsing is incremental. That means the method will\r
372 only to parse the MSA files when never parsed before. </p>\r
373\r
374 @param moduleName the base name of the module\r
375 @return the native MSA information\r
376 @throws BuildException\r
377 MSA file is not valid\r
378 **/\r
379 public synchronized static Map<String, XmlObject> getNativeMsa(ModuleIdentification moduleId) throws BuildException {\r
380 if (nativeMsa.containsKey(moduleId)) {\r
381 return nativeMsa.get(moduleId);\r
382 }\r
383 File msaFile = getMsaFile(moduleId);\r
384 Map<String, XmlObject> msaMap = getNativeMsa(msaFile);\r
385 nativeMsa.put(moduleId, msaMap);\r
386 return msaMap;\r
387 }\r
388\r
389 public synchronized static Map<String, XmlObject> getNativeMsa(File msaFile) throws BuildException {\r
390 if (! msaFile.exists()) {\r
391 throw new BuildException("Module Surface Area file [" + msaFile.getPath() + "] can't be found!");\r
392 }\r
393 try {\r
394 ModuleSurfaceAreaDocument doc = (ModuleSurfaceAreaDocument)XmlObject.Factory.parse(msaFile);\r
395 //\r
396 // Validate File if they accord with XML Schema\r
397 //\r
398 if ( ! doc.validate()){\r
399 throw new BuildException("Module Surface Area file [" + msaFile.getPath() + "] format is invalid!");\r
400 }\r
401 //\r
402 // parse MSA file\r
403 //\r
404 ModuleSurfaceArea msa= doc.getModuleSurfaceArea();\r
405 Map<String, XmlObject> msaMap = new HashMap<String, XmlObject>();\r
406 msaMap.put("MsaHeader", cloneXmlObject(msa.getMsaHeader(), true));\r
407 msaMap.put("ModuleDefinitions", cloneXmlObject(msa.getModuleDefinitions(), true));\r
408 msaMap.put("LibraryClassDefinitions", cloneXmlObject(msa.getLibraryClassDefinitions(), true));\r
409 msaMap.put("SourceFiles", cloneXmlObject(msa.getSourceFiles(), true));\r
410 msaMap.put("PackageDependencies", cloneXmlObject(msa.getPackageDependencies(), true));\r
411 msaMap.put("Protocols", cloneXmlObject(msa.getProtocols(), true));\r
412 msaMap.put("PPIs", cloneXmlObject(msa.getPPIs(), true));\r
413 msaMap.put("Guids", cloneXmlObject(msa.getGuids(), true));\r
414 msaMap.put("Externs", cloneXmlObject(msa.getExterns(), true));\r
415 msaMap.put("PcdCoded", cloneXmlObject(msa.getPcdCoded(), true));\r
416 return msaMap;\r
417 }\r
418 catch (Exception ex){\r
419 throw new BuildException(ex.getMessage());\r
420 }\r
421 }\r
422\r
423 public static Map<String, XmlObject> getFpdBuildOptions() {\r
424 Map<String, XmlObject> map = new HashMap<String, XmlObject>();\r
425 map.put("BuildOptions", fpdBuildOptions);\r
426 return map;\r
427 }\r
428\r
429 public static void setFpdBuildOptions(XmlObject fpdBuildOptions) {\r
430 GlobalData.fpdBuildOptions = cloneXmlObject(fpdBuildOptions, true);\r
431 }\r
432\r
433 public static XmlObject getFpdDynamicPcds() {\r
434 return fpdDynamicPcds;\r
435 }\r
436\r
437 public static void setFpdDynamicPcds(XmlObject fpdDynamicPcds) {\r
438 GlobalData.fpdDynamicPcds = fpdDynamicPcds;\r
439 }\r
440\r
441 //////////////////////////////////////////////\r
442 //////////////////////////////////////////////\r
443\r
444 public static Set<ModuleIdentification> getModules(PackageIdentification packageId){\r
445 Spd spd = spdTable.get(packageId);\r
446 if (spd == null ) {\r
447 Set<ModuleIdentification> dummy = new HashSet<ModuleIdentification>();\r
448 return dummy;\r
449 }\r
450 else {\r
451 return spd.getModules();\r
452 }\r
453 }\r
454\r
455 /**\r
456 * The header file path is relative to workspace dir\r
457 */\r
458 public static String[] getLibraryClassHeaderFiles(\r
459 PackageIdentification[] packages, String name)\r
460 throws BuildException {\r
461 if (packages == null) {\r
462 // throw Exception or not????\r
463 return new String[0];\r
464 }\r
465 String[] result = null;\r
466 for (int i = 0; i < packages.length; i++) {\r
467 Spd spd = spdTable.get(packages[i]);\r
468 //\r
469 // If find one package defined the library class\r
470 //\r
471 if ((result = spd.getLibClassIncluder(name)) != null) {\r
472 return result;\r
473 }\r
474 }\r
475 //\r
476 // If can't find library class declaration in every package\r
477 //\r
478 throw new BuildException("Can not find library class [" + name\r
479 + "] declaration in any SPD package!");\r
480 }\r
481\r
482 /**\r
483 * The header file path is relative to workspace dir\r
484 */\r
485 public static String getPackageHeaderFiles(PackageIdentification packages,\r
486 String moduleType) throws BuildException {\r
487 if (packages == null) {\r
488 return new String("");\r
489 }\r
490 Spd spd = spdTable.get(packages);\r
491 //\r
492 // If can't find package header file, skip it\r
493 //\r
494 String temp = null;\r
495 if (spd != null) {\r
496 if ((temp = spd.getPackageIncluder(moduleType)) != null) {\r
497 return temp;\r
498 } else {\r
499 temp = "";\r
500 return temp;\r
501 }\r
502 } else {\r
503 return null;\r
504 }\r
505 }\r
506\r
507 /**\r
508 * return two values: {cName, GuidValue}\r
509 */\r
510 public static String[] getGuid(List<PackageIdentification> packages, String name)\r
511 throws BuildException {\r
512 if (packages == null) {\r
513 // throw Exception or not????\r
514 return new String[0];\r
515 }\r
516 String[] result = null;\r
517 Iterator item = packages.iterator();\r
518 while (item.hasNext()){\r
519 Spd spd = spdTable.get(item.next());\r
520 //\r
521 // If find one package defined the GUID\r
522 //\r
523 if ((result = spd.getGuid(name)) != null) {\r
524 return result;\r
525 }\r
526 }\r
527\r
528 return null;\r
529 }\r
530\r
531 /**\r
532 * return two values: {cName, GuidValue}\r
533 */\r
534 public static String[] getPpiGuid(List<PackageIdentification> packages,\r
535 String name) throws BuildException {\r
536 if (packages == null) {\r
537 return new String[0];\r
538 }\r
539 String[] result = null;\r
540 Iterator item = packages.iterator();\r
541 while (item.hasNext()){\r
542 Spd spd = spdTable.get(item.next());\r
543 //\r
544 // If find one package defined the Ppi GUID\r
545 //\r
546 if ((result = spd.getPpi(name)) != null) {\r
547 return result;\r
548 }\r
549 }\r
550 return null;\r
551\r
552 }\r
553\r
554 /**\r
555 * return two values: {cName, GuidValue}\r
556 */\r
557 public static String[] getProtocolGuid(List<PackageIdentification> packages,\r
558 String name) throws BuildException {\r
559 if (packages == null) {\r
560 return new String[0];\r
561 }\r
562 String[] result = null;\r
563 Iterator item = packages.iterator();\r
564 while (item.hasNext()){\r
565 Spd spd = spdTable.get(item.next());\r
566 //\r
567 // If find one package defined the protocol GUID\r
568 //\r
569 if ((result = spd.getProtocol(name))!= null){\r
570 return result;\r
571 }\r
572 }\r
573 return null;\r
574\r
575 }\r
576\r
577 public synchronized static PlatformIdentification getPlatformByName(String name) throws BuildException {\r
578 Iterator iter = platformList.iterator();\r
579 while(iter.hasNext()){\r
580 PlatformIdentification platformId = (PlatformIdentification)iter.next();\r
581 if (platformId.getName().equalsIgnoreCase(name)) {\r
582 return platformId;\r
583 }\r
584 }\r
585 throw new BuildException("Can't find platform [" + name + "] in the current WORKSPACE database!");\r
586 }\r
587\r
588 public synchronized static PlatformIdentification getPlatform(String filename) throws BuildException {\r
589 File file = new File(workspaceDir + File.separatorChar + filename);\r
590 Iterator iter = platformList.iterator();\r
591 while(iter.hasNext()){\r
592 PlatformIdentification platformId = (PlatformIdentification)iter.next();\r
593 if (platformId.getFpdFile().getPath().equalsIgnoreCase(file.getPath())) {\r
594 return platformId;\r
595 }\r
596 }\r
597 throw new BuildException("Can't find platform file [" + filename + "] in the current WORKSPACE database!");\r
598 }\r
599\r
600 public synchronized static PackageIdentification refreshPackageIdentification(PackageIdentification packageId) throws BuildException {\r
601 Iterator iter = packageList.iterator();\r
602 while(iter.hasNext()){\r
603 PackageIdentification packageItem = (PackageIdentification)iter.next();\r
604 if (packageItem.equals(packageId)) {\r
605 packageId.setName(packageItem.getName());\r
606 packageId.setSpdFile(packageItem.getSpdFile());\r
607 return packageId;\r
608 }\r
609 }\r
610 throw new BuildException("Can't find package GUID value " + packageId.getGuid() + " in the current workspace!");\r
611 }\r
612\r
613 public synchronized static ModuleIdentification refreshModuleIdentification(ModuleIdentification moduleId) throws BuildException {\r
614// System.out.println("1");\r
615// System.out.println("##" + moduleId.getGuid());\r
616 PackageIdentification packageId = getPackageForModule(moduleId);\r
617// System.out.println("" + packageId.getGuid());\r
618 moduleId.setPackage(packageId);\r
619 Spd spd = spdTable.get(packageId);\r
620 if (spd == null) {\r
621 throw new BuildException("Can't find package GUID value " + packageId.getGuid() + " in the current workspace!");\r
622 }\r
623 Set<ModuleIdentification> modules = spd.getModules();\r
624 Iterator<ModuleIdentification> iter = modules.iterator();\r
625 while (iter.hasNext()) {\r
626 ModuleIdentification item = iter.next();\r
627 if (item.equals(moduleId)) {\r
628 moduleId.setName(item.getName());\r
629 moduleId.setModuleType(item.getModuleType());\r
630 moduleId.setMsaFile(item.getMsaFile());\r
631 return moduleId;\r
632 }\r
633 }\r
634 throw new BuildException("Can't find module GUID value " + moduleId.getGuid() + " in package, " + packageId + ", in the current workspace!");\r
635 }\r
636\r
637 public synchronized static Set<PackageIdentification> getPackageList(){\r
638 return packageList;\r
639 }\r
640 ///// remove!!\r
641 private static XmlObject cloneXmlObject(XmlObject object, boolean deep) throws BuildException {\r
642 if ( object == null) {\r
643 return null;\r
644 }\r
645 XmlObject result = null;\r
646 try {\r
647 result = XmlObject.Factory.parse(object.getDomNode()\r
648 .cloneNode(deep));\r
649 } catch (Exception ex) {\r
650 throw new BuildException(ex.getMessage());\r
651 }\r
652 return result;\r
653 }\r
654\r
655 ////// Tool Chain Related, try to refine and put some logic process to ToolChainFactory\r
656\r
657 public static ToolChainInfo getToolChainInfo() {\r
658// GlobalData.log.info(toolsDef.getConfigInfo() + "" + toolChainEnvInfo + toolChainPlatformInfo);\r
659 if (toolChainInfo == null) {\r
660 toolChainInfo = toolsDef.getConfigInfo().intersection(toolChainEnvInfo);\r
661 if (toolChainPlatformInfo != null) {\r
662 toolChainInfo = toolChainInfo.intersection(toolChainPlatformInfo);\r
663 }\r
664 toolChainInfo.addCommands(toolsDef.getConfigInfo().getCommands());\r
665 toolChainInfo.normalize();\r
666 GlobalData.log.info(toolChainInfo + "");\r
667 }\r
668 return toolChainInfo;\r
669 }\r
670\r
671\r
672\r
673 public static void setPlatformToolChainFamilyOption(ToolChainMap map) {\r
674 platformToolChainFamilyOption = map;\r
675 }\r
676\r
677 public static void setPlatformToolChainOption(ToolChainMap map) {\r
678 platformToolChainOption = map;\r
679 }\r
680\r
681 public static void addModuleToolChainOption(FpdModuleIdentification fpdModuleId,\r
682 ToolChainMap toolChainOption) {\r
683 moduleToolChainOption.put(fpdModuleId, toolChainOption);\r
684 }\r
685\r
686 public static void addModuleToolChainFamilyOption(FpdModuleIdentification fpdModuleId,\r
687 ToolChainMap toolChainOption) {\r
688 moduleToolChainFamilyOption.put(fpdModuleId, toolChainOption);\r
689 }\r
690\r
691 public static boolean isCommandSet(String target, String toolchain, String arch) {\r
692 String[] commands = getToolChainInfo().getCommands();\r
693\r
694 for (int i = 0; i < commands.length; ++i) {\r
695 String cmdName = toolsDef.getConfig().get(new String[] {target, toolchain, arch, commands[i], ToolChainAttribute.NAME.toString()});\r
696 if (cmdName != null && cmdName.length() != 0) {\r
697 return true;\r
698 }\r
699 }\r
700\r
701 return false;\r
702 }\r
703\r
704 public static String getCommandSetting(String[] commandDescription, FpdModuleIdentification fpdModuleId) throws EdkException {\r
705 ToolChainKey toolChainKey = new ToolChainKey(commandDescription);\r
706 ToolChainMap toolChainConfig = toolsDef.getConfig();\r
707 String setting = null;\r
708\r
709 if (!commandDescription[ToolChainElement.ATTRIBUTE.value].equals(ToolChainAttribute.FLAGS.toString())) {\r
710 setting = toolChainConfig.get(toolChainKey);\r
711 if (setting == null) {\r
712 setting = "";\r
713 }\r
714 return setting;\r
715 }\r
716\r
717 //\r
718 // get module specific options, if any\r
719 //\r
720 // tool tag first\r
721 ToolChainMap option = moduleToolChainOption.get(fpdModuleId);\r
722 ToolChainKey toolChainFamilyKey = null;\r
723\r
724 if ((option == null) || (option != null && (setting = option.get(toolChainKey)) == null)) {\r
725 //\r
726 // then tool chain family\r
727 //\r
728 toolChainFamilyKey = new ToolChainKey(commandDescription);\r
729 toolChainFamilyKey.setKey(ToolChainAttribute.FAMILY.toString(), ToolChainElement.ATTRIBUTE.value);\r
730 String family = toolChainConfig.get(toolChainFamilyKey);\r
731 toolChainFamilyKey.setKey(family, ToolChainElement.TOOLCHAIN.value);\r
732 toolChainFamilyKey.setKey(ToolChainAttribute.FLAGS.toString(), ToolChainElement.ATTRIBUTE.value);\r
733\r
734 option = moduleToolChainFamilyOption.get(fpdModuleId);\r
735 if (option != null) {\r
736 setting = option.get(toolChainFamilyKey);\r
737 }\r
738 }\r
739\r
740 //\r
741 // get platform options, if any\r
742 //\r
743 if (setting == null) {\r
744 // tool tag first\r
745 if (platformToolChainOption == null || (setting = platformToolChainOption.get(toolChainKey)) == null) {\r
746 // then tool chain family\r
747 if (toolChainFamilyKey == null) {\r
748 toolChainFamilyKey = new ToolChainKey(commandDescription);\r
749 toolChainFamilyKey.setKey(ToolChainAttribute.FAMILY.toString(), ToolChainElement.ATTRIBUTE.value);\r
750 String family = toolChainConfig.get(toolChainFamilyKey);\r
751 toolChainFamilyKey.setKey(family, ToolChainElement.TOOLCHAIN.value);\r
752 toolChainFamilyKey.setKey(ToolChainAttribute.FLAGS.toString(), ToolChainElement.ATTRIBUTE.value);\r
753 }\r
754\r
755 setting = platformToolChainFamilyOption.get(toolChainFamilyKey);\r
756 }\r
757 }\r
758\r
759 if (setting == null) {\r
760 setting = "";\r
761 }\r
762\r
763 return setting;\r
764 }\r
765\r
766 public static void setToolChainEnvInfo(ToolChainInfo envInfo) {\r
767 toolChainEnvInfo = envInfo;\r
768 }\r
769 public static void setToolChainPlatformInfo(ToolChainInfo platformInfo) {\r
770 toolChainPlatformInfo = platformInfo;\r
771 }\r
772\r
773 //\r
774 // for PCD\r
775 //\r
776 public synchronized static MemoryDatabaseManager getPCDMemoryDBManager() {\r
777 return pcdDbManager;\r
778 }\r
779\r
780 //\r
781 // For PCD get tokenSpaceGUid\r
782 //\r
783 public synchronized static String getGuidInfoFromCname(String cName){\r
784 String cNameGuid = null;\r
785 String guid = null;\r
786 Set set = spdTable.keySet();\r
787 Iterator iter = set.iterator();\r
788\r
789 if (iter == null) {\r
790 return null;\r
791 }\r
792\r
793 while (iter.hasNext()){\r
794 Spd spd = (Spd) spdTable.get(iter.next());\r
795 guid = spd.getGuidFromCname(cName);\r
796 if (guid != null){\r
797 cNameGuid = guid;\r
798 break;\r
799 }\r
800 }\r
801 return cNameGuid;\r
802 }\r
803\r
804 //\r
805 // For PCD\r
806 //\r
807 public synchronized static Map<FpdModuleIdentification, XmlObject>\r
808 getFpdModuleSaXmlObject(String xmlObjectName) {\r
809 Set<FpdModuleIdentification> fpdModuleSASet = fpdModuleSA.keySet();\r
810 Iterator item = fpdModuleSASet.iterator();\r
811\r
812\r
813 Map<FpdModuleIdentification, XmlObject> SAPcdBuildDef = new HashMap<FpdModuleIdentification, XmlObject>();\r
814 Map<String, XmlObject> SANode = new HashMap<String, XmlObject>();\r
815 FpdModuleIdentification moduleId;\r
816 while (item.hasNext()) {\r
817\r
818 moduleId = (FpdModuleIdentification) item.next();\r
819 SANode = fpdModuleSA.get(moduleId);\r
820 try{\r
821 if (SANode.get(xmlObjectName)!= null){\r
822 SAPcdBuildDef.put(moduleId,\r
823 (XmlObject) SANode.get(xmlObjectName));\r
824\r
825 }\r
826 } catch (Exception e){\r
827 EdkLog.log(EdkLog.EDK_INFO, e.getMessage());\r
828 }\r
829 }\r
830 return SAPcdBuildDef;\r
831 }\r
832\r
833 public synchronized static Map<FpdModuleIdentification,XmlObject> getFpdPcdBuildDefinitions() {\r
834 Map<FpdModuleIdentification,XmlObject> pcdBuildDef = getFpdModuleSaXmlObject ("PcdBuildDefinition");\r
835\r
836 return pcdBuildDef;\r
837 }\r
838}\r
839\r