]> git.proxmox.com Git - mirror_edk2.git/blame_incremental - Tools/Java/Source/GenBuild/org/tianocore/build/global/SurfaceAreaQuery.java
1. Fix EDKT399: "RePackagable" attribute should be supported by clone operation
[mirror_edk2.git] / Tools / Java / Source / GenBuild / org / tianocore / build / global / SurfaceAreaQuery.java
... / ...
CommitLineData
1/** @file\r
2 This file is for surface area information retrieval.\r
3\r
4 Copyright (c) 2006, Intel Corporation\r
5 All rights reserved. This program and the accompanying materials\r
6 are licensed and made available under the terms and conditions of the BSD License\r
7 which accompanies this distribution. The full text of the license may be found at\r
8 http://opensource.org/licenses/bsd-license.php\r
9\r
10 THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
11 WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
12\r
13 **/\r
14package org.tianocore.build.global;\r
15\r
16import java.util.ArrayList;\r
17import java.util.HashMap;\r
18import java.util.Iterator;\r
19import java.util.LinkedHashMap;\r
20import java.util.List;\r
21import java.util.Map;\r
22import java.util.Stack;\r
23import java.util.regex.Matcher;\r
24import java.util.regex.Pattern;\r
25\r
26import org.tianocore.ExternsDocument.Externs.Extern;\r
27import org.apache.xmlbeans.XmlObject;\r
28import org.apache.xmlbeans.XmlString;\r
29import org.tianocore.*;\r
30import org.tianocore.FilenameDocument.Filename;\r
31import org.tianocore.MsaHeaderDocument.MsaHeader;\r
32import org.tianocore.ProtocolsDocument.Protocols.Protocol;\r
33import org.tianocore.ProtocolsDocument.Protocols.ProtocolNotify;\r
34import org.tianocore.build.autogen.CommonDefinition;\r
35import org.tianocore.build.id.FpdModuleIdentification;\r
36import org.tianocore.build.id.ModuleIdentification;\r
37import org.tianocore.build.id.PackageIdentification;\r
38import org.tianocore.build.id.PlatformIdentification;\r
39import org.tianocore.build.toolchain.ToolChainInfo;\r
40import org.tianocore.common.exception.EdkException;\r
41import org.w3c.dom.Node;\r
42\r
43/**\r
44 * SurfaceAreaQuery class is used to query Surface Area information from msa,\r
45 * mbd, spd and fpd files.\r
46 *\r
47 * This class should not instantiated. All the public interfaces is static.\r
48 *\r
49 * @since GenBuild 1.0\r
50 */\r
51public class SurfaceAreaQuery {\r
52\r
53 public String prefix = "http://www.TianoCore.org/2006/Edk2.0";\r
54\r
55 //\r
56 // Contains name/value pairs of Surface Area document object. The name is\r
57 // always the top level element name.\r
58 //\r
59 private Map<String, XmlObject> map = null;\r
60\r
61 //\r
62 // mapStack is used to do nested query\r
63 //\r
64 private Stack<Map<String, XmlObject>> mapStack = new Stack<Map<String, XmlObject>>();\r
65\r
66 //\r
67 // prefix of name space\r
68 //\r
69 private String nsPrefix = "sans";\r
70\r
71 //\r
72 // xmlbeans needs a name space for each Xpath element\r
73 //\r
74 private String ns = null;\r
75\r
76 //\r
77 // keep the namep declaration for xmlbeans Xpath query\r
78 //\r
79 private String queryDeclaration = null;\r
80\r
81 private StringBuffer normQueryString = new StringBuffer(4096);\r
82 private Pattern xPathPattern = Pattern.compile("([^/]*)(/|//)([^/]+)");\r
83\r
84 /**\r
85 * Set a Surface Area document for query later\r
86 *\r
87 * @param map\r
88 * A Surface Area document in TopLevelElementName/XmlObject\r
89 * format.\r
90 */\r
91 public SurfaceAreaQuery(Map<String, XmlObject> map) {\r
92 ns = prefix;\r
93 queryDeclaration = "declare namespace " + nsPrefix + "='" + ns + "'; ";\r
94 this.map = map;\r
95 }\r
96\r
97 /**\r
98 * Push current used Surface Area document into query stack. The given new\r
99 * document will be used for any immediately followed getXXX() callings,\r
100 * untill pop() is called.\r
101 *\r
102 * @param newMap\r
103 * The TopLevelElementName/XmlObject format of a Surface Area\r
104 * document.\r
105 */\r
106 public void push(Map<String, XmlObject> newMap) {\r
107 mapStack.push(this.map);\r
108 this.map = newMap;\r
109 }\r
110\r
111 /**\r
112 * Discard current used Surface Area document and use the top document in\r
113 * stack instead.\r
114 */\r
115 public void pop() {\r
116 this.map = mapStack.pop();\r
117 }\r
118\r
119 // /\r
120 // / Convert xPath to be namespace qualified, which is necessary for\r
121 // XmlBeans\r
122 // / selectPath(). For example, converting /MsaHeader/ModuleType to\r
123 // / /ns:MsaHeader/ns:ModuleType\r
124 // /\r
125 private String normalizeQueryString(String[] exp, String from) {\r
126 normQueryString.setLength(0);\r
127\r
128 int i = 0;\r
129 while (i < exp.length) {\r
130 String newExp = from + exp[i];\r
131 Matcher matcher = xPathPattern.matcher(newExp);\r
132\r
133 while (matcher.find()) {\r
134 String starter = newExp.substring(matcher.start(1), matcher\r
135 .end(1));\r
136 String seperator = newExp.substring(matcher.start(2), matcher\r
137 .end(2));\r
138 String token = newExp.substring(matcher.start(3), matcher\r
139 .end(3));\r
140\r
141 normQueryString.append(starter);\r
142 normQueryString.append(seperator);\r
143 normQueryString.append(nsPrefix);\r
144 normQueryString.append(":");\r
145 normQueryString.append(token);\r
146 }\r
147\r
148 ++i;\r
149 if (i < exp.length) {\r
150 normQueryString.append(" | ");\r
151 }\r
152 }\r
153\r
154 return normQueryString.toString();\r
155 }\r
156\r
157 /**\r
158 * Search all XML documents stored in "map" for the specified xPath, using\r
159 * relative path (starting with '$this')\r
160 *\r
161 * @param xPath\r
162 * xpath query string array\r
163 * @returns An array of XmlObject if elements are found at the specified\r
164 * xpath\r
165 * @returns NULL if nothing is at the specified xpath\r
166 */\r
167 public Object[] get(String[] xPath) {\r
168 if (map == null) {\r
169 return null;\r
170 }\r
171\r
172 String[] keys = (String[]) map.keySet().toArray(new String[map.size()]);\r
173 List<Object> result = new ArrayList<Object>();\r
174 for (int i = 0; i < keys.length; ++i) {\r
175 XmlObject rootNode = (XmlObject) map.get(keys[i]);\r
176 if (rootNode == null) {\r
177 continue;\r
178 }\r
179\r
180 String query = queryDeclaration\r
181 + normalizeQueryString(xPath, "$this/" + keys[i]);\r
182 XmlObject[] tmp = rootNode.selectPath(query);\r
183 for (int j = 0; j < tmp.length; ++j) {\r
184 result.add((Object)tmp[j]);\r
185 }\r
186 }\r
187\r
188 int size = result.size();\r
189 if (size <= 0) {\r
190 return null;\r
191 }\r
192\r
193 return (Object[]) result.toArray(new Object[size]);\r
194 }\r
195\r
196 /**\r
197 * Search XML documents named by "rootName" for the given xPath, using\r
198 * relative path (starting with '$this')\r
199 *\r
200 * @param rootName\r
201 * The top level element name\r
202 * @param xPath\r
203 * The xpath query string array\r
204 * @returns An array of XmlObject if elements are found at the given xpath\r
205 * @returns NULL if nothing is found at the given xpath\r
206 */\r
207 public Object[] get(String rootName, String[] xPath) {\r
208 if (map == null) {\r
209 return null;\r
210 }\r
211\r
212 XmlObject root = (XmlObject) map.get(rootName);\r
213 if (root == null) {\r
214 return null;\r
215 }\r
216\r
217 String query = queryDeclaration\r
218 + normalizeQueryString(xPath, "$this/" + rootName);\r
219 XmlObject[] result = root.selectPath(query);\r
220 if (result.length > 0) {\r
221 return (Object[])result;\r
222 }\r
223\r
224 query = queryDeclaration + normalizeQueryString(xPath, "/" + rootName);\r
225 result = root.selectPath(query);\r
226 if (result.length > 0) {\r
227 return (Object[])result;\r
228 }\r
229\r
230 return null;\r
231 }\r
232\r
233 /**\r
234 * Retrieve SourceFiles/Filename for specified ARCH type\r
235 *\r
236 * @param arch\r
237 * architecture name\r
238 * @returns An 2 dimension string array if elements are found at the known\r
239 * xpath\r
240 * @returns NULL if nothing is found at the known xpath\r
241 */\r
242 public String[][] getSourceFiles(String arch) {\r
243 String[] xPath;\r
244 Object[] returns;\r
245\r
246 xPath = new String[] { "/Filename" };\r
247\r
248 returns = get("SourceFiles", xPath);\r
249\r
250 if (returns == null || returns.length == 0) {\r
251 return new String[0][3];\r
252 }\r
253\r
254 Filename[] sourceFileNames = (Filename[]) returns;\r
255 List<String[]> outputList = new ArrayList<String[]>();\r
256 for (int i = 0; i < sourceFileNames.length; i++) {\r
257 List archList = sourceFileNames[i].getSupArchList();\r
258 if (arch == null || arch.trim().equalsIgnoreCase("") || archList == null || contains(archList, arch)) {\r
259 outputList.add(new String[] {sourceFileNames[i].getToolCode(), sourceFileNames[i].getStringValue(), sourceFileNames[i].getToolChainFamily()});\r
260 }\r
261 }\r
262\r
263 String[][] outputString = new String[outputList.size()][3];\r
264 for (int index = 0; index < outputList.size(); index++) {\r
265 //\r
266 // ToolCode (FileType)\r
267 //\r
268 outputString[index][0] = outputList.get(index)[0];\r
269 //\r
270 // File name (relative to MODULE_DIR)\r
271 //\r
272 outputString[index][1] = outputList.get(index)[1];\r
273 //\r
274 // Tool chain family\r
275 //\r
276 outputString[index][2] = outputList.get(index)[2];\r
277 }\r
278 return outputString;\r
279 }\r
280\r
281 /**\r
282 * Retrieve /PlatformDefinitions/OutputDirectory from FPD\r
283 *\r
284 * @returns Directory names array if elements are found at the known xpath\r
285 * @returns Empty if nothing is found at the known xpath\r
286 */\r
287 public String getFpdOutputDirectory() {\r
288 String[] xPath = new String[] { "/PlatformDefinitions" };\r
289\r
290 Object[] returns = get("PlatformSurfaceArea", xPath);\r
291 if (returns == null || returns.length == 0) {\r
292 return null;\r
293 }\r
294 PlatformDefinitionsDocument.PlatformDefinitions item = (PlatformDefinitionsDocument.PlatformDefinitions)returns[0];\r
295 return item.getOutputDirectory();\r
296 }\r
297\r
298 public String getFpdIntermediateDirectories() {\r
299 String[] xPath = new String[] { "/PlatformDefinitions" };\r
300\r
301 Object[] returns = get("PlatformSurfaceArea", xPath);\r
302 if (returns == null || returns.length == 0) {\r
303 return "UNIFIED";\r
304 }\r
305 PlatformDefinitionsDocument.PlatformDefinitions item = (PlatformDefinitionsDocument.PlatformDefinitions)returns[0];\r
306 if(item.getIntermediateDirectories() == null) {\r
307 return null;\r
308 }\r
309 else {\r
310 return item.getIntermediateDirectories().toString();\r
311 }\r
312 }\r
313\r
314 public String getModuleFfsKeyword() {\r
315 String[] xPath = new String[] { "/" };\r
316\r
317 Object[] returns = get("ModuleSaBuildOptions", xPath);\r
318 if (returns == null || returns.length == 0) {\r
319 return null;\r
320 }\r
321 ModuleSaBuildOptionsDocument.ModuleSaBuildOptions item = (ModuleSaBuildOptionsDocument.ModuleSaBuildOptions)returns[0];\r
322 return item.getFfsFormatKey();\r
323 }\r
324\r
325 public String getModuleFvBindingKeyword() {\r
326 String[] xPath = new String[] { "/" };\r
327\r
328 Object[] returns = get("ModuleSaBuildOptions", xPath);\r
329 if (returns == null || returns.length == 0) {\r
330 return null;\r
331 }\r
332 ModuleSaBuildOptionsDocument.ModuleSaBuildOptions item = (ModuleSaBuildOptionsDocument.ModuleSaBuildOptions)returns[0];\r
333 return item.getFvBinding();\r
334 }\r
335\r
336 public List getModuleSupportedArchs() {\r
337 String[] xPath = new String[] { "/" };\r
338\r
339 Object[] returns = get("ModuleDefinitions", xPath);\r
340 if (returns == null || returns.length == 0) {\r
341 return null;\r
342 }\r
343 ModuleDefinitionsDocument.ModuleDefinitions item = (ModuleDefinitionsDocument.ModuleDefinitions)returns[0];\r
344 return item.getSupportedArchitectures();\r
345 }\r
346\r
347 public BuildOptionsDocument.BuildOptions.Ffs[] getFpdFfs() {\r
348 String[] xPath = new String[] {"/Ffs"};\r
349\r
350 Object[] returns = get("BuildOptions", xPath);\r
351 if (returns == null || returns.length == 0) {\r
352 return new BuildOptionsDocument.BuildOptions.Ffs[0];\r
353 }\r
354 return (BuildOptionsDocument.BuildOptions.Ffs[])returns;\r
355 }\r
356\r
357 public String getModuleOutputFileBasename() {\r
358 String[] xPath = new String[] { "/" };\r
359\r
360 Object[] returns = get("ModuleDefinitions", xPath);\r
361 if (returns == null || returns.length == 0) {\r
362 return null;\r
363 }\r
364 ModuleDefinitionsDocument.ModuleDefinitions item = (ModuleDefinitionsDocument.ModuleDefinitions)returns[0];\r
365 return item.getOutputFileBasename();\r
366 }\r
367\r
368 /**\r
369 * Retrieve BuildOptions/Option or Arch/Option\r
370 *\r
371 * @param toolChainFamilyFlag\r
372 * if true, retrieve options for toolchain family; otherwise for\r
373 * toolchain\r
374 *\r
375 * @returns String[][5] name, target, toolchain, arch, coommand of options\r
376 * if elements are found at the known xpath. String[0][] if dont\r
377 * find element.\r
378 *\r
379 * @returns Empty array if nothing is there\r
380 */\r
381 public String[][] getOptions(String from, String[] xPath, boolean toolChainFamilyFlag) {\r
382 String target = null;\r
383 String toolchain = null;\r
384 String toolchainFamily = null;\r
385 List<String> archList = null;\r
386 String cmd = null;\r
387 String optionName = null;\r
388\r
389 Object[] returns = get(from, xPath);\r
390 if (returns == null) {\r
391 return new String[0][5];\r
392 }\r
393\r
394 List<String[]> optionList = new ArrayList<String[]>();\r
395 OptionDocument.Option option;\r
396\r
397 for (int i = 0; i < returns.length; i++) {\r
398 option = (OptionDocument.Option) returns[i];\r
399\r
400 //\r
401 // Get Target, ToolChain(Family), Arch, Cmd, and Option from Option,\r
402 // then\r
403 // put to result[][5] array in above order.\r
404 //\r
405 String[] targetList;\r
406 if (option.getBuildTargets() == null) {\r
407 target = null;\r
408 }\r
409 else {\r
410 target = option.getBuildTargets().toString();\r
411 }\r
412 if (target != null) {\r
413 targetList = target.split(" ");\r
414 } else {\r
415 targetList = new String[1];\r
416 targetList[0] = null;\r
417 }\r
418\r
419 if (toolChainFamilyFlag) {\r
420 toolchainFamily = option.getToolChainFamily();\r
421 if (toolchainFamily != null) {\r
422 toolchain = toolchainFamily.toString();\r
423 } else {\r
424 toolchain = null;\r
425 }\r
426 } else {\r
427 toolchain = option.getTagName();\r
428 }\r
429\r
430 archList = new ArrayList<String>();\r
431 List archEnumList = option.getSupArchList();\r
432 if (archEnumList == null) {\r
433 archList.add(null);\r
434 } else {\r
435 //archList.addAll(archEnumList);\r
436 Iterator it = archEnumList.iterator();\r
437 while (it.hasNext()) {\r
438 String archType = (String)it.next();\r
439 archList.add(archType);\r
440 }\r
441 }\r
442\r
443 cmd = option.getToolCode();\r
444\r
445 optionName = option.getStringValue();\r
446 for (int t = 0; t < targetList.length; t++) {\r
447 for (int j = 0; j < archList.size(); j++) {\r
448 optionList.add(new String[] { targetList[t],\r
449 toolchain, archList.get(j), cmd, optionName});\r
450 }\r
451 }\r
452 }\r
453\r
454 String[][] result = new String[optionList.size()][5];\r
455 for (int i = 0; i < optionList.size(); i++) {\r
456 result[i][0] = optionList.get(i)[0];\r
457 result[i][1] = optionList.get(i)[1];\r
458 result[i][2] = optionList.get(i)[2];\r
459 result[i][3] = optionList.get(i)[3];\r
460 result[i][4] = optionList.get(i)[4];\r
461 }\r
462 return result;\r
463 }\r
464\r
465 public String[][] getModuleBuildOptions(boolean toolChainFamilyFlag) {\r
466 String[] xPath;\r
467\r
468 if (toolChainFamilyFlag == true) {\r
469 xPath = new String[] {\r
470 "/Options/Option[not(@ToolChainFamily) and not(@TagName)]",\r
471 "/Options/Option[@ToolChainFamily]", };\r
472 } else {\r
473 xPath = new String[] {\r
474 "/Options/Option[not(@ToolChainFamily) and not(@TagName)]",\r
475 "/Options/Option[@TagName]", };\r
476 }\r
477 return getOptions("ModuleSaBuildOptions", xPath, toolChainFamilyFlag);\r
478 }\r
479\r
480 public String[][] getPlatformBuildOptions(boolean toolChainFamilyFlag) {\r
481 String[] xPath;\r
482\r
483 if (toolChainFamilyFlag == true) {\r
484 xPath = new String[] {\r
485 "/BuildOptions/Options/Option[not(@ToolChainFamily) and not(@TagName)]",\r
486 "/BuildOptions/Options/Option[@ToolChainFamily]", };\r
487 } else {\r
488 xPath = new String[] {\r
489 "/BuildOptions/Options/Option[not(@ToolChainFamily) and not(@TagName)]",\r
490 "/BuildOptions/Options/Option[@TagName]", };\r
491 }\r
492\r
493 return getOptions("PlatformSurfaceArea", xPath, toolChainFamilyFlag);\r
494 }\r
495\r
496 public ToolChainInfo getFpdToolChainInfo() {\r
497 String[] xPath = new String[] { "/PlatformDefinitions" };\r
498\r
499 Object[] returns = get("PlatformSurfaceArea", xPath);\r
500 if (returns == null || returns.length == 0) {\r
501 return null;\r
502 }\r
503\r
504 PlatformDefinitionsDocument.PlatformDefinitions item = (PlatformDefinitionsDocument.PlatformDefinitions)returns[0];\r
505 ToolChainInfo toolChainInfo = new ToolChainInfo();\r
506 toolChainInfo.addTargets(item.getBuildTargets().toString());\r
507 toolChainInfo.addArchs(item.getSupportedArchitectures().toString());\r
508 toolChainInfo.addTagnames((String)null);\r
509 return toolChainInfo;\r
510 }\r
511\r
512 /**\r
513 * Retrieve <xxxHeader>/ModuleType\r
514 *\r
515 * @returns The module type name if elements are found at the known xpath\r
516 * @returns null if nothing is there\r
517 */\r
518 public String getModuleType() {\r
519 String[] xPath = new String[] { "/ModuleType" };\r
520\r
521 Object[] returns = get(xPath);\r
522 if (returns != null && returns.length > 0) {\r
523 ModuleTypeDef type = (ModuleTypeDef) returns[0];\r
524 return type.enumValue().toString();\r
525 }\r
526\r
527 return null;\r
528 }\r
529\r
530 /**\r
531 * Retrieve PackageDependencies/Package\r
532 *\r
533 * @param arch\r
534 * Architecture name\r
535 *\r
536 * @returns package name list if elements are found at the known xpath\r
537 * @returns null if nothing is there\r
538 */\r
539 public PackageIdentification[] getDependencePkg(String arch) throws EdkException {\r
540 String[] xPath;\r
541 String packageGuid = null;\r
542 String packageVersion = null;\r
543\r
544\r
545 xPath = new String[] { "/Package" };\r
546\r
547 Object[] returns = get("PackageDependencies", xPath);\r
548 if (returns == null) {\r
549 return new PackageIdentification[0];\r
550 }\r
551\r
552 //\r
553 // Get packageIdentification\r
554 //\r
555 List<PackageIdentification> packageIdList = new ArrayList<PackageIdentification>();\r
556 for (int i = 0; i < returns.length; i++) {\r
557 PackageDependenciesDocument.PackageDependencies.Package item = (PackageDependenciesDocument.PackageDependencies.Package) returns[i];\r
558 List archList = item.getSupArchList();\r
559 if (arch == null || archList == null || contains(archList, arch)) {\r
560 packageGuid = item.getPackageGuid();\r
561 packageVersion = item.getPackageVersion();\r
562 PackageIdentification pkgId = new PackageIdentification(null, packageGuid, packageVersion);\r
563 GlobalData.refreshPackageIdentification(pkgId);\r
564 packageIdList.add(pkgId);\r
565 }\r
566 }\r
567\r
568 return packageIdList.toArray(new PackageIdentification[packageIdList.size()]);\r
569 }\r
570\r
571 /**\r
572 * Retrieve LibraryClassDefinitions/LibraryClass for specified usage\r
573 *\r
574 * @param usage\r
575 * Library class usage\r
576 *\r
577 * @returns LibraryClass objects list if elements are found at the known\r
578 * xpath\r
579 * @returns null if nothing is there\r
580 */\r
581 public String[] getLibraryClasses(String usage, String arch) {\r
582 String[] xPath;\r
583 if (usage == null || usage.equals("")) {\r
584 xPath = new String[] { "/LibraryClass" };\r
585 } else {\r
586 xPath = new String[] { "/LibraryClass[@Usage='" + usage + "']" };\r
587 }\r
588\r
589 Object[] returns = get("LibraryClassDefinitions", xPath);\r
590 if (returns == null || returns.length == 0) {\r
591 return new String[0];\r
592 }\r
593\r
594 LibraryClassDocument.LibraryClass[] libraryClassList = (LibraryClassDocument.LibraryClass[]) returns;\r
595 List<String> libraryClassName = new ArrayList<String>();\r
596 for (int i = 0; i < libraryClassList.length; i++) {\r
597 List archList = libraryClassList[i].getSupArchList();\r
598\r
599 if (arch == null || contains(archList, arch)) {\r
600 libraryClassName.add(libraryClassList[i].getKeyword());\r
601 }\r
602 }\r
603\r
604 String[] libraryArray = new String[libraryClassName.size()];\r
605 libraryClassName.toArray(libraryArray);\r
606 return libraryArray;\r
607 }\r
608\r
609 /**\r
610 * Retrieve ModuleEntryPoint names\r
611 *\r
612 * @returns ModuleEntryPoint name list if elements are found at the known\r
613 * xpath\r
614 * @returns null if nothing is there\r
615 */\r
616 public String[] getModuleEntryPointArray() {\r
617 String[] xPath = new String[] { "/Extern/ModuleEntryPoint" };\r
618\r
619 Object[] returns = get("Externs", xPath);\r
620\r
621 if (returns != null && returns.length > 0) {\r
622 String[] entryPoints = new String[returns.length];\r
623\r
624 for (int i = 0; i < returns.length; ++i) {\r
625 entryPoints[i] = ((CNameType) returns[i]).getStringValue();\r
626 }\r
627\r
628 return entryPoints;\r
629 }\r
630\r
631 return null;\r
632 }\r
633\r
634 /**\r
635 * retrieve Protocol for specified usage\r
636 *\r
637 * @param usage\r
638 * Protocol usage arch Architecture\r
639 *\r
640 * @returns Protocol String list if elements are found at the known xpath\r
641 * @returns String[0] if nothing is there\r
642 */\r
643 public String[] getProtocolArray(String arch, String usage) {\r
644 String[] xPath;\r
645 String usageXpath = "";\r
646 String archXpath = "";\r
647\r
648 if (arch == null || arch.equals("")) {\r
649 return new String[0];\r
650 } else {\r
651 archXpath = "/Protocol";\r
652 if (usage != null && !usage.equals("")) {\r
653 usageXpath = "/Protocol[@Usage='" + usage + "']";\r
654 xPath = new String[] { usageXpath, archXpath };\r
655 } else {\r
656 return getProtocolArray(arch);\r
657 }\r
658\r
659 }\r
660\r
661 Object[] returns = get("Protocols", xPath);\r
662 if (returns == null) {\r
663 return new String[0];\r
664 }\r
665 Protocol[] protocolList = (Protocol[]) returns;\r
666\r
667 String[] protocolArray = new String[returns.length];\r
668 for (int i = 0; i < returns.length; i++) {\r
669 protocolArray[i] = protocolList[i].getProtocolCName();\r
670 }\r
671 return protocolArray;\r
672 }\r
673\r
674 /**\r
675 * retrieve Protocol for specified usage\r
676 *\r
677 * @param arch\r
678 * Architecture\r
679 *\r
680 * @returns Protocol String list if elements are found at the known xpath\r
681 * @returns String[0] if nothing is there\r
682 */\r
683 public String[] getProtocolArray(String arch) {\r
684 String[] xPath;\r
685\r
686 if (arch == null || arch.equals("")) {\r
687 return new String[0];\r
688 } else {\r
689 xPath = new String[] { "/Protocol" };\r
690 }\r
691\r
692 Object[] returns = get("Protocols", xPath);\r
693 if (returns == null) {\r
694 return new String[0];\r
695 }\r
696 Protocol[] returnlList = (Protocol[]) returns;\r
697\r
698 List<String> protocolList = new ArrayList<String>();\r
699\r
700 for (int i = 0; i < returns.length; i++) {\r
701 List archList = returnlList[i].getSupArchList();\r
702 if (archList == null || contains(archList, arch)){\r
703 protocolList.add(returnlList[i].getProtocolCName());\r
704 }\r
705 }\r
706 String[] protocolArray = new String[protocolList.size()];\r
707 for (int i = 0; i < protocolList.size(); i++) {\r
708 protocolArray[i] = protocolList.get(i);\r
709 }\r
710 return protocolArray;\r
711 }\r
712\r
713 /**\r
714 * Retrieve ProtocolNotify for specified usage\r
715 *\r
716 * @param usage\r
717 * ProtocolNotify usage\r
718 *\r
719 * @returns String[] if elements are found at the known xpath\r
720 * @returns String[0] if nothing is there\r
721 */\r
722 public String[] getProtocolNotifyArray(String arch) {\r
723 String[] xPath;\r
724\r
725 if (arch == null || arch.equals("")) {\r
726 return new String[0];\r
727 } else {\r
728 xPath = new String[] { "/ProtocolNotify" };\r
729 }\r
730\r
731 Object[] returns = get("Protocols", xPath);\r
732 if (returns == null) {\r
733 return new String[0];\r
734 }\r
735\r
736 List<String> protocolNotifyList = new ArrayList<String>();\r
737\r
738 for (int i = 0; i < returns.length; i++) {\r
739 List archList = ((ProtocolNotify) returns[i]).getSupArchList();\r
740 if (archList == null || contains(archList, arch)){\r
741 protocolNotifyList.add(((ProtocolNotify) returns[i]).getProtocolNotifyCName());\r
742 }\r
743\r
744 }\r
745 String[] protocolNotifyArray = new String[protocolNotifyList.size()];\r
746 for (int i = 0; i < protocolNotifyList.size(); i++) {\r
747 protocolNotifyArray[i] = protocolNotifyList.get(i);\r
748 }\r
749 return protocolNotifyArray;\r
750 }\r
751\r
752 /**\r
753 * Retrieve ProtocolNotify for specified usage\r
754 *\r
755 * @param usage\r
756 * ProtocolNotify usage\r
757 *\r
758 * @returns String[] if elements are found at the known xpath\r
759 * @returns String[0] if nothing is there\r
760 */\r
761 public String[] getProtocolNotifyArray(String arch, String usage) {\r
762\r
763 String[] xPath;\r
764 String usageXpath;\r
765 String archXpath;\r
766\r
767 if (arch == null || arch.equals("")) {\r
768 return new String[0];\r
769 } else {\r
770 archXpath = "/ProtocolNotify";\r
771 if (usage != null && !usage.equals("")) {\r
772 usageXpath = "/ProtocolNotify[@Usage='" + arch + "']";\r
773 xPath = new String[] { archXpath, usageXpath };\r
774 } else {\r
775 return getProtocolNotifyArray(arch);\r
776 }\r
777 }\r
778\r
779 Object[] returns = get("Protocols", xPath);\r
780 if (returns == null) {\r
781 return new String[0];\r
782 }\r
783\r
784 String[] protocolNotifyList = new String[returns.length];\r
785\r
786 for (int i = 0; i < returns.length; i++) {\r
787 protocolNotifyList[i] = ((ProtocolNotify) returns[i]).getProtocolNotifyCName();\r
788 }\r
789 return protocolNotifyList;\r
790 }\r
791\r
792 /**\r
793 * Retrieve ModuleUnloadImage names\r
794 *\r
795 * @returns ModuleUnloadImage name list if elements are found at the known\r
796 * xpath\r
797 * @returns null if nothing is there\r
798 */\r
799 public String[] getModuleUnloadImageArray() {\r
800 String[] xPath = new String[] { "/Extern/ModuleUnloadImage" };\r
801\r
802 Object[] returns = get("Externs", xPath);\r
803 if (returns != null && returns.length > 0) {\r
804 String[] stringArray = new String[returns.length];\r
805 CNameType[] doc = (CNameType[]) returns;\r
806\r
807 for (int i = 0; i < returns.length; ++i) {\r
808 stringArray[i] = doc[i].getStringValue();\r
809 }\r
810\r
811 return stringArray;\r
812 }\r
813\r
814 return null;\r
815 }\r
816\r
817 /**\r
818 * Retrieve Extern\r
819 *\r
820 * @returns Extern objects list if elements are found at the known xpath\r
821 * @returns null if nothing is there\r
822 */\r
823 public ExternsDocument.Externs.Extern[] getExternArray() {\r
824 String[] xPath = new String[] { "/Extern" };\r
825\r
826 Object[] returns = get("Externs", xPath);\r
827 if (returns != null && returns.length > 0) {\r
828 return (ExternsDocument.Externs.Extern[]) returns;\r
829 }\r
830\r
831 return null;\r
832 }\r
833\r
834 /**\r
835 * Retrieve PpiNotify for specified arch\r
836 *\r
837 * @param arch\r
838 * PpiNotify arch\r
839 *\r
840 * @returns String[] if elements are found at the known xpath\r
841 * @returns String[0] if nothing is there\r
842 */\r
843 public String[] getPpiNotifyArray(String arch) {\r
844 String[] xPath;\r
845\r
846 if (arch == null || arch.equals("")) {\r
847 return new String[0];\r
848 } else {\r
849 xPath = new String[] { "/PpiNotify" };\r
850 }\r
851\r
852 Object[] returns = get("PPIs", xPath);\r
853 if (returns == null) {\r
854 return new String[0];\r
855 }\r
856\r
857\r
858 List<String> ppiNotifyList = new ArrayList<String>();\r
859 for (int i = 0; i < returns.length; i++) {\r
860 List archList = ((PPIsDocument.PPIs.PpiNotify) returns[i]).getSupArchList();\r
861 if (archList == null || contains(archList, arch)){\r
862 ppiNotifyList.add(((PPIsDocument.PPIs.PpiNotify) returns[i]).getPpiNotifyCName());\r
863 }\r
864\r
865 }\r
866 String[] ppiNotifyArray = new String[ppiNotifyList.size()];\r
867 for (int i = 0; i < ppiNotifyList.size(); i++) {\r
868 ppiNotifyArray[i] = ppiNotifyList.get(i);\r
869 }\r
870\r
871 return ppiNotifyArray;\r
872 }\r
873\r
874 /**\r
875 * Retrieve PpiNotify for specified usage and arch\r
876 *\r
877 * @param arch\r
878 * PpiNotify arch usage PpiNotify usage\r
879 *\r
880 *\r
881 * @returns String[] if elements are found at the known xpath\r
882 * @returns String[0] if nothing is there\r
883 */\r
884 public String[] getPpiNotifyArray(String arch, String usage) {\r
885\r
886 String[] xPath;\r
887 String usageXpath;\r
888 String archXpath;\r
889\r
890 if (arch == null || arch.equals("")) {\r
891 return new String[0];\r
892 } else {\r
893 archXpath = "/PpiNotify";\r
894 if (usage != null && !usage.equals("")) {\r
895 usageXpath = "/PpiNotify[@Usage='" + arch + "']";\r
896 xPath = new String[] { archXpath, usageXpath };\r
897 } else {\r
898 return getProtocolNotifyArray(arch);\r
899 }\r
900 }\r
901\r
902 Object[] returns = get("PPIs", xPath);\r
903 if (returns == null) {\r
904 return new String[0];\r
905 }\r
906\r
907 String[] ppiNotifyList = new String[returns.length];\r
908\r
909 for (int i = 0; i < returns.length; i++) {\r
910 ppiNotifyList[i] = ((PPIsDocument.PPIs.PpiNotify) returns[i]).getPpiNotifyCName();\r
911 }\r
912 return ppiNotifyList;\r
913 }\r
914\r
915 /**\r
916 * Retrieve Ppi for specified arch\r
917 *\r
918 * @param arch\r
919 * Ppi arch\r
920 *\r
921 * @returns String[] if elements are found at the known xpath\r
922 * @returns String[0] if nothing is there\r
923 */\r
924 public String[] getPpiArray(String arch) {\r
925 String[] xPath;\r
926\r
927 if (arch == null || arch.equals("")) {\r
928 return new String[0];\r
929 } else {\r
930 xPath = new String[] { "/Ppi" };\r
931 }\r
932\r
933 Object[] returns = get("PPIs", xPath);\r
934 if (returns == null) {\r
935 return new String[0];\r
936 }\r
937\r
938 List<String> ppiList = new ArrayList<String>();\r
939 for (int i = 0; i < returns.length; i++) {\r
940 List archList = ((PPIsDocument.PPIs.Ppi) returns[i]).getSupArchList();\r
941 if (archList == null || contains(archList, arch)){\r
942 ppiList.add(((PPIsDocument.PPIs.Ppi) returns[i]).getPpiCName());\r
943 }\r
944\r
945 }\r
946 String[] ppiArray = new String[ppiList.size()];\r
947 for (int i = 0; i < ppiList.size(); i++) {\r
948 ppiArray[i] = ppiList.get(i);\r
949 }\r
950 return ppiArray;\r
951 }\r
952\r
953 /**\r
954 * Retrieve PpiNotify for specified usage and arch\r
955 *\r
956 * @param arch\r
957 * PpiNotify arch usage PpiNotify usage\r
958 *\r
959 *\r
960 * @returns String[] if elements are found at the known xpath\r
961 * @returns String[0] if nothing is there\r
962 */\r
963 public String[] getPpiArray(String arch, String usage) {\r
964\r
965 String[] xPath;\r
966 String usageXpath;\r
967 String archXpath;\r
968\r
969 if (arch == null || arch.equals("")) {\r
970 return new String[0];\r
971 } else {\r
972 archXpath = "/Ppi";\r
973 if (usage != null && !usage.equals("")) {\r
974 usageXpath = "/Ppi[@Usage='" + arch + "']";\r
975 xPath = new String[] { archXpath, usageXpath };\r
976 } else {\r
977 return getProtocolNotifyArray(arch);\r
978 }\r
979 }\r
980\r
981 Object[] returns = get("PPIs", xPath);\r
982 if (returns == null) {\r
983 return new String[0];\r
984 }\r
985\r
986 String[] ppiList = new String[returns.length];\r
987\r
988 for (int i = 0; i < returns.length; i++) {\r
989 ppiList[i] = ((PPIsDocument.PPIs.Ppi) returns[i]).getPpiCName();\r
990 }\r
991 return ppiList;\r
992 }\r
993\r
994 /**\r
995 * Retrieve GuidEntry information for specified usage\r
996 *\r
997 * @param arch\r
998 * GuidEntry arch\r
999 *\r
1000 * @returns GuidEntry objects list if elements are found at the known xpath\r
1001 * @returns null if nothing is there\r
1002 */\r
1003 public String[] getGuidEntryArray(String arch) {\r
1004 String[] xPath;\r
1005\r
1006 if (arch == null || arch.equals("")) {\r
1007 xPath = new String[] { "/GuidCNames" };\r
1008 } else {\r
1009 xPath = new String[] { "/GuidCNames" };\r
1010 }\r
1011\r
1012 Object[] returns = get("Guids", xPath);\r
1013 if (returns == null) {\r
1014 return new String[0];\r
1015 }\r
1016\r
1017 List<String> guidList = new ArrayList<String>();\r
1018 for (int i = 0; i < returns.length; i++) {\r
1019 List archList = ((GuidsDocument.Guids.GuidCNames) returns[i]).getSupArchList();\r
1020 if (archList == null || contains(archList, arch)){\r
1021 guidList.add(((GuidsDocument.Guids.GuidCNames) returns[i]).getGuidCName());\r
1022 }\r
1023\r
1024 }\r
1025 String[] guidArray = new String[guidList.size()];\r
1026 for (int i = 0; i < guidList.size(); i++) {\r
1027 guidArray[i] = guidList.get(i);\r
1028 }\r
1029 return guidArray;\r
1030\r
1031 }\r
1032\r
1033 /**\r
1034 * Retrieve GuidEntry information for specified usage\r
1035 *\r
1036 * @param arch\r
1037 * GuidEntry arch usage GuidEntry usage\r
1038 *\r
1039 * @returns GuidEntry objects list if elements are found at the known xpath\r
1040 * @returns null if nothing is there\r
1041 */\r
1042 public String[] getGuidEntryArray(String arch, String usage) {\r
1043 String[] xPath;\r
1044 String archXpath;\r
1045 String usageXpath;\r
1046\r
1047 if (arch == null || arch.equals("")) {\r
1048 return new String[0];\r
1049 } else {\r
1050 archXpath = "/GuidEntry";\r
1051 if (usage != null && !usage.equals("")) {\r
1052 usageXpath = "/GuidEntry[@Usage='" + arch + "']";\r
1053 xPath = new String[] { archXpath, usageXpath };\r
1054 } else {\r
1055 return getProtocolNotifyArray(arch);\r
1056 }\r
1057 }\r
1058\r
1059 Object[] returns = get("Guids", xPath);\r
1060 if (returns == null) {\r
1061 return new String[0];\r
1062 }\r
1063\r
1064 String[] guidList = new String[returns.length];\r
1065\r
1066 for (int i = 0; i < returns.length; i++) {\r
1067 guidList[i] = ((GuidsDocument.Guids.GuidCNames) returns[i]).getGuidCName();\r
1068 }\r
1069 return guidList;\r
1070 }\r
1071\r
1072 /**\r
1073 * Retrieve Library instance information\r
1074 *\r
1075 * @param arch\r
1076 * Architecture name\r
1077 * @param usage\r
1078 * Library instance usage\r
1079 *\r
1080 * @returns library instance name list if elements are found at the known\r
1081 * xpath\r
1082 * @returns null if nothing is there\r
1083 */\r
1084 public ModuleIdentification[] getLibraryInstance(String arch) throws EdkException {\r
1085 String[] xPath;\r
1086 String saGuid = null;\r
1087 String saVersion = null;\r
1088 String pkgGuid = null;\r
1089 String pkgVersion = null;\r
1090\r
1091 if (arch == null || arch.equalsIgnoreCase("")) {\r
1092 xPath = new String[] { "/Instance" };\r
1093 } else {\r
1094 //\r
1095 // Since Schema don't have SupArchList now, so the follow Xpath is\r
1096 // equal to "/Instance" and [not(@SupArchList) or @SupArchList= arch]\r
1097 // don't have effect.\r
1098 //\r
1099 xPath = new String[] { "/Instance[not(@SupArchList) or @SupArchList='"\r
1100 + arch + "']" };\r
1101 }\r
1102\r
1103 Object[] returns = get("Libraries", xPath);\r
1104 if (returns == null || returns.length == 0) {\r
1105 return new ModuleIdentification[0];\r
1106 }\r
1107\r
1108 ModuleIdentification[] saIdList = new ModuleIdentification[returns.length];\r
1109 for (int i = 0; i < returns.length; i++) {\r
1110 LibrariesDocument.Libraries.Instance library = (LibrariesDocument.Libraries.Instance) returns[i];\r
1111 saGuid = library.getModuleGuid();\r
1112 saVersion = library.getModuleVersion();\r
1113\r
1114 pkgGuid = library.getPackageGuid();\r
1115 pkgVersion = library.getPackageVersion();\r
1116\r
1117 ModuleIdentification saId = new ModuleIdentification(null, saGuid,\r
1118 saVersion);\r
1119 PackageIdentification pkgId = new PackageIdentification(null,\r
1120 pkgGuid, pkgVersion);\r
1121 GlobalData.refreshPackageIdentification(pkgId);\r
1122 saId.setPackage(pkgId);\r
1123 GlobalData.refreshModuleIdentification(saId);\r
1124\r
1125 saIdList[i] = saId;\r
1126\r
1127 }\r
1128 return saIdList;\r
1129 }\r
1130\r
1131 // /\r
1132 // / This method is used for retrieving the elements information which has\r
1133 // / CName sub-element\r
1134 // /\r
1135 private String[] getCNames(String from, String xPath[]) {\r
1136 Object[] returns = get(from, xPath);\r
1137 if (returns == null || returns.length == 0) {\r
1138 return null;\r
1139 }\r
1140\r
1141 String[] strings = new String[returns.length];\r
1142 for (int i = 0; i < returns.length; ++i) {\r
1143 // TBD\r
1144 strings[i] = ((CNameType) returns[i]).getStringValue();\r
1145 }\r
1146\r
1147 return strings;\r
1148 }\r
1149\r
1150 /**\r
1151 * Retrive library's constructor name\r
1152 *\r
1153 * @returns constructor name list if elements are found at the known xpath\r
1154 * @returns null if nothing is there\r
1155 */\r
1156 public String getLibConstructorName() {\r
1157 String[] xPath = new String[] { "/Extern/Constructor" };\r
1158\r
1159 Object[] returns = get("Externs", xPath);\r
1160 if (returns != null && returns.length > 0) {\r
1161 CNameType constructor = ((CNameType) returns[0]);\r
1162 return constructor.getStringValue();\r
1163 }\r
1164\r
1165 return null;\r
1166 }\r
1167\r
1168 /**\r
1169 * Retrive library's destructor name\r
1170 *\r
1171 * @returns destructor name list if elements are found at the known xpath\r
1172 * @returns null if nothing is there\r
1173 */\r
1174 public String getLibDestructorName() {\r
1175 String[] xPath = new String[] { "/Extern/Destructor" };\r
1176\r
1177 Object[] returns = get("Externs", xPath);\r
1178 if (returns != null && returns.length > 0) {\r
1179 //\r
1180 // Only support one Destructor function.\r
1181 //\r
1182 CNameType destructor = (CNameType) returns[0];\r
1183 return destructor.getStringValue();\r
1184 }\r
1185\r
1186 return null;\r
1187 }\r
1188\r
1189 /**\r
1190 * Retrive DriverBinding names\r
1191 *\r
1192 * @returns DriverBinding name list if elements are found at the known xpath\r
1193 * @returns null if nothing is there\r
1194 */\r
1195 public String[] getDriverBindingArray() {\r
1196 String[] xPath = new String[] { "/Extern/DriverBinding" };\r
1197 return getCNames("Externs", xPath);\r
1198 }\r
1199\r
1200 /**\r
1201 * Retrive ComponentName names\r
1202 *\r
1203 * @returns ComponentName name list if elements are found at the known xpath\r
1204 * @returns null if nothing is there\r
1205 */\r
1206 public String[] getComponentNameArray() {\r
1207 String[] xPath = new String[] { "/Extern/ComponentName" };\r
1208 return getCNames("Externs", xPath);\r
1209 }\r
1210\r
1211 /**\r
1212 * Retrive DriverConfig names\r
1213 *\r
1214 * @returns DriverConfig name list if elements are found at the known xpath\r
1215 * @returns null if nothing is there\r
1216 */\r
1217 public String[] getDriverConfigArray() {\r
1218 String[] xPath = new String[] { "/Extern/DriverConfig" };\r
1219 return getCNames("Externs", xPath);\r
1220 }\r
1221\r
1222 /**\r
1223 * Retrive DriverDiag names\r
1224 *\r
1225 * @returns DriverDiag name list if elements are found at the known xpath\r
1226 * @returns null if nothing is there\r
1227 */\r
1228 public String[] getDriverDiagArray() {\r
1229 String[] xPath = new String[] { "/Extern/DriverDiag" };\r
1230 return getCNames("Externs", xPath);\r
1231 }\r
1232\r
1233 /**\r
1234 * Retrive DriverBinding, ComponentName, DriverConfig,\r
1235 * DriverDiag group array\r
1236 * \r
1237 * @returns DriverBinding group name list if elements are found\r
1238 * at the known xpath\r
1239 * @returns null if nothing is there\r
1240 */\r
1241 public String[][] getExternProtocolGroup() {\r
1242 String[] xPath = new String[] {"/Extern"};\r
1243 Object[] returns = get("Externs",xPath);\r
1244\r
1245 if (returns == null) {\r
1246 return new String[0][4];\r
1247 }\r
1248 List<Extern> externList = new ArrayList<Extern>();\r
1249 for (int i = 0; i < returns.length; i++) {\r
1250 org.tianocore.ExternsDocument.Externs.Extern extern = (org.tianocore.ExternsDocument.Externs.Extern)returns[i];\r
1251 if (extern.getDriverBinding() != null) {\r
1252 externList.add(extern);\r
1253 }\r
1254 }\r
1255\r
1256 String[][] externGroup = new String[externList.size()][4];\r
1257 for (int i = 0; i < externList.size(); i++) {\r
1258 String driverBindingStr = externList.get(i).getDriverBinding();\r
1259 if ( driverBindingStr != null){\r
1260 externGroup[i][0] = driverBindingStr;\r
1261 } else {\r
1262 externGroup[i][0] = null;\r
1263 }\r
1264\r
1265 String componentNameStr = externList.get(i).getComponentName();\r
1266 if (componentNameStr != null) {\r
1267 externGroup[i][1] = componentNameStr;\r
1268 } else {\r
1269 externGroup[i][1] = null;\r
1270 }\r
1271\r
1272 String driverConfigStr = externList.get(i).getDriverConfig();\r
1273 if (driverConfigStr != null) {\r
1274 externGroup[i][2] = driverConfigStr;\r
1275 } else {\r
1276 externGroup[i][2] = null;\r
1277 }\r
1278\r
1279 String driverDiagStr = externList.get(i).getDriverDiag();\r
1280 if (driverDiagStr != null) {\r
1281 externGroup[i][3] = driverDiagStr;\r
1282 } else {\r
1283 externGroup[i][3] = null;\r
1284 }\r
1285 }\r
1286 return externGroup;\r
1287 }\r
1288 \r
1289 /**\r
1290 * Retrive SetVirtualAddressMapCallBack names\r
1291 *\r
1292 * @returns SetVirtualAddressMapCallBack name list if elements are found at\r
1293 * the known xpath\r
1294 * @returns null if nothing is there\r
1295 */\r
1296 public String[] getSetVirtualAddressMapCallBackArray() {\r
1297 String[] xPath = new String[] { "/Extern/SetVirtualAddressMapCallBack" };\r
1298 return getCNames("Externs", xPath);\r
1299 }\r
1300\r
1301 /**\r
1302 * Retrive ExitBootServicesCallBack names\r
1303 *\r
1304 * @returns ExitBootServicesCallBack name list if elements are found at the\r
1305 * known xpath\r
1306 * @returns null if nothing is there\r
1307 */\r
1308 public String[] getExitBootServicesCallBackArray() {\r
1309 String[] xPath = new String[] { "/Extern/ExitBootServicesCallBack" };\r
1310 return getCNames("Externs", xPath);\r
1311 }\r
1312\r
1313 /**\r
1314 Judge whether current driver is PEI_PCD_DRIVER or DXE_PCD_DRIVER or\r
1315 NOT_PCD_DRIVER.\r
1316 \r
1317 @return CommonDefinition.PCD_DRIVER_TYPE the type of current driver\r
1318 **/\r
1319 public CommonDefinition.PCD_DRIVER_TYPE getPcdDriverType() {\r
1320 String[] xPath = new String[] {"/PcdIsDriver"};\r
1321 Object[] results = get ("Externs", xPath);\r
1322\r
1323 if (results != null && results.length != 0) {\r
1324 PcdDriverTypes type = (PcdDriverTypes) results[0];\r
1325 String typeStr = type.enumValue().toString();\r
1326 if (typeStr.equals(CommonDefinition.PCD_DRIVER_TYPE.PEI_PCD_DRIVER.toString())) {\r
1327 return CommonDefinition.PCD_DRIVER_TYPE.PEI_PCD_DRIVER;\r
1328 } else if (typeStr.equals(CommonDefinition.PCD_DRIVER_TYPE.DXE_PCD_DRIVER.toString())) {\r
1329 return CommonDefinition.PCD_DRIVER_TYPE.DXE_PCD_DRIVER;\r
1330 }\r
1331 return CommonDefinition.PCD_DRIVER_TYPE.UNKNOWN_PCD_DRIVER;\r
1332 }\r
1333\r
1334 return CommonDefinition.PCD_DRIVER_TYPE.NOT_PCD_DRIVER;\r
1335 }\r
1336\r
1337 /**\r
1338 * Retrieve module surface area file information\r
1339 *\r
1340 * @returns ModuleSA objects list if elements are found at the known xpath\r
1341 * @returns Empty ModuleSA list if nothing is there\r
1342 */\r
1343 public Map<FpdModuleIdentification, Map<String, XmlObject>> getFpdModules() throws EdkException {\r
1344 String[] xPath = new String[] { "/FrameworkModules/ModuleSA" };\r
1345 Object[] result = get("PlatformSurfaceArea", xPath);\r
1346 String arch = null;\r
1347 String fvBinding = null;\r
1348 String saGuid = null;\r
1349 String saVersion = null;\r
1350 String pkgGuid = null;\r
1351 String pkgVersion = null;\r
1352\r
1353 Map<FpdModuleIdentification, Map<String, XmlObject>> fpdModuleMap = new LinkedHashMap<FpdModuleIdentification, Map<String, XmlObject>>();\r
1354\r
1355 if (result == null) {\r
1356 return fpdModuleMap;\r
1357 }\r
1358\r
1359 for (int i = 0; i < result.length; i++) {\r
1360 //\r
1361 // Get Fpd SA Module element node and add to ObjectMap.\r
1362 //\r
1363 Map<String, XmlObject> ObjectMap = new HashMap<String, XmlObject>();\r
1364 ModuleSADocument.ModuleSA moduleSA = (ModuleSADocument.ModuleSA) result[i];\r
1365 if (((ModuleSADocument.ModuleSA) result[i]).getLibraries() != null) {\r
1366 ObjectMap.put("Libraries", moduleSA.getLibraries());\r
1367 }\r
1368 if (((ModuleSADocument.ModuleSA) result[i]).getPcdBuildDefinition() != null) {\r
1369 ObjectMap.put("PcdBuildDefinition", moduleSA.getPcdBuildDefinition());\r
1370 }\r
1371 if (((ModuleSADocument.ModuleSA) result[i]).getModuleSaBuildOptions() != null) {\r
1372 ObjectMap.put("ModuleSaBuildOptions", moduleSA.getModuleSaBuildOptions());\r
1373 }\r
1374\r
1375 //\r
1376 // Get Fpd SA Module attribute and create FpdMoudleIdentification.\r
1377 //\r
1378 if (moduleSA.isSetSupArchList()) {\r
1379 arch = moduleSA.getSupArchList().toString();\r
1380 } else {\r
1381 arch = null;\r
1382 }\r
1383\r
1384 // TBD\r
1385 fvBinding = null;\r
1386 saVersion = ((ModuleSADocument.ModuleSA) result[i]).getModuleVersion();\r
1387\r
1388 saGuid = moduleSA.getModuleGuid();\r
1389 pkgGuid = moduleSA.getPackageGuid();\r
1390 pkgVersion = moduleSA.getPackageVersion();\r
1391\r
1392 //\r
1393 // Create Module Identification which have class member of package\r
1394 // identification.\r
1395 //\r
1396 PackageIdentification pkgId = new PackageIdentification(null, pkgGuid, pkgVersion);\r
1397 GlobalData.refreshPackageIdentification(pkgId);\r
1398 \r
1399 ModuleIdentification saId = new ModuleIdentification(null, saGuid, saVersion);\r
1400 saId.setPackage(pkgId);\r
1401 GlobalData.refreshModuleIdentification(saId);\r
1402 \r
1403\r
1404\r
1405 //\r
1406 // Create FpdModule Identification which have class member of module\r
1407 // identification\r
1408 //\r
1409 String[] archList = new String[0];\r
1410 if (arch == null || arch.trim().length() == 0) {\r
1411 archList = GlobalData.getToolChainInfo().getArchs();\r
1412 } else {\r
1413 archList = arch.split(" ");\r
1414 }\r
1415 for (int j = 0; j < archList.length; j++) {\r
1416 FpdModuleIdentification fpdSaId = new FpdModuleIdentification(saId, archList[j]);\r
1417\r
1418 if (fvBinding != null) {\r
1419 fpdSaId.setFvBinding(fvBinding);\r
1420 }\r
1421\r
1422 //\r
1423 // Put element to Map<FpdModuleIdentification, Map<String,\r
1424 // Object>>.\r
1425 //\r
1426 fpdModuleMap.put(fpdSaId, ObjectMap);\r
1427 }\r
1428 }\r
1429 return fpdModuleMap;\r
1430 }\r
1431\r
1432 /**\r
1433 * Retrieve valid image names\r
1434 *\r
1435 * @returns valid iamges name list if elements are found at the known xpath\r
1436 * @returns empty list if nothing is there\r
1437 */\r
1438 public String[] getFpdValidImageNames() {\r
1439 String[] xPath = new String[] { "/Flash/FvImages/FvImage[@Type='ImageName']/FvImageNames" };\r
1440\r
1441 Object[] queryResult = get("PlatformSurfaceArea", xPath);\r
1442 if (queryResult == null) {\r
1443 return new String[0];\r
1444 }\r
1445\r
1446 String[] result = new String[queryResult.length];\r
1447 for (int i = 0; i < queryResult.length; i++) {\r
1448 result[i] = ((XmlString) queryResult[i]).getStringValue();\r
1449 }\r
1450\r
1451 return result;\r
1452 }\r
1453\r
1454 public Node getFpdUserExtensionPreBuild() {\r
1455 String[] xPath = new String[] { "/UserExtensions[@UserID='TianoCore' and @Identifier='0']" };\r
1456\r
1457 Object[] queryResult = get("PlatformSurfaceArea", xPath);\r
1458 if (queryResult == null || queryResult.length == 0) {\r
1459 return null;\r
1460 }\r
1461 UserExtensionsDocument.UserExtensions a = (UserExtensionsDocument.UserExtensions)queryResult[0];\r
1462\r
1463 return a.getDomNode();\r
1464 }\r
1465\r
1466 public Node getFpdUserExtensionPostBuild() {\r
1467 String[] xPath = new String[] { "/UserExtensions[@UserID='TianoCore' and @Identifier='1']" };\r
1468\r
1469 Object[] queryResult = get("PlatformSurfaceArea", xPath);\r
1470 if (queryResult == null || queryResult.length == 0) {\r
1471 return null;\r
1472 }\r
1473 UserExtensionsDocument.UserExtensions a = (UserExtensionsDocument.UserExtensions)queryResult[0];\r
1474\r
1475 return a.getDomNode();\r
1476 }\r
1477\r
1478 /**\r
1479 * Retrieve FV image option information\r
1480 *\r
1481 * @param fvName\r
1482 * FV image name\r
1483 *\r
1484 * @returns option name/value list if elements are found at the known xpath\r
1485 * @returns empty list if nothing is there\r
1486 */\r
1487 public String[][] getFpdOptions(String fvName) {\r
1488 String[] xPath = new String[] { "/Flash/FvImages/FvImage[@Type='Options' and ./FvImageNames='"\r
1489 + fvName + "']/FvImageOptions" };\r
1490 Object[] queryResult = get("PlatformSurfaceArea", xPath);\r
1491 if (queryResult == null) {\r
1492 return new String[0][];\r
1493 }\r
1494 ArrayList<String[]> list = new ArrayList<String[]>();\r
1495 for (int i = 0; i < queryResult.length; i++) {\r
1496 FvImagesDocument.FvImages.FvImage.FvImageOptions item = (FvImagesDocument.FvImages.FvImage.FvImageOptions) queryResult[i];\r
1497 List<FvImagesDocument.FvImages.FvImage.FvImageOptions.NameValue> namevalues = item\r
1498 .getNameValueList();\r
1499 Iterator iter = namevalues.iterator();\r
1500 while (iter.hasNext()) {\r
1501 FvImagesDocument.FvImages.FvImage.FvImageOptions.NameValue nvItem = (FvImagesDocument.FvImages.FvImage.FvImageOptions.NameValue) iter\r
1502 .next();\r
1503 list.add(new String[] { nvItem.getName(), nvItem.getValue() });\r
1504 }\r
1505 }\r
1506 String[][] result = new String[list.size()][2];\r
1507 for (int i = 0; i < list.size(); i++) {\r
1508 result[i][0] = list.get(i)[0];\r
1509 result[i][1] = list.get(i)[1];\r
1510 }\r
1511 return result;\r
1512\r
1513 }\r
1514\r
1515 public XmlObject getFpdBuildOptions() {\r
1516 String[] xPath = new String[] { "/BuildOptions" };\r
1517\r
1518 Object[] queryResult = get("PlatformSurfaceArea", xPath);\r
1519\r
1520 if (queryResult == null || queryResult.length == 0) {\r
1521 return null;\r
1522 }\r
1523 return (XmlObject)queryResult[0];\r
1524 }\r
1525\r
1526 public PlatformIdentification getFpdHeader() {\r
1527 String[] xPath = new String[] { "/PlatformHeader" };\r
1528\r
1529 Object[] returns = get("PlatformSurfaceArea", xPath);\r
1530\r
1531 if (returns == null || returns.length == 0) {\r
1532 return null;\r
1533 }\r
1534 PlatformHeaderDocument.PlatformHeader header = (PlatformHeaderDocument.PlatformHeader) returns[0];\r
1535\r
1536 String name = header.getPlatformName();\r
1537\r
1538 String guid = header.getGuidValue();\r
1539\r
1540 String version = header.getVersion();\r
1541\r
1542 return new PlatformIdentification(name, guid, version);\r
1543 }\r
1544\r
1545 /**\r
1546 * Retrieve FV image attributes information\r
1547 *\r
1548 * @param fvName\r
1549 * FV image name\r
1550 *\r
1551 * @returns attribute name/value list if elements are found at the known\r
1552 * xpath\r
1553 * @returns empty list if nothing is there\r
1554 */\r
1555 public String[][] getFpdAttributes(String fvName) {\r
1556 String[] xPath = new String[] { "/Flash/FvImages/FvImage[@Type='Attributes' and ./FvImageNames='"\r
1557 + fvName + "']/FvImageOptions" };\r
1558 Object[] queryResult = get("PlatformSurfaceArea", xPath);\r
1559 if (queryResult == null) {\r
1560 return new String[0][];\r
1561 }\r
1562 ArrayList<String[]> list = new ArrayList<String[]>();\r
1563 for (int i = 0; i < queryResult.length; i++) {\r
1564\r
1565 FvImagesDocument.FvImages.FvImage.FvImageOptions item = (FvImagesDocument.FvImages.FvImage.FvImageOptions) queryResult[i];\r
1566 List<FvImagesDocument.FvImages.FvImage.FvImageOptions.NameValue> namevalues = item.getNameValueList();\r
1567 Iterator iter = namevalues.iterator();\r
1568 while (iter.hasNext()) {\r
1569 FvImagesDocument.FvImages.FvImage.FvImageOptions.NameValue nvItem = (FvImagesDocument.FvImages.FvImage.FvImageOptions.NameValue) iter\r
1570 .next();\r
1571 list.add(new String[] { nvItem.getName(), nvItem.getValue() });\r
1572 }\r
1573 }\r
1574 String[][] result = new String[list.size()][2];\r
1575 for (int i = 0; i < list.size(); i++) {\r
1576 result[i][0] = list.get(i)[0];\r
1577 result[i][1] = list.get(i)[1];\r
1578 }\r
1579 return result;\r
1580 }\r
1581\r
1582 /**\r
1583 * Retrieve flash definition file name\r
1584 *\r
1585 * @returns file name if elements are found at the known xpath\r
1586 * @returns null if nothing is there\r
1587 */\r
1588 public String getFlashDefinitionFile() {\r
1589 String[] xPath = new String[] { "/PlatformDefinitions/FlashDeviceDefinitions/FlashDefinitionFile" };\r
1590\r
1591 Object[] queryResult = get("PlatformSurfaceArea", xPath);\r
1592 if (queryResult == null || queryResult.length == 0) {\r
1593 return null;\r
1594 }\r
1595\r
1596 FileNameConvention filename = (FileNameConvention) queryResult[queryResult.length - 1];\r
1597 return filename.getStringValue();\r
1598 }\r
1599\r
1600 public String[][] getFpdGlobalVariable() {\r
1601 String[] xPath = new String[] { "/Flash/FvImages/NameValue" };\r
1602 Object[] queryResult = get("PlatformSurfaceArea", xPath);\r
1603 if (queryResult == null) {\r
1604 return new String[0][];\r
1605 }\r
1606\r
1607 String[][] result = new String[queryResult.length][2];\r
1608\r
1609 for (int i = 0; i < queryResult.length; i++) {\r
1610 FvImagesDocument.FvImages.NameValue item = (FvImagesDocument.FvImages.NameValue)queryResult[i];\r
1611 result[i][0] = item.getName();\r
1612 result[i][1] = item.getValue();\r
1613 }\r
1614 return result;\r
1615 }\r
1616\r
1617 /**\r
1618 * Retrieve FV image component options\r
1619 *\r
1620 * @param fvName\r
1621 * FV image name\r
1622 *\r
1623 * @returns name/value pairs list if elements are found at the known xpath\r
1624 * @returns empty list if nothing is there\r
1625 */\r
1626 public String[][] getFpdComponents(String fvName) {\r
1627 String[] xPath = new String[] { "/Flash/FvImages/FvImage[@Type='Components' and ./FvImageNames='"+ fvName + "']/FvImageOptions" };\r
1628 Object[] queryResult = get("PlatformSurfaceArea", xPath);\r
1629 if (queryResult == null) {\r
1630 return new String[0][];\r
1631 }\r
1632\r
1633 ArrayList<String[]> list = new ArrayList<String[]>();\r
1634 for (int i = 0; i < queryResult.length; i++) {\r
1635 FvImagesDocument.FvImages.FvImage.FvImageOptions item = (FvImagesDocument.FvImages.FvImage.FvImageOptions) queryResult[i];\r
1636 List<FvImagesDocument.FvImages.FvImage.FvImageOptions.NameValue> namevalues = item.getNameValueList();\r
1637 Iterator iter = namevalues.iterator();\r
1638 while (iter.hasNext()) {\r
1639 FvImagesDocument.FvImages.FvImage.FvImageOptions.NameValue nvItem = (FvImagesDocument.FvImages.FvImage.FvImageOptions.NameValue) iter\r
1640 .next();\r
1641 list.add(new String[] { nvItem.getName(), nvItem.getValue() });\r
1642 }\r
1643 }\r
1644 String[][] result = new String[list.size()][2];\r
1645 for (int i = 0; i < list.size(); i++) {\r
1646 result[i][0] = list.get(i)[0];\r
1647 result[i][1] = list.get(i)[1];\r
1648 }\r
1649 return result;\r
1650 }\r
1651\r
1652 /**\r
1653 * Retrieve PCD tokens\r
1654 *\r
1655 * @returns CName/ItemType pairs list if elements are found at the known\r
1656 * xpath\r
1657 * @returns null if nothing is there\r
1658 */\r
1659 public String[][] getPcdTokenArray() {\r
1660 String[] xPath = new String[] { "/PcdData" };\r
1661\r
1662 Object[] returns = get("PCDs", xPath);\r
1663 if (returns == null || returns.length == 0) {\r
1664 return null;\r
1665 }\r
1666\r
1667 return null;\r
1668 }\r
1669\r
1670 /**\r
1671 * Retrieve MAS header\r
1672 *\r
1673 * @return\r
1674 * @return\r
1675 */\r
1676 public ModuleIdentification getMsaHeader() {\r
1677 String[] xPath = new String[] { "/" };\r
1678 Object[] returns = get("MsaHeader", xPath);\r
1679\r
1680 if (returns == null || returns.length == 0) {\r
1681 return null;\r
1682 }\r
1683\r
1684 MsaHeader msaHeader = (MsaHeader) returns[0];\r
1685 //\r
1686 // Get BaseName, ModuleType, GuidValue, Version\r
1687 // which in MsaHeader.\r
1688 //\r
1689 String name = msaHeader.getModuleName();\r
1690 String moduleType = msaHeader.getModuleType().toString();\r
1691 String guid = msaHeader.getGuidValue();\r
1692 String version = msaHeader.getVersion();\r
1693\r
1694 ModuleIdentification moduleId = new ModuleIdentification(name, guid,\r
1695 version);\r
1696\r
1697 moduleId.setModuleType(moduleType);\r
1698\r
1699 return moduleId;\r
1700 }\r
1701\r
1702 /**\r
1703 * Retrieve Extern Specification\r
1704 *\r
1705 * @param\r
1706 *\r
1707 * @return String[] If have specification element in the <extern> String[0]\r
1708 * If no specification element in the <extern>\r
1709 *\r
1710 */\r
1711\r
1712 public String[] getExternSpecificaiton() {\r
1713 String[] xPath = new String[] { "/Specification" };\r
1714\r
1715 Object[] queryResult = get("Externs", xPath);\r
1716 if (queryResult == null) {\r
1717 return new String[0];\r
1718 }\r
1719\r
1720 String[] specificationList = new String[queryResult.length];\r
1721 for (int i = 0; i < queryResult.length; i++) {\r
1722 specificationList[i] = ((Sentence)queryResult[i])\r
1723 .getStringValue();\r
1724 }\r
1725 return specificationList;\r
1726 }\r
1727\r
1728 /**\r
1729 * Retreive MsaFile which in SPD\r
1730 *\r
1731 * @param\r
1732 * @return String[][3] The string sequence is ModuleName, ModuleGuid,\r
1733 * ModuleVersion, MsaFile String[0][] If no msafile in SPD\r
1734 */\r
1735 public String[] getSpdMsaFile() {\r
1736 String[] xPath = new String[] { "/MsaFiles" };\r
1737\r
1738 Object[] returns = get("PackageSurfaceArea", xPath);\r
1739 if (returns == null) {\r
1740 return new String[0];\r
1741 }\r
1742\r
1743 List<String> filenameList = ((MsaFilesDocument.MsaFiles) returns[0])\r
1744 .getFilenameList();\r
1745 return filenameList.toArray(new String[filenameList.size()]);\r
1746 }\r
1747\r
1748 /**\r
1749 * Reteive\r
1750 */\r
1751 public Map<String, String[]> getSpdLibraryClasses() {\r
1752 String[] xPath = new String[] { "/LibraryClassDeclarations/LibraryClass" };\r
1753\r
1754 Object[] returns = get("PackageSurfaceArea", xPath);\r
1755\r
1756 //\r
1757 // Create Map, Key - LibraryClass, String[] - LibraryClass Header file.\r
1758 //\r
1759 Map<String, String[]> libClassHeaderMap = new HashMap<String, String[]>();\r
1760\r
1761 if (returns == null) {\r
1762 return libClassHeaderMap;\r
1763 }\r
1764\r
1765 for (int i = 0; i < returns.length; i++) {\r
1766 LibraryClassDeclarationsDocument.LibraryClassDeclarations.LibraryClass library = (LibraryClassDeclarationsDocument.LibraryClassDeclarations.LibraryClass) returns[i];\r
1767 libClassHeaderMap.put(library.getName(), new String[] { library\r
1768 .getIncludeHeader() });\r
1769 }\r
1770 return libClassHeaderMap;\r
1771 }\r
1772\r
1773 /**\r
1774 * Reteive\r
1775 */\r
1776 public Map<String, String> getSpdPackageHeaderFiles() {\r
1777 String[] xPath = new String[] { "/PackageHeaders/IncludePkgHeader" };\r
1778\r
1779 Object[] returns = get("PackageSurfaceArea", xPath);\r
1780\r
1781 //\r
1782 // Create Map, Key - ModuleType, String - PackageInclude Header file.\r
1783 //\r
1784 Map<String, String> packageIncludeMap = new HashMap<String, String>();\r
1785\r
1786 if (returns == null) {\r
1787 return packageIncludeMap;\r
1788 }\r
1789\r
1790 for (int i = 0; i < returns.length; i++) {\r
1791 PackageHeadersDocument.PackageHeaders.IncludePkgHeader includeHeader = (PackageHeadersDocument.PackageHeaders.IncludePkgHeader) returns[i];\r
1792 packageIncludeMap.put(includeHeader.getModuleType().toString(),\r
1793 includeHeader.getStringValue());\r
1794 }\r
1795 return packageIncludeMap;\r
1796 }\r
1797\r
1798 public PackageIdentification getSpdHeader() {\r
1799 String[] xPath = new String[] { "/SpdHeader" };\r
1800\r
1801 Object[] returns = get("PackageSurfaceArea", xPath);\r
1802\r
1803 if (returns == null || returns.length == 0) {\r
1804 return null;\r
1805 }\r
1806\r
1807 SpdHeaderDocument.SpdHeader header = (SpdHeaderDocument.SpdHeader) returns[0];\r
1808\r
1809 String name = header.getPackageName();\r
1810\r
1811 String guid = header.getGuidValue();\r
1812\r
1813 String version = header.getVersion();\r
1814\r
1815 return new PackageIdentification(name, guid, version);\r
1816 }\r
1817\r
1818 /**\r
1819 * Reteive\r
1820 */\r
1821 public Map<String, String[]> getSpdGuid() {\r
1822 String[] xPath = new String[] { "/GuidDeclarations/Entry" };\r
1823\r
1824 Object[] returns = get("PackageSurfaceArea", xPath);\r
1825\r
1826 //\r
1827 // Create Map, Key - GuidName, String[] - C_NAME & GUID value.\r
1828 //\r
1829 Map<String, String[]> guidDeclMap = new HashMap<String, String[]>();\r
1830 if (returns == null) {\r
1831 return guidDeclMap;\r
1832 }\r
1833\r
1834 for (int i = 0; i < returns.length; i++) {\r
1835 GuidDeclarationsDocument.GuidDeclarations.Entry entry = (GuidDeclarationsDocument.GuidDeclarations.Entry) returns[i];\r
1836 String[] guidPair = new String[2];\r
1837 guidPair[0] = entry.getCName();\r
1838 guidPair[1] = entry.getGuidValue();\r
1839 guidDeclMap.put(entry.getCName(), guidPair);\r
1840 }\r
1841 return guidDeclMap;\r
1842 }\r
1843\r
1844 /**\r
1845 * Reteive\r
1846 */\r
1847 public Map<String, String[]> getSpdProtocol() {\r
1848 String[] xPath = new String[] { "/ProtocolDeclarations/Entry" };\r
1849\r
1850 Object[] returns = get("PackageSurfaceArea", xPath);\r
1851\r
1852 //\r
1853 // Create Map, Key - protocolName, String[] - C_NAME & GUID value.\r
1854 //\r
1855 Map<String, String[]> protoclMap = new HashMap<String, String[]>();\r
1856\r
1857 if (returns == null) {\r
1858 return protoclMap;\r
1859 }\r
1860\r
1861 for (int i = 0; i < returns.length; i++) {\r
1862 ProtocolDeclarationsDocument.ProtocolDeclarations.Entry entry = (ProtocolDeclarationsDocument.ProtocolDeclarations.Entry) returns[i];\r
1863 String[] protocolPair = new String[2];\r
1864\r
1865 protocolPair[0] = entry.getCName();\r
1866 protocolPair[1] = entry.getGuidValue();\r
1867 protoclMap.put(entry.getCName(), protocolPair);\r
1868 }\r
1869 return protoclMap;\r
1870 }\r
1871\r
1872 /**\r
1873 * getSpdPpi() Retrieve the SPD PPI Entry\r
1874 *\r
1875 * @param\r
1876 * @return Map<String, String[2]> if get the PPI entry from SPD. Key - PPI\r
1877 * Name String[0] - PPI CNAME String[1] - PPI Guid Null if no PPI\r
1878 * entry in SPD.\r
1879 */\r
1880 public Map<String, String[]> getSpdPpi() {\r
1881 String[] xPath = new String[] { "/PpiDeclarations/Entry" };\r
1882\r
1883 Object[] returns = get("PackageSurfaceArea", xPath);\r
1884\r
1885 //\r
1886 // Create Map, Key - protocolName, String[] - C_NAME & GUID value.\r
1887 //\r
1888 Map<String, String[]> ppiMap = new HashMap<String, String[]>();\r
1889\r
1890 if (returns == null) {\r
1891 return ppiMap;\r
1892 }\r
1893\r
1894 for (int i = 0; i < returns.length; i++) {\r
1895 PpiDeclarationsDocument.PpiDeclarations.Entry entry = (PpiDeclarationsDocument.PpiDeclarations.Entry) returns[i];\r
1896 String[] ppiPair = new String[2];\r
1897 ppiPair[0] = entry.getCName();\r
1898 ppiPair[1] = entry.getGuidValue();\r
1899 ppiMap.put(entry.getCName(), ppiPair);\r
1900 }\r
1901 return ppiMap;\r
1902 }\r
1903\r
1904 /**\r
1905 * Retrieve module Guid string\r
1906 *\r
1907 * @returns GUILD string if elements are found at the known xpath\r
1908 * @returns null if nothing is there\r
1909 */\r
1910 public String getModuleGuid() {\r
1911 String[] xPath = new String[] { "" };\r
1912\r
1913 Object[] returns = get("MsaHeader", xPath);\r
1914 if (returns != null && returns.length > 0) {\r
1915 String guid = ((MsaHeaderDocument.MsaHeader) returns[0])\r
1916 .getGuidValue();\r
1917 return guid;\r
1918 }\r
1919\r
1920 return null;\r
1921 }\r
1922\r
1923 //\r
1924 // For new Pcd\r
1925 //\r
1926 public ModuleSADocument.ModuleSA[] getFpdModuleSAs() {\r
1927 String[] xPath = new String[] { "/FrameworkModules/ModuleSA" };\r
1928 Object[] result = get("PlatformSurfaceArea", xPath);\r
1929 if (result != null) {\r
1930 return (ModuleSADocument.ModuleSA[]) result;\r
1931 }\r
1932 return new ModuleSADocument.ModuleSA[0];\r
1933\r
1934 }\r
1935 /**\r
1936 Get name array of PCD in a module. In one module, token space\r
1937 is same, and token name should not be conflicted.\r
1938\r
1939 @return String[]\r
1940 **/\r
1941 public String[] getModulePcdEntryNameArray() {\r
1942 PcdCodedDocument.PcdCoded.PcdEntry[] pcdEntries = null;\r
1943 String[] results;\r
1944 int index;\r
1945 String[] xPath = new String[] {"/PcdEntry"};\r
1946 Object[] returns = get ("PcdCoded", xPath);\r
1947\r
1948 if (returns == null) {\r
1949 return new String[0];\r
1950 }\r
1951\r
1952 pcdEntries = (PcdCodedDocument.PcdCoded.PcdEntry[])returns;\r
1953 results = new String[pcdEntries.length];\r
1954\r
1955 for (index = 0; index < pcdEntries.length; index ++) {\r
1956 results[index] = pcdEntries[index].getCName();\r
1957 }\r
1958 return results;\r
1959 }\r
1960\r
1961 /**\r
1962 Search in a List for a given string\r
1963\r
1964 @return boolean\r
1965 **/\r
1966 public boolean contains(List list, String str) {\r
1967 if (list == null || list.size()== 0) {\r
1968 return true;\r
1969 }\r
1970 Iterator it = list.iterator();\r
1971 while (it.hasNext()) {\r
1972 String s = (String)it.next();\r
1973 if (s.equalsIgnoreCase(str)) {\r
1974 return true;\r
1975 }\r
1976 }\r
1977\r
1978 return false;\r
1979 }\r
1980\r
1981 public boolean isHaveTianoR8FlashMap(){\r
1982 String[] xPath = new String[] {"/"};\r
1983 Object[] returns = get ("Externs", xPath);\r
1984\r
1985 if (returns == null) {\r
1986 return false;\r
1987 }\r
1988\r
1989 ExternsDocument.Externs ext = (ExternsDocument.Externs)returns[0];\r
1990\r
1991 if (ext.getTianoR8FlashMapH()){\r
1992 return true;\r
1993 }else {\r
1994 return false;\r
1995 }\r
1996 }\r
1997 \r
1998 public Node getFpdModuleSequence(String fvName) {\r
1999 String[] xPath = new String[] { "/BuildOptions/UserExtensions[@UserID='IMAGES' and @Identifier='1' and ./FvName='" + fvName + "']" };\r
2000 Object[] result = get("PlatformSurfaceArea", xPath);\r
2001 \r
2002 if (result == null || result.length == 0) {\r
2003 return null;\r
2004 }\r
2005 \r
2006 UserExtensionsDocument.UserExtensions a = (UserExtensionsDocument.UserExtensions)result[0];\r
2007 \r
2008 return a.getDomNode();\r
2009 }\r
2010}\r