summaryrefslogtreecommitdiff
path: root/Tools/Java/Source
diff options
context:
space:
mode:
authorlhauch <lhauch@6f19259b-4bc3-4df7-8a09-765794883524>2006-10-25 16:17:28 +0000
committerlhauch <lhauch@6f19259b-4bc3-4df7-8a09-765794883524>2006-10-25 16:17:28 +0000
commit4de927647804b8ae7bc214dd7f9fd5eaf45853d1 (patch)
treed1c1c503b0b78ceb3c1e9a65fc7ed0c95ebe604f /Tools/Java/Source
parente1869179c62a6542dbbe559e418e55e50cdbd3cd (diff)
downloadedk2-platforms-4de927647804b8ae7bc214dd7f9fd5eaf45853d1.tar.xz
Added the DbTools that will update the FrameworkDatabase.db file based on what is found after scanning the WORKSPACE environment - entries for new SPD and FPD files that are found during the scan are added, and the entries for SPD and FPD files that are listed in the database, but are not in the current workspace are deleted.
Modified AllResource to include only files that are not compiled. Added the MSA entries to the SPD file for all modules that are compiled, both Java and C. git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@1839 6f19259b-4bc3-4df7-8a09-765794883524
Diffstat (limited to 'Tools/Java/Source')
-rw-r--r--Tools/Java/Source/CheckTools/CheckTools.msa39
-rw-r--r--Tools/Java/Source/CheckTools/src/org/tianocore/CheckTools/CheckTools.java154
-rw-r--r--Tools/Java/Source/CheckTools/src/org/tianocore/CheckTools/ToolChecks.java757
-rw-r--r--Tools/Java/Source/CheckTools/src/org/tianocore/CheckTools/ToolInfo.java185
-rw-r--r--Tools/Java/Source/ContextTool/ContextTool.msa31
-rw-r--r--Tools/Java/Source/DbTools/DbTools.msa31
-rw-r--r--Tools/Java/Source/DbTools/build.xml42
-rw-r--r--Tools/Java/Source/DbTools/src/org/tianocore/DbTools/DbCmds.java501
-rw-r--r--Tools/Java/Source/DbTools/src/org/tianocore/DbTools/DbTool.java24
-rw-r--r--Tools/Java/Source/DbTools/src/org/tianocore/DbTools/UpdateDb.java557
-rw-r--r--Tools/Java/Source/Merge/Merge.msa18
11 files changed, 2243 insertions, 96 deletions
diff --git a/Tools/Java/Source/CheckTools/CheckTools.msa b/Tools/Java/Source/CheckTools/CheckTools.msa
new file mode 100644
index 0000000000..bcda84307e
--- /dev/null
+++ b/Tools/Java/Source/CheckTools/CheckTools.msa
@@ -0,0 +1,39 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<ModuleSurfaceArea xmlns="http://www.TianoCore.org/2006/Edk2.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
+ <MsaHeader>
+ <ModuleName>Check Tool Definitions</ModuleName>
+ <ModuleType>TOOL</ModuleType>
+ <GuidValue>015250d4-e7e2-452f-a6aa-c8be46acbfc7</GuidValue>
+ <Version>0.1</Version>
+ <Abstract>The tool checks the active tool definition file to verify tools exists</Abstract>
+ <Description>
+This tool will verify the tool chain configuration file to verify that the directories and programs exist.
+It will also check to see if an ACPI compiler has been defined for tool chain tag names - if not, then it prints a warning.
+It also checks the assembler to see if it exists, and where.
+The quiet option will not print anything.
+The return values are:
+ 0 - PASS
+ 1 - FAIL
+
+USAGE:
+checkTools [-h] [-d] [-i] [-v] [-s | -scan] [-t | -test] [-q | -quiet] [[-f | -filename] filename.txt]</Description>
+ <Copyright>Copyright (c) 2006, Intel Corporation All rights reserved.</Copyright>
+ <License URL="http://opensource.org/licenses/bsd-license.php">This program and the accompanying materials are licensed and made available under the terms and conditions of the BSD License which accompanies this distribution. The full text of the license may be found at http://opensource.org/licenses/bsd-license.php
+
+THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
+WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.</License>
+ <Specification>FRAMEWORK_BUILD_PACKAGING_SPECIFICATION 0x00000052</Specification>
+ </MsaHeader>
+ <ModuleDefinitions>
+ <SupportedArchitectures>EBC IA32 X64 IPF ARM PPC</SupportedArchitectures>
+ <BinaryModule>false</BinaryModule>
+ <OutputFileBasename>Merge</OutputFileBasename>
+ </ModuleDefinitions>
+ <SourceFiles>
+ <Filename>src/org/tianocore/CheckTools/ToolChecks.java</Filename>
+ <Filename>src/org/tianocore/CheckTools/ToolInfo.java</Filename>
+ <Filename>src/org/tianocore/CheckTools/CheckTools.java</Filename>
+ <Filename>build.xml</Filename>
+ <Filename>readme.txt</Filename>
+ </SourceFiles>
+</ModuleSurfaceArea>
diff --git a/Tools/Java/Source/CheckTools/src/org/tianocore/CheckTools/CheckTools.java b/Tools/Java/Source/CheckTools/src/org/tianocore/CheckTools/CheckTools.java
index a7b55279d2..7c0a26be8d 100644
--- a/Tools/Java/Source/CheckTools/src/org/tianocore/CheckTools/CheckTools.java
+++ b/Tools/Java/Source/CheckTools/src/org/tianocore/CheckTools/CheckTools.java
@@ -34,6 +34,11 @@
* a file that was specified in target.txt
*
* -t = TEST can be used with -f or -s, not with -i.
+ *
+ * -d = DUMP can be used with -f, not with -i
+ *
+ * -q = QUIET - turns off all System.out.print statements, the return code
+ * is the only thing that will determine PASS or FAIL
*
*/
package org.tianocore.CheckTools;
@@ -49,28 +54,35 @@ public class CheckTools {
private int VERBOSE = 0;
+ private boolean QUIET = false;
+
// private String argv[];
-
+
private final int DEFAULT = 1;
private final int TEST = 2;
private final int SCAN = 4;
- private final int INTERACTIVE = 8;
+ private final int DUMP = 8;
+
+ private final int INTERACTIVE = 16;
private boolean USERFILE = false;
private String inFile = "";
-
+
private final int PASS = 0;
-
+
private final int FAIL = 1;
private String SEP = System.getProperty("file.separator");
public static void main(String[] argv) {
- int exitCode = new CheckTools().checkTool(argv);
+ CheckTools cts = new CheckTools();
+ int exitCode = cts.checkTool(argv);
+ if (DEBUG > 10)
+ System.out.println("Exit Code: " + exitCode);
if (exitCode == -1) {
new CheckTools().usage();
System.exit(1);
@@ -79,57 +91,48 @@ public class CheckTools {
}
private int checkTool(String[] arguments) {
- String WORKSPACE = System.getenv("WORKSPACE");
- if ((DEBUG > 0) || (VERBOSE > 0))
- System.out.println("Verifying Tool Chains for WORKSPACE: " + WORKSPACE);
- int returnCode = 0;
-
- if (WORKSPACE == null) {
- System.out.println("Please set the environment variable, WORKSPACE and run again.");
- System.exit(FAIL);
- }
- String targetTxt = WORKSPACE + SEP + "Tools" + SEP + "Conf" + SEP + "target.txt";
-
if ((DEBUG > 1) && (arguments.length > 0))
System.out.println("Arguments: ");
int cmdCode = DEFAULT;
if (arguments.length > 0) {
cmdCode = DEFAULT;
+ for (int i = 0; i < arguments.length; i++)
+ if (arguments[i].toLowerCase().startsWith("-q"))
+ QUIET = true;
for (int i = 0; i < arguments.length; i++) {
String arg = arguments[i];
if (DEBUG > 1)
System.out.println(" [" + i + "] " + arg);
if (!(arg.toLowerCase().startsWith("-t") || arg.toLowerCase().startsWith("-s")
- || arg.toLowerCase().startsWith("-i") || arg.toLowerCase().startsWith("-v")
+ || arg.toLowerCase().startsWith("-d") || arg.toLowerCase().startsWith("-i")
+ || arg.toLowerCase().startsWith("-v") || arg.toLowerCase().startsWith("-q")
|| arg.toLowerCase().startsWith("-h") || arg.toLowerCase().startsWith("-f"))) {
// Only allow valid option flags
- System.out.println("Invalid argument: " + arg);
- usage();
+ if (QUIET == false) {
+ System.out.println("Invalid argument: " + arg);
+ usage();
+ }
System.exit(FAIL);
}
- if (arg.toLowerCase().startsWith("-h")) {
- usage();
- System.exit(PASS);
- }
-
- if (arg.toLowerCase().startsWith("-t")) {
+ if (arg.toLowerCase().startsWith("-d")) {
if (cmdCode == DEFAULT) {
- cmdCode = TEST;
+ cmdCode = DUMP;
} else {
- System.out.println("Invalid Options");
+ if (QUIET == false)
+ System.out.println("Invalid Options");
usage();
System.exit(FAIL);
}
}
- if (arg.toLowerCase().startsWith("-s")) {
- if (cmdCode == DEFAULT) {
- cmdCode = SCAN;
- } else {
- System.out.println("Invalid Options");
- usage();
- System.exit(FAIL);
- }
+ if (arg.toLowerCase().startsWith("-f")) {
+ i++;
+ inFile = arguments[i];
+ USERFILE = true;
+ }
+ if (arg.toLowerCase().startsWith("-h")) {
+ usage();
+ System.exit(PASS);
}
if (arg.toLowerCase().startsWith("-i")) {
// Interactive can be specified with any
@@ -137,10 +140,30 @@ public class CheckTools {
// on fail mode.
cmdCode = cmdCode | INTERACTIVE;
}
- if (arg.toLowerCase().startsWith("-f")) {
- i++;
- inFile = arguments[i];
- USERFILE = true;
+ if (arg.toLowerCase().startsWith("-q")) {
+ QUIET = true;
+ }
+ if (arg.toLowerCase().startsWith("-s")) {
+ if (cmdCode == DEFAULT) {
+ cmdCode = SCAN;
+ } else {
+ if (!QUIET) {
+ System.out.println("Invalid Options");
+ usage();
+ }
+ System.exit(FAIL);
+ }
+ }
+ if (arg.toLowerCase().startsWith("-t")) {
+ if (cmdCode == DEFAULT) {
+ cmdCode = TEST;
+ } else {
+ if (!QUIET) {
+ System.out.println("Invalid Options");
+ usage();
+ }
+ System.exit(FAIL);
+ }
}
if (arg.startsWith("-v")) {
// Verbose level can be increased to print
@@ -148,13 +171,30 @@ public class CheckTools {
VERBOSE += 1;
}
if (arg.startsWith("-V")) {
- System.out.println(copyright);
- System.out.println("CheckTools, " + version);
+ if (!QUIET) {
+ System.out.println(copyright);
+ System.out.println("CheckTools, " + version);
+ }
System.exit(PASS);
}
}
}
-
+ if (QUIET)
+ VERBOSE = 0;
+
+ String WORKSPACE = System.getenv("WORKSPACE");
+ if ((DEBUG > 0) || (VERBOSE > 0))
+ System.out.println("Verifying Tool Chains for WORKSPACE: " + WORKSPACE);
+ int returnCode = 0;
+
+ if (WORKSPACE == null) {
+ if (QUIET == false)
+ System.out.println("Please set the environment variable, WORKSPACE and run again.");
+ System.exit(FAIL);
+ }
+ String targetTxt = WORKSPACE + SEP + "Tools" + SEP + "Conf" + SEP + "target.txt";
+
+
if (inFile.length() < 1) {
//
// Check the target.txt file for a Tool Configuration File.
@@ -183,7 +223,8 @@ public class CheckTools {
}
bufReader.close();
} catch (IOException e) {
- System.out.println(" [target.txt] Read Error: " + e);
+ if (QUIET == false)
+ System.out.println(" [target.txt] Read Error: " + e);
System.exit(FAIL);
}
}
@@ -195,18 +236,22 @@ public class CheckTools {
if (!toolsFile.exists()) {
// use the template file
if (USERFILE) {
- System.out.println("Could not locate the specified file: " + inFile);
- System.out.println(" It must be located in the WORKSPACE" + SEP + "Tools" + SEP + "Conf directory");
+ if (QUIET == false) {
+ System.out.println("Could not locate the specified file: " + inFile);
+ System.out.println(" It must be located in the WORKSPACE" + SEP + "Tools" + SEP + "Conf directory");
+ }
System.exit(FAIL);
}
toolsDef = WORKSPACE + SEP + "Tools" + SEP + "Conf" + SEP + "tools_def.template";
File toolsTemplate = new File(toolsDef);
if (!toolsTemplate.exists()) {
- System.out.println("Your WORKSPACE is not properly configured!");
+ if (QUIET == false)
+ System.out.println("Your WORKSPACE is not properly configured!");
System.exit(FAIL);
} else {
- System.out.println("**** WARNING: No Tool Configuration File was found, using the template file, "
- + toolsDef);
+ if (QUIET == false)
+ System.out.println("**** WARNING: No Tool Configuration File was found, using the template file, "
+ + toolsDef);
}
}
@@ -216,20 +261,29 @@ public class CheckTools {
// check tool configuration file
if (DEBUG > 2)
System.out.println("Calling checkTools(" + toolsDef + ", " + cmdCode + ", " + VERBOSE + ")");
- returnCode = new ToolChecks().checkTools(toolsDef, cmdCode, VERBOSE);
+ ToolChecks tc = new ToolChecks();
+ returnCode = tc.checkTools(toolsDef, cmdCode, VERBOSE, QUIET);
+ if (VERBOSE > 10)
+ System.out.println(" checkTools returned: " + returnCode);
return returnCode;
}
private void usage() {
- System.out.println("Usage: checkTools [-h] [-i] [-v] [-s | -scan] [-t | -test] [[-f | -filename] filename.txt]");
+ if (QUIET)
+ return;
+ System.out
+ .println("Usage: checkTools [-h] [-d] [-i] [-v] [-s | -scan] [-t | -test] [-q | -quiet] [[-f | -filename] filename.txt]");
System.out.println(" Where");
System.out.println(" -h Help - display this screen.");
+ System.out.println(" -d Dump - display the tool defintion file in user readable format");
System.out.println(" -i Interactive query - not yet implemented!");
System.out.println(" -v Verbose - add up to 3 -v options to increase info messages.");
System.out.println(" -s Scan - search the usual places on your system for tools.");
System.out.println(" The Scan feature not yet implemented!.");
System.out.println(" -t Test - checks that PATH entries in the tool configuration file exist.");
+ System.out
+ .println(" -q Quiet - no messages get printed, the return value determines pass or fail.");
System.out.println(" -f filename Use filename instead of the file specified in target.txt or");
System.out.println(" tools_def.txt or tools_def.template.");
System.out.println(" By Rule, all tool configuration files must reside in the");
diff --git a/Tools/Java/Source/CheckTools/src/org/tianocore/CheckTools/ToolChecks.java b/Tools/Java/Source/CheckTools/src/org/tianocore/CheckTools/ToolChecks.java
index 5dbd5c54df..59cc336fd9 100644
--- a/Tools/Java/Source/CheckTools/src/org/tianocore/CheckTools/ToolChecks.java
+++ b/Tools/Java/Source/CheckTools/src/org/tianocore/CheckTools/ToolChecks.java
@@ -46,46 +46,66 @@ public class ToolChecks {
private final int SCAN = 4;
- private final int INTERACTIVE = 8;
+ private final int DUMP = 8;
+
+ private final int INTERACTIVE = 16;
private final int PASS = 0;
private final int FAIL = 1;
-
+
private ArrayList<String> errLog = new ArrayList<String>();
-
+
private ArrayList<String> goodLog = new ArrayList<String>();
- public int checkTools(String toolConfFile, int cmdCode, int VERBOSE) {
+ private ArrayList<String> warnLog = new ArrayList<String>();
+
+ public int checkTools(String toolConfFile, int cmdCode, int VERBOSE, boolean QUIET) {
int returnCode = FAIL;
boolean interActive = false;
if ((DEBUG > 0) || (VERBOSE > 0)) {
- System.out.println("Using Tool Configuration File: " + toolConfFile);
+ if ((cmdCode & DUMP) == DUMP)
+ System.out.print("Using Tool Configuration File: " + toolConfFile + " ");
+ else
+ System.out.println("Using Tool Configuration File: " + toolConfFile);
}
-
+
if (DEBUG > 2)
System.out.println("The cmdCode: " + cmdCode);
-
+
if ((cmdCode & INTERACTIVE) == INTERACTIVE) {
interActive = true;
- System.out.println("***** WARNING ***** The Interactive function has not been implemented yet!");
+ if (QUIET == false)
+ System.out.println("***** WARNING ***** The Interactive function has not been implemented yet!");
+ }
+
+ if ((cmdCode & DUMP) == DUMP) {
+ returnCode = dumpFile(toolConfFile, VERBOSE, QUIET);
+ if (DEBUG > 10)
+ System.out.println("dumpFile returned: " + returnCode);
}
if ((cmdCode & SCAN) == SCAN) {
- returnCode = scanFile(toolConfFile, interActive, VERBOSE);
+ returnCode = scanFile(toolConfFile, interActive, VERBOSE, QUIET);
}
if (((cmdCode & TEST) == TEST) || ((cmdCode & DEFAULT) == DEFAULT))
- returnCode = testFile(toolConfFile, interActive, VERBOSE);
-
- if (!errLog.isEmpty()) {
- System.out.println("Tool Configuration File: " + toolConfFile);
- for (int i = 0; i < goodLog.size(); i++)
- System.out.println("Tool Chain Tag Name: " + goodLog.get(i) + " is valid!");
+ returnCode = testFile(toolConfFile, interActive, VERBOSE, QUIET);
+
+ if ((errLog.isEmpty() == false) && (QUIET == false)) {
+ // We had ERRORS, not just Warnings.
+ // System.out.println("Tool Configuration File: " + toolConfFile);
+ System.out.println(" goodLog has: " + goodLog.size() + " entries");
+ if ((goodLog.isEmpty() == false) && (VERBOSE > 1))
+ for (int i = 0; i < goodLog.size(); i++)
+ System.out.println("Tool Chain Tag Name: " + goodLog.get(i) + " is valid!");
for (int i = 0; i < errLog.size(); i++)
System.out.println(errLog.get(i));
+ if (warnLog.isEmpty() == false)
+ for (int i = 0; i < warnLog.size(); i++)
+ System.out.println(" " + warnLog.get(i));
if (VERBOSE > 0) {
System.out.println();
System.out.println("You can remove these WARNING messages by editing the file:");
@@ -94,24 +114,644 @@ public class ToolChecks {
System.out.println("chain tag names that do not apply to your system.");
}
} else {
- System.out.println("");
- System.out.println(" Tool Configuration File: " + toolConfFile + " is valid!");
+ if (QUIET == false) {
+ if ((cmdCode & DUMP) == DUMP)
+ System.out.println("");
+ if (VERBOSE > 0) {
+ System.out.print("Valid Tag Names:");
+ for (int i = 0; i < goodLog.size(); i++)
+ System.out.print(" " + goodLog.get(i));
+ System.out.println("");
+ }
+ if (warnLog.isEmpty() == false)
+ for (int i = 0; i < warnLog.size(); i++)
+ System.out.println(" " + warnLog.get(i));
+ if (returnCode == 0)
+ if (warnLog.isEmpty())
+ System.out.println(" Tool Configuration File: " + toolConfFile + " is valid!");
+ else
+ System.out.println(" Tool Configuration File: " + toolConfFile
+ + " is valid! However, there are WARNINGS!");
+ else
+ System.out.println(" Tool Configuration File: " + toolConfFile
+ + " contains INVALID tool tag names!");
+ }
}
return returnCode;
}
- private int scanFile(String testFile, boolean interActive, int VERBOSE) {
+ private int scanFile(String testFile, boolean interActive, int VERBOSE, boolean QUIET) {
if ((DEBUG > 0) || (VERBOSE > 0))
System.out.println("Scanning the Normal Installation Locations ...");
- System.out.println("The Scan function has not been implemented yet!");
+ System.out.println("The Scan function has not been implemented yet!");
return FAIL;
}
- private int testFile(String testFile, boolean interActive, int VERBOSE) {
+
+ private int dumpFile(String testFile, int VERBOSE, boolean QUIET) {
+ int retCode = PASS;
+ try {
+ //
+ // initialize local variables
+ //
+ ArrayList<ToolInfo> info = new ArrayList<ToolInfo>();
+ String readLine = "";
+ String fileLine[] = new String[2];
+ String property[] = new String[5];
+ ToolInfo toolInf = null;
+ String lastTagName = "arf";
+ String lastFamily = "arf";
+ String lastArch = "IA32";
+ String lastCmdCode = "arf";
+ // String lastFlags = "arf";
+ boolean found = false;
+ String tFamily = "arf";
+ String tCmdName = "arf";
+ String acpiPath = "";
+ String cmdPath = "";
+ String asmPath = "";
+ int ctr = 0;
+ //
+ // Setup the reader
+ //
+ FileReader toolConfFile = new FileReader(testFile);
+ BufferedReader bufReader = new BufferedReader(toolConfFile);
+
+ while ((readLine = bufReader.readLine()) != null) {
+ if (!readLine.startsWith("#")) {
+ if (readLine.contains("IDENTIFIER")) {
+ readLine = readLine.trim();
+ fileLine = readLine.split("=");
+ if (QUIET == false)
+ System.out.println("IDENTIFIER: " + fileLine[1].trim());
+ toolInf = new ToolInfo();
+ toolInf.setValid();
+ } else if (readLine.contains("_")) {
+ /**
+ * This section should complete array values
+ * String TagName
+ * String Family
+ * boolean Valid
+ * String Arch
+ * ArrayList<String> Targets
+ * ArrayList<String> CmdCode
+ * ArrayList<String> Path
+ * ArrayList<String> Arguments
+ */
+ if (DEBUG > 10)
+ System.out.println("Processing: " + readLine.trim());
+ readLine = readLine.trim();
+ readLine = readLine.replaceFirst("=", "_SPLIT_HERE_");
+ fileLine = readLine.split("_SPLIT_HERE_");
+ fileLine[0] = fileLine[0].trim();
+ fileLine[1] = fileLine[1].trim();
+ property = fileLine[0].split("_");
+
+ // Covert to simple string names
+ String tTarget = property[0].trim();
+ if (tTarget.contentEquals("*"))
+ tTarget = "All Targets";
+ String tTag = property[1].trim();
+ String tArch = property[2].trim();
+ String tCmdCode = property[3].trim();
+ String tArg = property[4].trim();
+ if (tArg.contentEquals("FAMILY"))
+ tFamily = fileLine[1].trim();
+ if (tArg.contentEquals("NAME")) {
+ tCmdName = fileLine[1].trim();
+ tCmdCode = tCmdCode + " (" + tCmdName + ")";
+ }
+
+ String tVal = fileLine[1].trim();
+
+ // Process the TagName
+ if ((!tTag.contentEquals(lastTagName))
+ || ((!tArch.contentEquals(lastArch)) && (!tArch.contentEquals("*")))
+ || (!tFamily.contentEquals(lastFamily))) {
+ if (DEBUG > 10) {
+ System.out.println(" LAST Tag: " + lastTagName + " Arch: " + lastArch + " Family: "
+ + lastFamily);
+ System.out.println(" NEXT Tag: " + tTag + " Arch: " + tArch + " Family: " + tFamily);
+ }
+ if ((!lastTagName.equals("arf")) && (!tTag.equals("*"))) {
+ toolInf.setTagName(lastTagName);
+ toolInf.setFamily(lastFamily);
+ toolInf.setArch(lastArch);
+ if (toolInf.getCmdCode().size() < 1)
+ toolInf.addCmdCode(lastCmdCode);
+ info.add(toolInf);
+ toolInf = new ToolInfo();
+ toolInf.setValid();
+ if (DEBUG > 3)
+ System.out.println(" ADDED " + ctr + " Tag: " + lastTagName + " Arch: " + lastArch
+ + " Family: " + lastFamily + " CmdCode: " + lastCmdCode);
+ ctr++;
+
+ }
+
+ if ((!tTag.contentEquals("*")) && (!tTag.contentEquals(lastTagName)))
+ lastTagName = tTag;
+
+ if ((!tArch.contentEquals(lastArch)) && (!tArch.contentEquals("*")))
+ lastArch = tArch;
+ if ((!tArch.contentEquals(lastArch)) && (tArch.contentEquals("*")))
+ lastArch = "IA32";
+
+ if (!tFamily.contentEquals(lastFamily))
+ lastFamily = tFamily;
+ if (DEBUG > 10)
+ System.out.println(" Setting Tag: " + lastTagName + " Arch: " + lastArch
+ + " Family: " + lastFamily);
+ }
+
+ // Set the Arch
+ if ((!lastArch.contentEquals(tArch)) && (!tArch.contentEquals("*"))) {
+ toolInf.setArch(tArch);
+ lastArch = tArch;
+ if (DEBUG > 10)
+ System.out.println(" Setting Arch: " + tArch);
+ }
+
+ // Process Target field - making sure we add only unique values.
+ if (!tTarget.contains("*")) {
+ found = false;
+ for (int k = 0; k < toolInf.getTargetName().size(); k++)
+ if (toolInf.getTargetName(k).contentEquals(tTarget))
+ found = true;
+ if (!found) {
+ toolInf.addTargetName(tTarget);
+ if (DEBUG > 10)
+ System.out.println(" Adding Target: " + tTarget);
+ }
+ }
+
+ // Process Command Code Field - making sure we add only unique values.
+ if (!tCmdCode.contentEquals("*")) {
+ found = false;
+ for (int k = 0; k < toolInf.getCmdCode().size(); k++)
+ if (toolInf.getCmdCode(k).startsWith(tCmdCode))
+ found = true;
+ if (!found) {
+ if (!tCmdCode.contains(" (")) {
+ boolean nf = true;
+ for (int m = toolInf.size(); m >= 0; --m) {
+ if (nf) {
+ ArrayList<String> lastCmdEntry = info.get(m).getCmdCode();
+ for (int l = 0; l < lastCmdEntry.size(); l++) {
+ if (lastCmdEntry.get(l).startsWith(tCmdCode)) {
+ tCmdCode = lastCmdEntry.get(l).trim();
+ if (DEBUG > 20)
+ System.out.println("found tCmdCode here: " + tCmdCode);
+ nf = false;
+ }
+ }
+ }
+ }
+ if (nf == false) {
+ toolInf.addCmdCode(tCmdCode);
+ if (DEBUG > 10)
+ System.out.println(" Adding previous CmdCode: " + tCmdCode);
+ }
+ } else {
+ toolInf.addCmdCode(tCmdCode);
+ lastCmdCode = tCmdCode;
+ if (DEBUG > 10)
+ System.out.println(" Adding first CmdCode: " + tCmdCode);
+ }
+ }
+ }
+
+ // Process Path Field - making sure we add only unique values.
+ if (tArg.contentEquals("PATH")) {
+ String prefix = "PATH_";
+ if (tCmdCode.contentEquals("ASM"))
+ prefix = "ASMPATH_";
+ if (tCmdCode.contentEquals("ASMLINK"))
+ prefix = "ALPATH_";
+ if (tCmdCode.contentEquals("ASL"))
+ prefix = "ASLPATH_";
+ File path = new File(tVal);
+ found = false;
+ if (path.exists()) {
+ for (int k = 0; k < toolInf.getPath().size(); k++)
+ if (toolInf.getPath(k).startsWith(prefix))
+ found = true;
+ if (found == false) {
+ toolInf.addPath(prefix + tVal);
+ if (DEBUG > 10)
+ System.out.println(" Adding valid path: " + tVal);
+ }
+ if (prefix.contentEquals("ASLPATH_"))
+ acpiPath = tVal;
+ if (prefix.contentEquals("PATH_"))
+ cmdPath = tVal;
+ if (prefix.contentEquals("ASMPATH_"))
+ asmPath = tVal;
+ } else {
+ toolInf.setInvalid();
+ for (int k = 0; k < toolInf.getBadPath().size(); k++)
+ if (toolInf.getBadPath(k).startsWith(prefix))
+ found = true;
+ if (!found) {
+ toolInf.addBadPath(prefix + tVal);
+ if (DEBUG > 10)
+ System.out.println(" Adding NOT valid Path: " + tVal);
+ retCode = FAIL;
+ }
+ }
+ }
+
+ if (tArg.contentEquals("DPATH")) {
+ found = false;
+ File path = new File(tVal);
+ if (path.exists()) {
+ for (int k = 0; k < toolInf.getPath().size(); k++)
+ if (toolInf.getPath(k).startsWith("DPATH_"))
+ found = true;
+ if (!found) {
+ toolInf.addPath("DPATH_" + tVal);
+ if (DEBUG > 10)
+ System.out.println(" Adding valid DPath: " + tVal);
+ }
+ } else {
+ toolInf.setInvalid();
+ for (int k = 0; k < toolInf.getBadPath().size(); k++)
+ if (toolInf.getBadPath(k).contentEquals("DPATH_" + tVal))
+ found = true;
+ if (!found) {
+ toolInf.addBadPath("DPATH_" + tVal);
+ if (DEBUG > 10)
+ System.out.println(" Adding NOT valid DPath: " + tVal);
+ retCode = FAIL;
+ }
+ }
+ }
+
+ if (tArg.contentEquals("SPATH")) {
+ found = false;
+ File path = new File(tVal);
+ if (path.exists()) {
+ for (int k = 0; k < toolInf.getPath().size(); k++)
+ if (toolInf.getPath(k).contentEquals("SPATH_" + tVal))
+ found = true;
+ if (!found) {
+ toolInf.addPath("SPATH_" + tVal);
+ if (DEBUG > 10)
+ System.out.println(" Adding valid SPath: " + tVal);
+ }
+ } else {
+ toolInf.setInvalid();
+ for (int k = 0; k < toolInf.getBadPath().size(); k++)
+ if (toolInf.getBadPath(k).contentEquals("SPATH_" + tVal))
+ found = true;
+ if (!found) {
+ toolInf.addBadPath("SPATH_" + tVal);
+ if (DEBUG > 10)
+ System.out.println(" Adding NOT valid SPath: " + tVal);
+ retCode = FAIL;
+ }
+ }
+ }
+
+ if (tArg.equals("INCLUDEPATH")) {
+ found = false;
+ File path = new File(tVal);
+ if (path.exists()) {
+ for (int k = 0; k < toolInf.getPath().size(); k++)
+ if (toolInf.getPath(k).contentEquals("INCLUDEPATH_" + tVal))
+ found = true;
+ if (!found) {
+ toolInf.addPath("INCLUDEPATH_" + tVal);
+ if (DEBUG > 10)
+ System.out.println(" Adding valid IPath: " + tVal);
+ }
+ } else {
+ toolInf.setInvalid();
+ for (int k = 0; k < toolInf.getBadPath().size(); k++)
+ if (toolInf.getBadPath(k).contentEquals("INCLUDE_" + tVal))
+ found = true;
+ if (!found) {
+ toolInf.addBadPath("INCLUDE_" + tVal);
+ if (DEBUG > 10)
+ System.out.println(" Adding NOT valid IPath: " + tVal);
+ retCode = FAIL;
+ }
+ }
+ }
+
+ if (tArg.equals("LIBPATH")) {
+ found = false;
+ File path = new File(tVal);
+ if (path.exists()) {
+ for (int k = 0; k < toolInf.getPath().size(); k++)
+ if (toolInf.getPath(k).contentEquals("LIB_" + tVal))
+ found = true;
+ if (!found) {
+ toolInf.addPath("LIB_" + tVal);
+ if (DEBUG > 10)
+ System.out.println(" Adding valid LPath: " + tVal);
+ }
+ } else {
+ toolInf.setInvalid();
+ for (int k = 0; k < toolInf.getBadPath().size(); k++)
+ if (toolInf.getBadPath(k).contentEquals("LIB_" + tVal))
+ found = true;
+ if (!found) {
+ toolInf.addBadPath("LIB_" + tVal);
+ if (DEBUG > 10)
+ System.out.println(" Adding NOT valid LPath: " + tVal);
+ retCode = FAIL;
+ }
+ }
+ }
+
+ if (tArg.equals("FLAGS")) {
+ String flags = fileLine[1].trim();
+ String fLine = tTarget + "_" + tCmdCode + "_FLAGS_" + flags;
+ toolInf.addArguments(fLine);
+ if (DEBUG > 10)
+ System.out.println(" Adding flag line: " + fLine);
+ }
+ }
+ }
+ }
+ toolInf.setArch(lastArch);
+ toolInf.setFamily(lastFamily);
+ toolInf.setTagName(lastTagName);
+ info.add(toolInf);
+ if (DEBUG > 2)
+ System.out.println(" ADDED " + ctr + " LAST Tag: " + lastTagName + " Arch: " + lastArch + " Family: "
+ + lastFamily + " Last CmdCode: " + lastCmdCode);
+ //
+ // Finished collecting data, print it out in Human Readable Format
+ if (info.size() > 0) {
+ if (QUIET == false)
+ System.out.println(" **** TOOL CHAINS ****");
+ if ((DEBUG > 0) || (VERBOSE > 1))
+ System.out.println("There are " + info.size()
+ + " different combinations of Tag Names and Architectures.");
+ lastTagName = "arf";
+
+ boolean asmExists = false;
+ boolean asmPathDefined = false;
+
+ boolean cmdPathDefined = false;
+ boolean dPathDefined = false;
+
+ boolean acpiPathDefined = false;
+ boolean acpiDeclared = false;
+ ArrayList<String> warnMsgs = null;
+
+ for (int i = 0; i < info.size(); i++) {
+ if (!lastTagName.contentEquals(info.get(i).getTagName())) {
+ if ((acpiDeclared == false) && (!lastTagName.contentEquals("arf"))) {
+ if (QUIET == false) {
+ System.out
+ .println(" ----WARNING: No ACPI assembler has been defined for "
+ + lastTagName
+ + ", you will not be able to successfully create a complete firmware image.");
+ System.out.println("");
+ }
+ }
+ if ((asmExists == false) && (!lastTagName.contentEquals("arf"))) {
+ if (QUIET == false) {
+ System.out.println(" ----WARNING: No Assembler has been defined for " + lastTagName
+ + ", you will not be able to successfully compile all platforms.");
+ System.out.println("");
+ }
+ }
+ asmPath = "";
+ asmPathDefined = false;
+ cmdPath = "";
+ cmdPathDefined = false;
+ dPathDefined = false;
+ acpiPath = "";
+ acpiPathDefined = false;
+ acpiDeclared = false;
+ warnMsgs = new ArrayList<String>();
+ lastTagName = info.get(i).getTagName();
+ }
+
+ if ((DEBUG > 0) || (VERBOSE > 1))
+ System.out.print("Tool Chain " + i + " Tag Name: " + info.get(i).getTagName() + ", Family: "
+ + info.get(i).getFamily());
+ else if (QUIET == false)
+ System.out.print("Tool Chain Tag Name: " + info.get(i).getTagName() + ", Family: "
+ + info.get(i).getFamily());
+
+ if (info.get(i).isValid()) {
+ ToolInfo vTool = info.get(i);
+ if (QUIET == false)
+ System.out.println(" is Valid for Architecture: " + info.get(i).getArch());
+ // OK, let's print out the command w/flags
+
+ for (int m = 0; m < vTool.getPath().size(); m++) {
+ String pathName[] = vTool.getPath(m).split("_");
+ String prefix = " Tool Path: ";
+ if (pathName[0].startsWith("DPATH")) {
+ prefix = " Dynamic Linker Path: ";
+ dPathDefined = true;
+ }
+ if (pathName[0].startsWith("PATH")) {
+ cmdPathDefined = true;
+ cmdPath = pathName[1].trim();
+ }
+ if (pathName[0].startsWith("APATH")) {
+ asmPathDefined = true;
+ asmPath = pathName[1].trim();
+ }
+ if (pathName[0].startsWith("ASLPATH")) {
+ acpiPathDefined = true;
+ acpiPath = pathName[1].trim();
+ }
+ if (VERBOSE > 0)
+ System.out.println(prefix + pathName[1].trim());
+ }
+ if (acpiPathDefined == false) {
+ if (VERBOSE > 0)
+ warnMsgs.add(" ---- WARNING: " + vTool.getTagName() + "ACPI Path is not defined!");
+ }
+ if ((VERBOSE == 0) && (QUIET == false))
+ System.out.print("Defined Targets: ");
+ for (int k = 0; k < vTool.getTargetName().size(); k++) {
+ String tTarget = vTool.getTargetName(k);
+ if (tTarget.contentEquals("*"))
+ break;
+
+ if (VERBOSE > 0)
+ System.out.println("+++ " + tTarget + " +++");
+ else if (QUIET == false)
+ System.out.print(" " + tTarget);
+
+ for (int j = 0; j < vTool.getCmdCode().size(); j++) {
+ String tCommand = vTool.getCmdCode(j);
+ if (tCommand.contains("ASL ")) {
+ acpiDeclared = true;
+ if (acpiPathDefined) {
+ // TODO: Check the acpi tool path
+ }
+ }
+ if (vTool.getArguments().size() > 1) {
+
+ if (!cmdPathDefined) {
+ warnMsgs.add(" ---- ERROR: Command Path is not defined!");
+ }
+ if ((vTool.getFamily().contentEquals("MSFT")) && (!dPathDefined)) {
+ warnMsgs
+ .add(" ---- ERROR: Microsoft Tool Chains require a Path (DPATH) to the mspdbXX.dll file");
+ }
+
+ // Process Flag lines!
+ for (int n = 0; n < vTool.getArguments().size(); n++) {
+ String tFlags = vTool.getArguments(n);
+ String aFlags[] = new String[2];
+ aFlags = tFlags.split("FLAGS_");
+ String tsCmd[] = tCommand.split(" ");
+ tsCmd[0] = tsCmd[0].trim();
+ if (DEBUG > 10)
+ System.out.println(" tCmd: " + tsCmd[0] + ", aFlags[0]: " + aFlags[0]
+ + ", tTarget: " + tTarget);
+ if (aFlags[0].contains(tsCmd[0])) {
+ if ((tFlags.contains("All")) || (aFlags[0].contains(tTarget))) {
+ String flagLine = aFlags[1].trim();
+ if (info.get(i).getFamily().contentEquals("MSFT")) {
+ if (tCommand.startsWith("PP")) {
+ if (QUIET == false)
+ if ((!flagLine.contains("/P "))
+ && (!flagLine.contains("/E "))) {
+ System.out
+ .println(" **** ERROR **** Pre-Processor Flags are NOT VALID!");
+ }
+ }
+ }
+ String cmdExe = "";
+
+ if (tCommand.contains("ASM ")) {
+ cmdExe = tCommand.replace("ASM (", "");
+ cmdExe = cmdExe.replace(")", "");
+ if (asmPathDefined)
+ cmdExe = asmPath.trim() + File.separator + cmdExe.trim();
+ else
+ cmdExe = cmdPath.trim() + File.separator + cmdExe.trim();
+ File testCmd = new File(cmdExe);
+ // System.out.println("Check: " + cmdExe);
+ if (!testCmd.exists()) {
+ String errMsg = " **** ERROR **** Assembler Command Defined, but does not exist! "
+ + cmdExe;
+ if (VERBOSE > 0) {
+ System.out.println(errMsg);
+ }
+ boolean nf = true;
+ for (int r = 0; r < warnMsgs.size(); r++)
+ if (warnMsgs.get(r).contentEquals(errMsg))
+ nf = false;
+ if (nf)
+ warnMsgs.add(errMsg);
+ } else
+ asmExists = true;
+
+ }
+
+ if ((tCommand.contains("ASM ")) && (asmPathDefined == false)
+ && (VERBOSE > 0))
+ System.out
+ .println(" --- WARNING: Assembler - "
+ + tCommand
+ + " defined, but a Separate Path to the Assembler was not defined, using: "
+ + cmdExe);
+ if ((asmPathDefined) && (tCommand.contains("ASM "))
+ && (asmPathDefined == false) && (VERBOSE == 0)) {
+ String msgIs = " --- WARNING: "
+ + info.get(i).getTagName()
+ + " Assembler "
+ + info.get(i).getArch()
+ + " - "
+ + tCommand
+ + " defined, but a Separate Path to the Assembler was not defined, using: "
+ + cmdExe;
+ boolean nf = true;
+ for (int r = 0; r < warnMsgs.size(); r++)
+ if (warnMsgs.get(r).contentEquals(msgIs))
+ nf = false;
+ if (nf)
+ warnMsgs.add(msgIs);
+ }
+ if (VERBOSE > 0)
+ System.out.println(" " + tCommand + " " + flagLine);
+ }
+ }
+ }
+ } else {
+ if (VERBOSE > 0)
+ System.out.println(" " + tCommand + " has no arguments defined.");
+ }
+ }
+ }
+
+ } else {
+ if (QUIET == false)
+ System.out.println(" is NOT VALID for Architecture: " + info.get(i).getArch());
+ retCode = FAIL;
+ for (int k = 0; k < info.get(i).getBadPath().size(); k++) {
+ String failureString = "";
+ String tempString = info.get(i).getBadPath(k);
+ if (tempString.startsWith("PATH_"))
+ failureString = "Common Command Path: " + tempString.replace("PATH_", "")
+ + " is NOT Valid!";
+ if (tempString.startsWith("SPATH"))
+ failureString = "Static Linker Path: " + tempString.replace("SPATH_", "")
+ + " is NOT valid!";
+ if (tempString.startsWith("DPATH"))
+ failureString = "Dynamic Linker Path: " + tempString.replace("DPATH_", "")
+ + " is NOT valid!";
+ if (tempString.startsWith("LIB_"))
+ failureString = "System Lib Path: " + tempString.replace("LIB_", "")
+ + " is NOT valid!";
+ if (tempString.startsWith("INCLUDEPATH_"))
+ failureString = "System include Path: " + tempString.replace("INCLUDEPATH_", "")
+ + " is NOT valid!";
+ if (tempString.startsWith("APATH"))
+ failureString = "Assembler Path: " + tempString.replace("APATH_", "")
+ + " is NOT valid!";
+ if (tempString.startsWith("ALPATH"))
+ failureString = "Assembler Link Path: " + tempString.replace("ALPATH_", "")
+ + " is NOT valid!";
+ if (tempString.startsWith("ASLPATH"))
+ failureString = "ACPI Path: " + tempString.replace("ASLPATH_", "")
+ + " is NOT valid!";
+ if (QUIET == false)
+ System.out.println(" --- " + failureString);
+ }
+
+ }
+
+ if ((VERBOSE == 0) && (QUIET == false)) {
+ System.out.println("");
+ for (int p = 0; p < warnMsgs.size(); p++)
+ System.out.println(warnMsgs.get(p));
+ }
+ if (QUIET == false)
+ System.out.println("");
+ }
+
+ }
+
+ } catch (IOException e) {
+ if (QUIET == false)
+ System.out.println("I/O Failure: " + e);
+ retCode = FAIL;
+ }
+
+ return retCode;
+ }
+
+ private int testFile(String testFile, boolean interActive, int VERBOSE, boolean QUIET) {
int retCode = PASS;
String readLine = "";
String fileLine[] = new String[2];
+ boolean definedAsl = false;
+
try {
FileReader toolConfFile = new FileReader(testFile);
BufferedReader reader = new BufferedReader(toolConfFile);
@@ -128,39 +768,82 @@ public class ToolChecks {
fileLine = readLine.split("=");
path = fileLine[1].trim();
props = fileLine[0].split("_");
+ String tagName = props[1].trim();
+ // System.out.println(" Testing TagName: " + tagName);
+ String cmdTag = props[3].trim();
+ if (!lastTag.contentEquals(tagName)) {
+ // we have a new tagName
+ // first past lastTag = barf, lastErrTag = barf, tagName = something other than BARF
+ if (DEBUG > 0)
+ System.out.println(" lastTag: " + lastTag + " this Tag: " + tagName + " lastErrTag: "
+ + lastErrTag);
+
+ if ((definedAsl == false) && (lastTag.contentEquals("barf") == false))
+ warnLog.add(" -- WARNING: Tool Chain Tag Name: " + lastTag
+ + " does not have an ACPI assembler defined!");
+ definedAsl = false;
+
+ if ((lastErrTag.contentEquals("barf")) || (!tagName.contentEquals(lastErrTag))) {
+ if ((DEBUG > 2) || (VERBOSE > 3))
+ System.out.println("Adding tag: " + tagName + " to the goodLog");
+ goodLog.add(tagName);
+ }
+
+ lastTag = tagName;
+
+ } // end of adding the new tag name to the goodLog and
+ // checking if we had an ACPI compiler defined for the TagName
File testPath = new File(path);
+ if (cmdTag.contentEquals("ASL"))
+ definedAsl = true;
if (!testPath.exists()) {
- if (!props[1].trim().contentEquals(lastErrTag))
- errLog.add(" -- WARNING: Tool Chain Tag Name: " + props[1].trim() + " is NOT valid!");
- if (VERBOSE > 1)
- errLog.add(" Tool Code: [" + props[3].trim() + "] Path: " + path + " does not exist!");
+ if (VERBOSE > 0)
+ System.out.println(" Invalid path: " + path + ", path does not exist!");
+ if (!tagName.contentEquals(lastErrTag)) {
+ errLog.add(" -- WARNING: Tool Chain Tag Name: " + tagName + " is NOT valid!");
+ errLog.add(" Tool Code: [" + cmdTag + "] Path: " + path + " does not exist!");
+ }
retCode = 1;
- lastErrTag = props[1].trim();
+ lastErrTag = tagName;
+
} else {
+
if ((DEBUG > 0) || (VERBOSE > 0)) {
- if ((!props[1].trim().contentEquals(lastTag))
- && (!props[1].trim().contentEquals(lastErrTag)))
- System.out.println("Tool Chain: " + props[1].trim() + " is valid");
+ if ((!tagName.contentEquals(lastTag)) && (!tagName.contentEquals(lastErrTag))
+ && (!lastTag.contentEquals("barf"))) {
+ String goodMsg = "Tool Chain: " + tagName + " is valid";
+ System.out.println(goodMsg);
+ }
}
- if (!props[1].trim().contentEquals(lastTag))
- goodLog.add(props[1].trim());
- lastTag = props[1].trim();
- }
- }
- }
+ } // end of path existence check
+ } // end of parsing the PATH line
+ } // end of reading file
+ // Check the LAST Tag to see of ACPI has been defined.
+ if (definedAsl == false)
+ warnLog.add(" -- WARNING: Tool Chain Tag Name: " + lastTag
+ + " does not have an ACPI assembler defined!");
+ // CLEAN UP
+ toolConfFile.close();
} catch (IOException e) {
- System.out.println(" [" + testFile + "] " + e);
+ if (QUIET == false)
+ System.out.println(" [" + testFile + "] " + e);
System.exit(FAIL);
- }
- if (errLog.size() > 0)
+ } // end of TRY-CATCH for reading file
+
+ if ((errLog.isEmpty() == false) && (QUIET == false))
for (int i = 0; i < goodLog.size(); i++) {
for (int j = 0; j < errLog.size(); j++) {
+ System.out.println(" Error Log [" + j + "] is " + errLog.get(j));
if (errLog.get(j).contains(goodLog.get(i).trim())) {
+ if (VERBOSE > 1)
+ System.out.println(" Removing: " + goodLog.get(i).trim());
goodLog.remove(i);
break;
}
}
}
+ if (DEBUG > 0)
+ System.out.println("Returning with goodLog having: " + goodLog.size());
return retCode;
}
diff --git a/Tools/Java/Source/CheckTools/src/org/tianocore/CheckTools/ToolInfo.java b/Tools/Java/Source/CheckTools/src/org/tianocore/CheckTools/ToolInfo.java
new file mode 100644
index 0000000000..3821c53dbd
--- /dev/null
+++ b/Tools/Java/Source/CheckTools/src/org/tianocore/CheckTools/ToolInfo.java
@@ -0,0 +1,185 @@
+/** @file
+ Tool Definition Class for translating the tools_def.txt entries
+
+ Copyright (c) 2006, Intel Corporation
+ All rights reserved. This program and the accompanying materials
+ are licensed and made available under the terms and conditions of the BSD License
+ which accompanies this distribution. The full text of the license may be found at
+ http://opensource.org/licenses/bsd-license.php
+
+ THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
+ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
+
+ **/
+
+/**
+ * This section should complete array values
+ * this.TagName
+ * this.Family
+ * this.Valid
+ * this.Arch
+ * this.Targets[]
+ * this.CmdCode[]
+ * this.Path[]
+ * this.Arguments[]
+ *
+ */
+
+package org.tianocore.CheckTools;
+
+import java.util.*;
+
+public class ToolInfo extends ArrayList {
+
+ ///
+ /// Define Class Serial Version UID
+ ///
+ private static final long serialVersionUID = 2513613555731096258L;
+
+ private String sTagName;
+
+ private String sFamily;
+
+ private boolean bValid;
+
+ private String sArch;
+
+ private ArrayList<String> aTargetName = null;
+
+ private ArrayList<String> aCmdCode = null;
+
+ private ArrayList<String> aCmdName = null;
+
+ private ArrayList<String> aPath = null;
+
+ private ArrayList<String> aBadPath = null;
+
+ private ArrayList<String> aArguments = null;
+
+ public ToolInfo() {
+ super();
+ init();
+ }
+
+ private void init() {
+ sTagName = "";
+ sFamily = "";
+ bValid = false;
+ sArch = "";
+ aTargetName = new ArrayList<String>();
+ aCmdCode = new ArrayList<String>();
+ aCmdName = new ArrayList<String>();
+ aPath = new ArrayList<String>();
+ aArguments = new ArrayList<String>();
+ aBadPath = new ArrayList<String>();
+ }
+
+ public String getTagName() {
+ return this.sTagName.trim();
+ }
+
+ public String getFamily() {
+ return this.sFamily.trim();
+ }
+
+ public boolean isValid() {
+ return this.bValid;
+ }
+
+ public String getArch() {
+ return this.sArch.trim();
+ }
+
+ public ArrayList<String> getTargetName() {
+ return this.aTargetName;
+ }
+
+ public String getTargetName(int id) {
+ return this.aTargetName.get(id).trim();
+ }
+
+ public ArrayList<String> getCmdCode() {
+ return this.aCmdCode;
+ }
+
+ public String getCmdCode(int id) {
+ return this.aCmdCode.get(id).trim();
+ }
+
+ public ArrayList<String> getCmdName() {
+ return this.aCmdName;
+ }
+
+ public String getCmdName(int id) {
+ return this.aCmdName.get(id).trim();
+ }
+
+ public ArrayList<String> getPath() {
+ return this.aPath;
+ }
+
+ public String getPath(int id) {
+ return this.aPath.get(id).trim();
+ }
+
+ public ArrayList<String> getArguments() {
+ return this.aArguments;
+ }
+
+ public String getArguments(int id) {
+ return this.aArguments.get(id).trim();
+ }
+
+ public ArrayList<String> getBadPath() {
+ return this.aBadPath;
+ }
+
+ public String getBadPath(int id) {
+ return this.aBadPath.get(id).trim();
+ }
+
+ public void setTagName(String val) {
+ this.sTagName = val.trim();
+ }
+
+ public void setFamily(String val) {
+ this.sFamily = val.trim();
+ }
+
+ public void setValid() {
+ this.bValid = true;
+ }
+
+ public void setInvalid() {
+ this.bValid = false;
+ }
+
+ public void setArch(String val) {
+ this.sArch = val.trim();
+ }
+
+ public void addTargetName(String val) {
+ this.aTargetName.add(val.trim());
+ }
+
+ public void addCmdCode(String val) {
+ this.aCmdCode.add(val.trim());
+ }
+
+ public void addCmdName(String val) {
+ this.aCmdName.add(val.trim());
+ }
+
+ public void addPath(String val) {
+ this.aPath.add(val.trim());
+ }
+
+ public void addArguments(String val) {
+ this.aArguments.add(val.trim());
+ }
+
+ public void addBadPath(String val) {
+ this.aBadPath.add(val.trim());
+ }
+
+}
diff --git a/Tools/Java/Source/ContextTool/ContextTool.msa b/Tools/Java/Source/ContextTool/ContextTool.msa
new file mode 100644
index 0000000000..6135d21431
--- /dev/null
+++ b/Tools/Java/Source/ContextTool/ContextTool.msa
@@ -0,0 +1,31 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<ModuleSurfaceArea xmlns="http://www.TianoCore.org/2006/Edk2.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
+ <MsaHeader>
+ <ModuleName>Context Tool</ModuleName>
+ <ModuleType>TOOL</ModuleType>
+ <GuidValue>893c2f79-1d84-495a-a9c5-f7c1e8a58b31</GuidValue>
+ <Version>0.1</Version>
+ <Abstract>The tool manipulates the Tools/Conf/target.txt file.</Abstract>
+ <Description>This tool is used to manipulate the target.txt file attributes from the command line.
+USAGE:
+ContextTool [-option1] [args] [-option2] [args] ...</Description>
+ <Copyright>Copyright (c) 2006, Intel Corporation All rights reserved.</Copyright>
+ <License URL="http://opensource.org/licenses/bsd-license.php">This program and the accompanying materials are licensed and made available under the terms and conditions of the BSD License which accompanies this distribution. The full text of the license may be found at http://opensource.org/licenses/bsd-license.php
+
+THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
+WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.</License>
+ <Specification>FRAMEWORK_BUILD_PACKAGING_SPECIFICATION 0x00000052</Specification>
+ </MsaHeader>
+ <ModuleDefinitions>
+ <SupportedArchitectures>IA32 X64 IPF</SupportedArchitectures>
+ <BinaryModule>false</BinaryModule>
+ <OutputFileBasename>ContextTool</OutputFileBasename>
+ </ModuleDefinitions>
+ <SourceFiles>
+ <Filename>org/tianocore/context/ContextMain.java</Filename>
+ <Filename>org/tianocore/context/HelpInfo.java</Filename>
+ <Filename>org/tianocore/context/ParseParameter.java</Filename>
+ <Filename>org/tianocore/context/TargetFile.java</Filename>
+ <Filename>build.xml</Filename>
+ </SourceFiles>
+</ModuleSurfaceArea>
diff --git a/Tools/Java/Source/DbTools/DbTools.msa b/Tools/Java/Source/DbTools/DbTools.msa
new file mode 100644
index 0000000000..254b0bec2d
--- /dev/null
+++ b/Tools/Java/Source/DbTools/DbTools.msa
@@ -0,0 +1,31 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<ModuleSurfaceArea xmlns="http://www.TianoCore.org/2006/Edk2.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
+ <MsaHeader>
+ <ModuleName>Database Manipulation Tools</ModuleName>
+ <ModuleType>TOOL</ModuleType>
+ <GuidValue>c51d72c2-6e85-4fcf-adb2-7c44b2f57f19</GuidValue>
+ <Version>0.3</Version>
+ <Abstract>The tool manipulates the FrameworkDatabase.db file</Abstract>
+ <Description>
+This tool will scan the current workspace and update the FrameworkDatabase.db file if the workspace content is not consistent with the database.
+USAGE:
+DbTool [-v] [-t] [-q] [-V] [--package] [--platform] [-h | -? | --help]</Description>
+ <Copyright>Copyright (c) 2006, Intel Corporation All rights reserved.</Copyright>
+ <License URL="http://opensource.org/licenses/bsd-license.php">This program and the accompanying materials are licensed and made available under the terms and conditions of the BSD License which accompanies this distribution. The full text of the license may be found at http://opensource.org/licenses/bsd-license.php
+
+THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
+WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.</License>
+ <Specification>FRAMEWORK_BUILD_PACKAGING_SPECIFICATION 0x00000052</Specification>
+ </MsaHeader>
+ <ModuleDefinitions>
+ <SupportedArchitectures>IA32 X64 IPF</SupportedArchitectures>
+ <BinaryModule>false</BinaryModule>
+ <OutputFileBasename>DbTools</OutputFileBasename>
+ </ModuleDefinitions>
+ <SourceFiles>
+ <Filename>src/org/tianocore/DbTools/UpdateDb.java</Filename>
+ <Filename>src/org/tianocore/DbTools/DbTool.java</Filename>
+ <Filename>src/org/tianocore/DbTools/DbCmds.java</Filename>
+ <Filename>build.xml</Filename>
+ </SourceFiles>
+</ModuleSurfaceArea>
diff --git a/Tools/Java/Source/DbTools/build.xml b/Tools/Java/Source/DbTools/build.xml
new file mode 100644
index 0000000000..5ae43e9223
--- /dev/null
+++ b/Tools/Java/Source/DbTools/build.xml
@@ -0,0 +1,42 @@
+<?xml version="1.0"?>
+<!--
+Copyright (c) 2006, Intel Corporation
+All rights reserved. This program and the accompanying materials
+are licensed and made available under the terms and conditions of the BSD License
+which accompanies this distribution. The full text of the license may be found at
+http://opensource.org/licenses/bsd-license.php
+
+THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
+WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
+-->
+<project name="DbTools" default="DbTools" basedir=".">
+ <taskdef resource="net/sf/antcontrib/antlib.xml"/>
+ <property environment="env"/>
+ <property name="WORKSPACE" value="${env.WORKSPACE}"/>
+ <path id="classpath">
+ <fileset dir="${WORKSPACE}/Tools/Jars" includes="*.jar"/>
+ <fileset dir="${env.XMLBEANS_HOME}/lib" includes="*.jar"/>
+ </path>
+ <property name="buildDir" value="build"/>
+ <property name="installLocation" value="${WORKSPACE}/Tools/Jars"/>
+ <target name="DbTools" depends="install"/>
+ <target name="source">
+ <mkdir dir="${buildDir}"/>
+ <javac srcdir="src" destdir="${buildDir}">
+ <classpath refid="classpath"/>
+ <!-- <compilerarg value="-Xlint"/> -->
+ </javac>
+ </target>
+ <target name="clean">
+ <delete dir="${buildDir}"/>
+ </target>
+ <target name="cleanall">
+ <delete dir="${buildDir}"/>
+ <delete file="${installLocation}/DbTools.jar"/>
+ </target>
+ <target name="install" depends="source">
+ <jar destfile="${installLocation}/DbTools.jar">
+ <fileset dir="${buildDir}"/>
+ </jar>
+ </target>
+</project>
diff --git a/Tools/Java/Source/DbTools/src/org/tianocore/DbTools/DbCmds.java b/Tools/Java/Source/DbTools/src/org/tianocore/DbTools/DbCmds.java
new file mode 100644
index 0000000000..502be2499b
--- /dev/null
+++ b/Tools/Java/Source/DbTools/src/org/tianocore/DbTools/DbCmds.java
@@ -0,0 +1,501 @@
+// @file
+// DbCmds command-line interface to the classes that
+// update the FrameworkDatabase.db file based on WORKSPACE Contents
+//
+// Copyright (c) 2006, Intel Corporation All rights reserved.
+//
+// This program and the accompanying materials are licensed and made
+// available under the terms and conditions of the BSD License which
+// accompanies this distribution. The full text of the license may
+// be found at http://opensource.org/licenses/bsd-license.php
+//
+// THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
+// WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
+//
+// This program is the command line interface to the CombineMsa class, which
+// will take the following arguments:
+//
+// Input:
+// -t, --test Test the Workspace against the FrameworkDatabase.db file
+// Returns 0 if valid, returns 1 if failed
+//
+// -f, --fix Fix the FrameworkDatabase.db file, so that it matches the
+// the contents of the WORKSPACE
+// Returns 0 if valid, returns 1 if failed
+//
+// -v [-v] Verbose Flag - sum of these will be used to set different
+// levels of verbosity
+//
+// -i Interactive, when used with -f or --fix, will query the user
+// regarding adds and deletes of packages and platforms from
+// the database.
+//
+// -a, --add Add an SPD or FPD file to the FrameworkDatabase.db file. The
+// SPD/FPD file must exist, or the command will fail.
+// Returns 0 if valid, returns 1 if failed
+//
+// -r, --del Remove an SPD or FPD file from the FrameworkDatabase.db file.
+// If the SPD/FPD file exists, the user will be queried to
+// remove it from the directory tree. For SPD files, the user
+// will also be presented with a list of Modules in the SPD
+// file, with the query to remove the modules as well as the
+// SPD file.
+// Returns 0 if valid, returns 1 if failed
+//
+// -u Display the UiName for all Packages and Platforms currently in
+// the FrameworkDatabase.db file.
+// Returns 0 if valid, returns 1 if failed
+//
+// -c Display a CSV listing of Type (SPD|FPD) UiName and Filename of
+// every entry in the FrameworkDatabase.db file.
+// Returns 0 if valid, returns 1 if failed
+//
+// No Options Display a list of Type (Package|Platfrom) and Filename of every
+// entry in the FrameworkDatabase.db file.
+// Returns 0 if valid, returns 1 if failed
+//
+// -h, -?, --help Displays this usage and exits.
+// Returns 0 if valid, returns 1 if failed
+//
+//
+// Output:
+// Displayed information
+//
+// Modifies - OPTIONAL
+// FrameworkDatabase.db
+//
+
+package org.tianocore.DbTools;
+
+import java.io.*;
+
+public class DbCmds {
+
+ protected enum Cmd {
+ SHOW_CSV, SHOW_PLATFORMS, SHOW_PACKAGES, FIX_DB, TEST_DB, FIND_SOMETHING, SHOW_FAR, ADD_SOMETHING,
+ DELETE_SOMETHING
+ }
+
+ private int DEBUG = 0;
+
+ private static final String copyright = "Copyright (c) 2006, Intel Corporation All rights reserved.";
+
+ private static final String version = "Version 0.1";
+
+ private static final String Specification = "FRAMEWORK_BUILD_PACKAGING_SPECIFICATION 0x00000052";
+
+ private int VERBOSE = 0;
+
+ public boolean INTERACTIVE = false;
+
+ private String workspace = System.getenv("WORKSPACE");
+
+ private final String frameworkDatabase = workspace + File.separator + "Tools" + File.separator + "Conf"
+ + File.separator + "FrameworkDatabase.db";
+
+ private final int ESUCCESS = 0;
+
+ private final int EFAILURE = 1;
+
+ private final int MIN_VERBOSE = 0;
+
+ private final int MED_VERBOSE = 1;
+
+ private final int MAX_VERBOSE = 2;
+
+ private final static int FOUND = 1;
+
+ private final static int NOTFOUND = 0;
+
+ private boolean TEST = false;
+
+ private int result = ESUCCESS;
+
+ private Cmd commandToCall;
+
+ private boolean isPlatform = false;
+
+ private boolean isPackage = false;
+
+ private boolean isFar = false;
+
+ private boolean QUIET = false;
+
+ private String commandArgs = "";
+
+ private String whatToFind = "";
+
+ public int DbUpdateCmdLine(String[] args) {
+
+ if (testFile(frameworkDatabase) == NOTFOUND) {
+ System.out.println("ERROR: E000 Invalid Workspace!");
+ System.out.println("The environment variable, WORKSPACE, does not point to a valid workspace");
+ System.out.println("DbUpdate Aborted!");
+ System.err.flush();
+ System.exit(EFAILURE);
+ }
+ result = parseCmdLine(args);
+ if (result == ESUCCESS) {
+ if (DEBUG > 2)
+ System.out.println("Parse Succeeded!");
+ if (VERBOSE > MAX_VERBOSE)
+ System.out.println("WORKSPACE: " + workspace);
+ if (DEBUG > 1)
+ System.out.println("Command to call: " + commandToCall.toString());
+ result = processCmdLine(commandToCall);
+ } else {
+ if (QUIET == false) {
+ System.out.println("Invalid Arguments");
+ outputUsage();
+ result = EFAILURE;
+ }
+ }
+ if (DEBUG > 2)
+ System.out.println(" Result: " + result);
+
+ return result;
+ }
+
+ private int processCmdLine(Cmd cmdCode) {
+ UpdateDb dbUp = new UpdateDb();
+ int res = ESUCCESS;
+ switch (cmdCode) {
+ case SHOW_CSV:
+ // display current Database contents in CSV format
+ // Modifies: NOTHING
+ if ((DEBUG > 3) || (VERBOSE > MED_VERBOSE))
+ System.out.println("Display contents of the FrameworkDatabase.db file in CSV format.");
+ result = dbUp.getCsvEntries(frameworkDatabase, VERBOSE);
+ break;
+ case FIX_DB:
+ // Automatically make the database match the contents of the workspace
+ // Modifies: FrameworkDatabase.db
+ if ((VERBOSE > MIN_VERBOSE) && (QUIET == false)) {
+ if (TEST == false)
+ System.out.println("Adjusting the FrameworkDatabase to match the contents of the WORKSPACE: "
+ + workspace);
+ if (TEST)
+ System.out.println("Verify the FrameworkDatabase matches the contents of the WORKSPACE: "
+ + workspace);
+ }
+ if ((DEBUG > 3) || (VERBOSE > MED_VERBOSE))
+ System.out.println("Scan the Workspace and update the FrameworkDatabase.db file.");
+ result = dbUp.fixDatabase(workspace, VERBOSE, INTERACTIVE, TEST, QUIET);
+
+ break;
+ case ADD_SOMETHING:
+ // Add a Platform, package or FAR to the workspace.
+ // Modifies: FrameworkDatabase.db
+ if (((DEBUG > 3) || (VERBOSE > MED_VERBOSE)) && (isPlatform))
+ System.out.println("Add Platform " + commandArgs + " to the FrameworkDatabase.db file");
+ else if (((DEBUG > 3) || (VERBOSE > MED_VERBOSE)) && (isPackage))
+ System.out.println("Add Package " + commandArgs + " to the FrameworkDatabase.db file");
+ else if (((DEBUG > 3) || (VERBOSE > MED_VERBOSE)) && (isFar))
+ System.out.println("Add Framework Archive " + commandArgs + " to the FrameworkDatabase.db file");
+ result = dbUp.addItem(frameworkDatabase, commandArgs, VERBOSE, INTERACTIVE);
+ break;
+ case DELETE_SOMETHING:
+ // Remove a platform, package or FAR from the workspace
+ // Modifies: FrameworkDatabase.db, AND Filesystem
+ if (((DEBUG > 3) || (VERBOSE > MED_VERBOSE)) && (isPlatform))
+ System.out.println("Removing Platform " + commandArgs + " from the FrameworkDatabase.db file");
+ else if (((DEBUG > 3) || (VERBOSE > MED_VERBOSE)) && (isPackage))
+ System.out.println("Removing Package " + commandArgs + " from the FrameworkDatabase.db file");
+ else if (((DEBUG > 3) || (VERBOSE > MED_VERBOSE)) && (isFar))
+ System.out.println("Removing Framework Archive " + commandArgs + " from the FrameworkDatabase.db file");
+ result = dbUp.addItem(workspace, commandArgs, VERBOSE, INTERACTIVE);
+ break;
+ case FIND_SOMETHING:
+ // Find something in the workspace
+ // Modifies: NOTHING
+ if ((DEBUG > 3) || (VERBOSE > MED_VERBOSE))
+ System.out.println("Finding " + whatToFind + " " + commandArgs + " in the Workspace");
+ result = dbUp.findItem(workspace, VERBOSE, whatToFind, commandArgs);
+ break;
+ case SHOW_FAR:
+ // Display FAR information for all SPDs in the workspace
+ // Modifies: NOTHING
+ if ((DEBUG > 3) || (VERBOSE > MED_VERBOSE))
+ System.out.println("Display Framework Archives in the Workspace");
+ result = dbUp.findFars(workspace, VERBOSE);
+ break;
+ case SHOW_PACKAGES:
+ // Display SPD information for all SPDs in the workspace
+ // Modifies: NOTHING
+ if ((DEBUG > 3) || (VERBOSE > MED_VERBOSE))
+ System.out.println("Display Packages in the Workspace");
+ result = dbUp.findSpds(workspace, VERBOSE);
+ break;
+ case SHOW_PLATFORMS:
+ // Display FPD information for all SPDs in the workspace
+ // Modifies: NOTHING
+ if ((DEBUG > 3) || (VERBOSE > MED_VERBOSE))
+ System.out.println("Display Platforms in the Workspace");
+ result = dbUp.findFpds(workspace, VERBOSE);
+ break;
+ default:
+ // ERROR IF WE GET HERE!
+ if ((DEBUG > 3) || (VERBOSE > MAX_VERBOSE))
+ System.out.println("We could not process the following: " + commandToCall.toString());
+ else if (QUIET == false)
+ outputUsage();
+ result = EFAILURE;
+ break;
+ }
+ return res;
+ }
+
+ private int parseCmdLine(String[] args) {
+
+ // Default is to fix the database.
+ commandToCall = Cmd.FIX_DB;
+ if (args.length == NOTFOUND) {
+ if ((DEBUG > 3) || (VERBOSE > MAX_VERBOSE))
+ System.out.println("NO ARGUMENTS! " + commandToCall.toString());
+ return (ESUCCESS);
+ }
+
+ for (int i = 0; i < args.length; i++)
+ if (args[i].toLowerCase().contentEquals("-q"))
+ QUIET = true;
+
+ for (int i = 0; i < args.length; i++) {
+ String arg = args[i].trim();
+ // This is the list of valid options
+ if (!((arg.toLowerCase().startsWith("-t")) || (arg.toLowerCase().startsWith("--t"))
+ || (arg.toLowerCase().startsWith("-q")) || (arg.toLowerCase().startsWith("-i"))
+ || (arg.toLowerCase().startsWith("-f")) || (arg.toLowerCase().startsWith("--f"))
+ || (arg.toLowerCase().startsWith("-c")) || (arg.toLowerCase().startsWith("--c"))
+ || (arg.toLowerCase().startsWith("-a")) || (arg.toLowerCase().startsWith("--a"))
+ || (arg.toLowerCase().startsWith("-r")) || (arg.toLowerCase().startsWith("--d"))
+ || (arg.toLowerCase().startsWith("-v")) || (arg.toLowerCase().startsWith("--c"))
+ || (arg.toLowerCase().startsWith("--p")) || (arg.toLowerCase().startsWith("-h"))
+ || (arg.toLowerCase().startsWith("--h")) || (arg.toLowerCase().startsWith("/h")) || (arg
+ .toLowerCase()
+ .startsWith("-?")))) {
+ // This is the fall through, we got something we did not know how to
+ // process!
+ if (args[i].startsWith("-")) {
+ System.out.println("ERROR: E1004 Unknown Option: " + arg);
+ System.out.println("Try running with -h or --help");
+ } else {
+ System.out.println("ERROR: E1005 Unknown Argument: " + arg);
+ System.out.println("Try running with -h or --help");
+ }
+ System.out.println("Program Aborted!");
+ System.err.flush();
+ System.exit(EFAILURE);
+ }
+ if ((arg.toLowerCase().contentEquals("-t")) || (arg.toLowerCase().contains("--test"))) {
+ // Test Workspace, do not fix.
+ TEST = true;
+ }
+ if (arg.toLowerCase().contentEquals("-q")) {
+ QUIET = true;
+ }
+ if (arg.toLowerCase().contentEquals("-i")) {
+ INTERACTIVE = true;
+ }
+ if ((arg.toLowerCase().contentEquals("-f")) || (arg.toLowerCase().contains("--fix"))) {
+ // Non-interactive fix of the database
+ commandToCall = Cmd.FIX_DB;
+ }
+ if ((arg.toLowerCase().contentEquals("-c")) || (arg.toLowerCase().contains("--csv"))) {
+ // Dump database in CSV format
+ commandToCall = Cmd.SHOW_CSV;
+ }
+ if ((arg.toLowerCase().trim().contentEquals("-a")) || (arg.toLowerCase().contains("--add"))) {
+ i++;
+ if (args[i].startsWith("-")) {
+ System.out.println("ERROR: E002 Missing Argument!");
+ System.out
+ .println("The add function requires an argument, either a package name or a platform name!");
+ System.out.println("DbUpdate Aborted!");
+ System.err.flush();
+ System.exit(EFAILURE);
+ }
+ commandToCall = Cmd.ADD_SOMETHING;
+ commandArgs = args[i];
+ setArgType(commandArgs);
+ }
+ if ((arg.toLowerCase().trim().contentEquals("-r")) || (arg.toLowerCase().contains("--del"))) {
+ i++;
+ if (args[i].startsWith("-")) {
+ System.out.println("ERROR: E002 Missing Argument!");
+ System.out
+ .println("The remove function requires an argument, either a package name or a platform name!");
+ System.out.println("DbUpdate Aborted!");
+ System.err.flush();
+ System.exit(EFAILURE);
+ }
+ commandToCall = Cmd.DELETE_SOMETHING;
+ commandArgs = args[i];
+ setArgType(commandArgs);
+ }
+ if (arg.toLowerCase().contains("--find")) {
+ commandToCall = Cmd.FIND_SOMETHING;
+ i++;
+ if (args[i].toLowerCase().contains("--lib"))
+ whatToFind = "LIBRARY";
+ else if (args[i].toLowerCase().contains("--guid"))
+ whatToFind = "GUID";
+ else if (args[i].toLowerCase().contains("--ppi"))
+ whatToFind = "PPI";
+ else if (args[i].toLowerCase().contains("--prot"))
+ whatToFind = "PROTOCOL";
+ else if (args[i].toLowerCase().contains("--pcd"))
+ whatToFind = "PCD";
+ else if (args[i].startsWith("-")) {
+ System.out.println("ERROR: E001 Invalid Argument");
+ System.out.println("The find function takes either a qualifier of --guid, --ppi,");
+ System.out.println(" --proto, --pcd, or the string to search for.");
+ System.err.flush();
+ System.exit(EFAILURE);
+ } else
+ commandArgs = args[i];
+
+ if (!whatToFind.contentEquals("")) {
+ i++;
+ if (args[i].startsWith("-")) {
+ System.out.println("ERROR: E001 Invalid Argument");
+ System.out.println("The find function qualifier (--guid, --ppi, --proto, --pcd)");
+ System.out.println(" must be followed by the string to search for.");
+ System.err.flush();
+ System.exit(EFAILURE);
+ } else
+ commandArgs = args[i];
+ }
+
+ }
+ if (arg.trim().contentEquals("-v")) {
+ VERBOSE++;
+ }
+ if (arg.toLowerCase().contains("--lib")) {
+ whatToFind = "LIBRARY";
+ }
+ if (arg.toLowerCase().contains("--guid")) {
+ whatToFind = "GUID";
+ }
+ if (arg.toLowerCase().contains("--ppi")) {
+ whatToFind = "PPI";
+ }
+ if (arg.toLowerCase().contains("--prot")) {
+ whatToFind = "PROTOCOL";
+ }
+ if (arg.toLowerCase().contains("--pcd")) {
+ whatToFind = "PCD";
+ }
+ if (arg.toLowerCase().contentEquals("-d") || arg.trim().toLowerCase().contains("--debug")) {
+ if ((i + 1 == args.length) || (args[i + 1].trim().startsWith("-"))) {
+ DEBUG = 1;
+ } else if (i + 1 < args.length) {
+ String pattern = "^\\d+";
+ if (args[i + 1].trim().matches(pattern)) {
+ i++;
+ DEBUG = Integer.parseInt(args[i]);
+ } else
+ DEBUG = 1;
+ }
+ }
+ if (arg.trim().contentEquals("-V")) {
+ System.out.println("DbTools, " + version);
+ System.out.println(copyright);
+ System.out.println(Specification);
+ System.err.flush();
+ System.exit(ESUCCESS);
+ }
+ if (arg.toLowerCase().trim().startsWith("--pack")) {
+ commandToCall = Cmd.SHOW_PACKAGES;
+ }
+ if (arg.toLowerCase().trim().startsWith("--far")) {
+ commandToCall = Cmd.SHOW_FAR;
+ }
+ if (arg.toLowerCase().trim().startsWith("--plat")) {
+ commandToCall = Cmd.SHOW_PLATFORMS;
+ }
+ if ((arg.toLowerCase().contentEquals("-h")) || (arg.toLowerCase().contentEquals("-?"))
+ || (arg.toLowerCase().startsWith("/h")) || (arg.toLowerCase().contentEquals("--help"))) {
+ outputUsage();
+ System.exit(EFAILURE);
+ }
+
+ }
+ return ESUCCESS;
+ }
+
+ private int testFile(String Filename) {
+ File tFile = new File(Filename);
+ if (DEBUG > 4)
+ System.out.println("File is located: " + tFile.getPath());
+ if (tFile.exists())
+ return FOUND;
+ else
+ return NOTFOUND;
+ }
+
+ private void setArgType(String argv) {
+ if (argv.trim().toLowerCase().contains(".spd"))
+ isPackage = true;
+ if (argv.trim().toLowerCase().contains(".fpd"))
+ isPlatform = true;
+ if (argv.trim().toLowerCase().contains(".far"))
+ isFar = true;
+ }
+
+ public String getArgType() {
+ String argt = "UNKNOWN";
+ if (isPackage)
+ argt = "SPD";
+ if (isFar)
+ argt = "FAR";
+ if (isPlatform)
+ argt = "FPD";
+ return argt;
+ }
+
+ private static void outputUsage() {
+
+ System.out.println("DbTool, " + version);
+ System.out.println(copyright);
+ System.out.println("Usage:");
+ System.out.println(" DbTool [-v] [-t] [-q] [-V] [--package] [--platform] [-h | -? | --help]");
+ System.out.println(" where:");
+ System.out.println(" -h | -? | --help OPTIONAL - This Help Text");
+ System.out
+ .println(" -t | --test OPTIONAL - Test the FrameworkDatabase Contents against the WORKSPACE");
+ System.out
+ .println(" -q OPTIONAL - Quiet mode - pass or fail only on return value, nothing is printed");
+ System.out
+ .println(" -f | --fix OPTIONAL - Automatically fix (non-interactive) the Database file to match the WORKSPACE.");
+ System.out
+ .println(" -v OPTIONAL - Verbose, print information messages. Adding more -v arguments increases verbosity.");
+ System.out.println(" --package OPTIONAL - Show all Packages installed in the WORKSPACE.");
+ System.out.println(" --platforms OPTIONAL - Show all Platforms installed in the WORKSPACE.");
+ System.out.println(" -V OPTIONAL - Display Verision information and exit.");
+ //
+ // TODO: Implement the following options.
+ //
+ /**
+ System.out.println("");
+ System.out.println(" =================== Options below this line have not been implemented in this release ===================");
+ System.out
+ .println(" -i OPTIONAL - Force interactive on commands that modify the WORKSPACE");
+ System.out
+ .println(" --far OPTIONAL - Show all Framework Archives installed in the WORKSPACE.");
+ System.out
+ .println(" --find [qualifier] value OPTIONAL - Search the WORKSPACE for value, with one and only one optional Qualifier.");
+ System.out.println(" qualifiers: --guid Find a GUID by Guid C Name");
+ System.out.println(" --prot Find a Protocol or ProtocolNotify by C Name");
+ System.out.println(" --ppi Find a PPI or PpiNotify by C Name");
+ System.out.println(" --pcd Find a PCD entry by C Name");
+ System.out.println(" --lib Find information about a Library Class");
+ System.out
+ .println(" -c OPTIONAL - Print a comma separated value listing of TYPE,UiName,Filename");
+ System.out
+ .println(" -a, --add value OPTIONAL - Add a value (package, platform or far) to the database");
+ System.out
+ .println(" -r, --del value OPTIONAL - Remove a value (package, platform or far) from the database");
+ System.out.println("");
+ */
+ }
+}
diff --git a/Tools/Java/Source/DbTools/src/org/tianocore/DbTools/DbTool.java b/Tools/Java/Source/DbTools/src/org/tianocore/DbTools/DbTool.java
new file mode 100644
index 0000000000..5e502b710c
--- /dev/null
+++ b/Tools/Java/Source/DbTools/src/org/tianocore/DbTools/DbTool.java
@@ -0,0 +1,24 @@
+// @file
+// DbUpdate wrapper
+//
+// Copyright (c) 2006, Intel Corporation All rights reserved.
+//
+// This program and the accompanying materials are licensed and made
+// available under the terms and conditions of the BSD License which
+// accompanies this distribution. The full text of the license may
+// be found at http://opensource.org/licenses/bsd-license.php
+//
+// THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
+// WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
+//
+
+package org.tianocore.DbTools;
+
+public class DbTool {
+
+ public static void main(String[] args) {
+ if (new DbCmds().DbUpdateCmdLine(args) != 0)
+ System.exit(1);
+ System.exit(0);
+ }
+}
diff --git a/Tools/Java/Source/DbTools/src/org/tianocore/DbTools/UpdateDb.java b/Tools/Java/Source/DbTools/src/org/tianocore/DbTools/UpdateDb.java
new file mode 100644
index 0000000000..ad581c93a6
--- /dev/null
+++ b/Tools/Java/Source/DbTools/src/org/tianocore/DbTools/UpdateDb.java
@@ -0,0 +1,557 @@
+// @file
+// This Class processes multiple MSA files and merges them into a single,
+// merged MSA file. It will optionally add the merged MSA file into a package.
+//
+//
+// Copyright (c) 2006, Intel Corporation All rights reserved.
+//
+// This program and the accompanying materials are licensed and made
+// available under the terms and conditions of the BSD License which
+// accompanies this distribution. The full text of the license may
+// be found at http://opensource.org/licenses/bsd-license.php
+//
+// THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
+// WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
+//
+//
+
+package org.tianocore.DbTools;
+
+import java.io.*;
+import java.util.*;
+// import java.sql.Time;
+
+// import java.lang.*;
+// import java.lang.ExceptionInInitializerError;
+
+// import org.apache.xmlbeans.*;
+import org.apache.xmlbeans.XmlCursor;
+// import org.apache.xmlbeans.XmlObject;
+import org.apache.xmlbeans.XmlOptions;
+// import org.apache.xmlbeans.XmlException;
+import org.tianocore.*;
+
+// import org.tianocore.*;
+// FrameworkDatabase.db Schema Elements
+import org.tianocore.FrameworkDatabaseDocument.*;
+import org.tianocore.FdbHeaderDocument.*;
+import org.tianocore.PackageListDocument.*;
+import org.tianocore.PlatformListDocument.*;
+import org.tianocore.FarListDocument.*;
+
+// FAR Schema Elements
+// import org.tianocore.FrameworkArchiveManifestDocument.*;
+// import org.tianocore.FarHeaderDocument.*;
+// import org.tianocore.FarPackageDocument.*;
+// import org.tianocore.FarPlatformDocument.*;
+
+// FPD Schema Elements
+import org.tianocore.PlatformSurfaceAreaDocument.*;
+import org.tianocore.PlatformHeaderDocument.*;
+
+// import org.tianocore.FrameworkModulesDocument.*;
+// import org.tianocore.DynamicPcdBuildDefinitionsDocument.*;
+
+// SPD Schema Elements
+// import org.tianocore.PackageSurfaceAreaDocument.*;
+// import org.tianocore.SpdHeaderDocument.*;
+// import org.tianocore.LibraryClassDeclarationsDocument.*;
+// import org.tianocore.GuidDeclarationsDocument.*;
+// import org.tianocore.ProtocolDeclarationsDocument.*;
+// import org.tianocore.PpiDeclarationsDocument.*;
+// import org.tianocore.PcdDeclarationsDocument.*;
+
+// MSA Schema Elements
+// import org.tianocore.ModuleSurfaceAreaDocument.*;
+// import org.tianocore.MsaHeaderDocument.*;
+// import org.tianocore.LicenseDocument.*;
+// import org.tianocore.LibraryClassDefinitionsDocument.*;
+// import org.tianocore.PackageDependenciesDocument.*;
+// import org.tianocore.ProtocolsDocument.*;
+// import org.tianocore.PPIsDocument.*;
+// import org.tianocore.PcdCodedDocument.*;
+
+public class UpdateDb {
+
+ private final int DEBUG = 0;
+
+ private final int PASS = 0;
+
+ private final int FAIL = 1;
+
+ private int dCtr = 0;
+
+ private int lCtr = 0;
+
+ // Future implementations
+ // private XmlCursor cursor = null;
+
+ // FrameworkDatabase Component Elements
+ // private FrameworkDatabaseDocument fdbDoc = null;
+
+ // private FrameworkDatabase fdbInstance = null;
+
+ // private FdbHeader fdbHeader = null;
+
+ // private PackageList fdbPackageList = null;
+
+ // private ArrayList<String> packageList = new ArrayList<String>();
+
+ // private PlatformList fdbPlatformList = null;
+
+ // private ArrayList<String> platformList = new ArrayList<String>();
+
+ // private FarList fdbFarList = null;
+
+ // private ArrayList<String> farList = new ArrayList<String>();
+
+ private ArrayList<String> spdList = new ArrayList<String>();
+
+ private ArrayList<String> fpdList = new ArrayList<String>();
+
+ // Platform Components
+ // private PlatformSurfaceAreaDocument fpdDoc = null;
+
+ // private PlatformSurfaceArea fpd = null;
+
+ // private PlatformHeader fpdHeader = null;
+
+ private boolean wasModified = false;
+
+ private int VERBOSE = 0;
+
+ // The combineMsaFiles routine is the primary routine for creating a
+ // Merged MSA file.
+
+ public UpdateDb() {
+ init();
+ }
+
+ private void init() {
+
+ }
+
+ public int getAllEntries(String dbFilename, int VERBOSE_FLAG) {
+ System.out.println("Function not yet implemented!");
+ return FAIL;
+ }
+
+ public int getCsvEntries(String dbFilename, int VERBOSE_FLAG) {
+ System.out.println("Function not yet implemented!");
+ return FAIL;
+ }
+
+ public int fixDatabase(String workspace, int VERBOSE_FLAG, boolean INTERACTIVE, boolean TEST, boolean QUIET) {
+ int result = PASS;
+ String dbFile = workspace + File.separator + "Tools" + File.separator + "Conf" + File.separator
+ + "FrameworkDatabase.db";
+ String dbBak = dbFile + ".bak";
+
+ try {
+ // Make a backup file for frameworkDatabase
+ if (VERBOSE_FLAG > 3)
+ System.out.println("Creating Backup file: " + dbBak);
+ copyFile(dbFile, dbBak);
+ } catch (IOException e) {
+ System.out.println("Error: Cannot make backup file " + dbBak);
+ return FAIL;
+ }
+
+ // Datebase update for SPD and FPD files
+ result = fixDB(workspace, dbFile, VERBOSE_FLAG, TEST, QUIET);
+ if ((result == 0) && (TEST) && (QUIET == false))
+ System.out.println("Workspace is consistent with current database!");
+ return PASS;
+ }
+
+ public int addItem(String dbFilename, String item, int VERBOSE_FLAG, boolean INTERACTIVE) {
+ System.out.println("Function not yet implemented!");
+ return FAIL;
+ }
+
+ public int delItem(String workspace, String item, int VERBOSE_FLAG, boolean INTERACTIVE) {
+ System.out.println("Function not yet implemented!");
+ return FAIL;
+ }
+
+ public int findItem(String workspace, int VERBOSE_FLAG, String findWhat, String item) {
+ System.out.println("Function not yet implemented!");
+ return FAIL;
+ }
+
+ public int findFars(String workspace, int VERBOSE_FLAG) {
+ System.out.println("Function not yet implemented!");
+ return FAIL;
+ }
+
+ public int findSpds(String workspace, int VERBOSE_FLAG) {
+ System.out.println("The following Package (SPD) files are in the workspace!");
+ File wsDir = new File(workspace);
+ findSPDFiles(wsDir, workspace, VERBOSE);
+ for (int i = 0; i < spdList.size(); i++) {
+ System.out.println(" " + spdList.get(i).trim());
+ // TODO: get the PackageName from the file
+ }
+ return FAIL;
+ }
+
+ public int findFpds(String workspace, int VERBOSE_FLAG) {
+ System.out.println("The following Platform (FPD) files are in the workspace!");
+ File wsDir = new File(workspace);
+ findFPDFiles(wsDir, workspace, VERBOSE);
+ for (int i = 0; i < fpdList.size(); i++) {
+ System.out.println(" " + fpdList.get(i).trim());
+ // TODO: get the PlatformName from the file
+ }
+ return FAIL;
+ }
+
+ // copy from source file to destination file
+ private int copyFile(String src, String dst) throws IOException {
+ try {
+ File srcFile = new File(src);
+ FileReader fileReader = new FileReader(srcFile);
+ BufferedReader reader = new BufferedReader(fileReader);
+
+ File dstFile = new File(dst);
+ FileWriter fileWriter = new FileWriter(dstFile);
+ BufferedWriter writer = new BufferedWriter(fileWriter);
+
+ String line = null;
+ while ((line = reader.readLine()) != null) {
+ writer.write(line);
+ writer.newLine();
+ }
+
+ reader.close();
+ writer.close();
+ } catch (IOException e) {
+ System.out.println("I/O Exception during file copy: " + e);
+ }
+
+ return PASS;
+ }
+
+ private int fixDB(String workspace, String dbFile, int VERBOSE, boolean TEST, boolean QUIET) {
+ File wsDir = new File(workspace);
+ int retValue = PASS;
+ // Find all .spd and .fpd files in workspace and put them in spdList and fpdList
+ if (VERBOSE > 0)
+ System.out.println("SPD File Search ");
+ findSPDFiles(wsDir, workspace, VERBOSE);
+ dCtr = 0;
+ lCtr = 0;
+ if (VERBOSE > 0) {
+ System.out.println(" ");
+ System.out.println("FPD File Search ");
+ }
+ findFPDFiles(wsDir, workspace, VERBOSE);
+ if (VERBOSE > 0)
+ System.out.println(" ");
+
+ try {
+ // check database file for possible update
+ retValue = checkDBForUpdate(workspace, dbFile, VERBOSE, TEST, QUIET);
+ } catch (IOException e) {
+ if (QUIET == false)
+ System.out.println("Error: Updating " + dbFile + " file.");
+ return FAIL;
+ }
+
+ if ((VERBOSE > 0) && (TEST) && (wasModified)) {
+ System.out.println("FRAMEWORK Database does NOT match the contents of the WORKSPACE");
+ retValue = FAIL;
+ }
+ if ((VERBOSE > 0) && (wasModified == false) && (QUIET == false))
+ System.out.println("FRAMEWORK Database matches the contents of the WORKSPACE");
+
+ return retValue;
+ }
+
+ private void findSPDFiles(File dir, String workspace, int VERBOSE) {
+ String str;
+
+ if (dir.isDirectory()) {
+ dCtr++;
+ String[] subdir = dir.list();
+ if (dCtr >= 10) {
+ if (VERBOSE > 2)
+ System.out.print(".");
+ dCtr = 0;
+ lCtr++;
+ }
+ if (lCtr > 79) {
+ if (VERBOSE > 2)
+ System.out.println(" ");
+ lCtr = 0;
+ dCtr = 0;
+ }
+
+ for (int i = 0; i < subdir.length; i++) {
+ findSPDFiles(new File(dir, subdir[i]), workspace, VERBOSE);
+ }
+ } else {
+ if (dir.toString().toLowerCase().endsWith(".spd")) {
+ str = dir.getPath().replace('\\', '/');
+ workspace = workspace.replace('\\', '/');
+ str = strStrip(str, workspace + "/");
+ spdList.add(str.toString());
+ if (VERBOSE == 2)
+ System.out.println(" " + str);
+ if (VERBOSE > 2)
+ System.out.print("+");
+ lCtr++;
+ }
+ }
+
+ }
+
+ private void findFPDFiles(File dir, String workspace, int VERBOSE) {
+ String str;
+
+ if (dir.isDirectory()) {
+ String[] subdir = dir.list();
+ if (dCtr >= 10) {
+ if (VERBOSE > 2)
+ System.out.print(".");
+ dCtr = 0;
+ lCtr++;
+ }
+ if (lCtr > 79) {
+ if (VERBOSE > 2)
+ System.out.println(" ");
+ lCtr = 0;
+ dCtr = 0;
+ }
+
+ for (int i = 0; i < subdir.length; i++) {
+ findFPDFiles(new File(dir, subdir[i]), workspace, VERBOSE);
+ }
+ } else {
+ if (dir.toString().toLowerCase().endsWith(".fpd")) {
+ str = dir.getPath().replace('\\', '/');
+ workspace = workspace.replace('\\', '/');
+ str = strStrip(str, workspace + "/");
+ fpdList.add(str.toString());
+ if (VERBOSE == 2)
+ System.out.println(" " + str);
+ if (VERBOSE > 2)
+ System.out.print("+");
+ lCtr++;
+ }
+ }
+ }
+
+ private int checkDBForUpdate(String workspace, String dbFileName, int VERBOSE, boolean TEST, boolean QUIET)
+ throws IOException {
+ int SpdFlag = 0;
+ int FpdFlag = 0;
+ String SpdFile = null;
+ String SpdFullFile = null;
+ String FpdFile = null;
+ String FpdFullFile = null;
+
+ String tmpDbFile = dbFileName + ".tmp";
+ String newSpd = null;
+ String newFpd = null;
+
+ FileReader fileReader = new FileReader(dbFileName);
+ BufferedReader reader = new BufferedReader(fileReader);
+
+ FileWriter fileWriter = new FileWriter(tmpDbFile);
+ BufferedWriter writer = new BufferedWriter(fileWriter);
+
+ String line = null;
+ try {
+ while ((line = reader.readLine()) != null) {
+ if (line.indexOf("Added the following") >= 0) {
+ wasModified = true;
+ continue;
+ }
+ //
+ // Process for .spd files
+ //
+ if (line.indexOf("<PackageList") >= 0) {
+ SpdFlag = 1;
+ } else {
+ if (line.indexOf("</PackageList") >= 0) {
+ SpdFlag = 2;
+ }
+ }
+ if (SpdFlag == 1 && line.indexOf("Filename") >= 0) {
+ SpdFile = strStrip(line, "<Filename>");
+ SpdFile = strStrip(SpdFile, "</Filename>");
+ SpdFile = SpdFile.trim();
+ SpdFullFile = workspace + File.separator + SpdFile;
+ if (!(new File(SpdFullFile)).exists()) {
+ if (VERBOSE > 0)
+ System.out.println("WARNING: Removing SPD file: " + SpdFile
+ + "from the DB, as it does not exist!");
+ wasModified = true;
+ continue;
+ }
+ // Don't add files that are already in the database
+ spdList.remove(SpdFile);
+ }
+ if (SpdFlag == 2) {
+ int cflag = 0;
+ for (int i = 0; i < spdList.size(); i++) {
+ newSpd = spdList.get(i);
+ newSpd = newSpd.trim();
+ if (newSpd.length() > 0) {
+ if (cflag == 0) {
+ Calendar c = Calendar.getInstance();
+ if (TEST == false)
+ writer.write(" <!-- Adding the following SPD files " + c.getTime() + " -->\n");
+ }
+ if (VERBOSE > 0)
+ System.out.println(" Adding SPD file: " + newSpd);
+ if (TEST == false)
+ writer.write(" <Filename>" + newSpd + "</Filename>\n");
+ cflag++;
+ wasModified = true;
+ }
+ }
+ SpdFlag++;
+ }
+ //
+ // Process for .fpd files
+ //
+ if (line.indexOf("<PlatformList") >= 0) {
+ FpdFlag = 1;
+ } else {
+ if (line.indexOf("</PlatformList") >= 0) {
+ FpdFlag = 2;
+ }
+ }
+ if (FpdFlag == 1 && line.indexOf("Filename") >= 0) {
+ FpdFile = strStrip(line, "<Filename>");
+ FpdFile = strStrip(FpdFile, "</Filename>");
+ FpdFile = FpdFile.trim();
+ FpdFullFile = workspace + File.separator + FpdFile;
+ if (!(new File(FpdFullFile)).exists()) {
+ if (VERBOSE > 0)
+ System.out.println("WARNING: Removing FPD file: " + FpdFile
+ + " from the DB, as it does not exist!");
+ wasModified = true;
+ continue;
+ }
+ // Don't add files that are already in the database
+ fpdList.remove(FpdFile);
+ }
+ if (FpdFlag == 2) {
+ int cflag = 0;
+ for (int i = 0; i < fpdList.size(); i++) {
+ newFpd = fpdList.get(i);
+ newFpd = newFpd.trim();
+ if (newFpd.length() > 0) {
+ if (cflag == 0) {
+ Calendar c = Calendar.getInstance();
+ if (TEST == false)
+ writer.write(" <!-- Adding the following FPD files " + c.getTime() + " -->\n");
+ }
+ if (VERBOSE > 0)
+ System.out.println(" Adding FPD file: " + newFpd);
+ if (TEST == false)
+ writer.write(" <Filename>" + newFpd + "</Filename>\n");
+ cflag++;
+ wasModified = true;
+ }
+ }
+ FpdFlag++;
+ }
+
+ if (DEBUG > 2) {
+ System.out.println(line);
+ }
+ if (TEST == false) {
+ writer.write(line);
+ writer.newLine();
+ }
+ }
+ reader.close();
+ writer.close();
+
+ } catch (IOException e) {
+ System.out.println("ERROR I/O Exception occured! " + e);
+ System.exit(FAIL);
+ }
+
+ if (wasModified) {
+ if ((VERBOSE > 0) && (QUIET == false))
+ System.out.println("FrameworkDatabase has been UPDATED for this Workspace!\n");
+ if (TEST == false)
+ copyFile(tmpDbFile, dbFileName);
+ } else {
+ if ((VERBOSE > 0) && (QUIET == false))
+ System.out.println("FrameworkDatabase correct for this Workspace!\n");
+ }
+
+ if (TEST == false) {
+ File tmpFile = new File(tmpDbFile);
+ if (tmpFile.exists()) {
+ tmpFile.delete();
+ }
+ }
+
+ return PASS;
+ }
+
+ static String strStrip(String str, String pattern) {
+ int ps = 0;
+ int pe = 0;
+ StringBuffer result = new StringBuffer();
+
+ while ((pe = str.indexOf(pattern, ps)) >= 0) {
+ result.append(str.substring(ps, pe));
+ ps = pe + pattern.length();
+ }
+ result.append(str.substring(ps));
+ return result.toString();
+ }
+
+ private String checkDuplicateStrings(String aString, ArrayList<String> aList) {
+ // This routine checks a string against an array.
+ // If the string is found, it will return an empty string.
+ // If the string is not found, it adds the string to the array, and
+ // returns the string to the caller.
+ for (int lctr = 0; lctr < aList.size(); lctr++) {
+ if (DEBUG > 8)
+ System.out.println("Comparing: \n" + aString.replace(" ", "").replace("\n", "") + "\nTo: \n"
+ + aList.get(lctr).replace(" ", "").replace("\n", "").toString().trim());
+ if (aString.replace(" ", "").replace("\n", "").contains(
+ aList.get(lctr).replace(" ", "").replace("\n", "")
+ .toString().trim())) {
+ if ((DEBUG > 3) || (VERBOSE > 3))
+ System.out.println("Found a duplicate String, skipping!");
+ return "";
+ }
+ }
+ if ((DEBUG > 3) || (VERBOSE > 3))
+ System.out.println("Returning UNIQUE String!\n " + aString);
+ aList.add(aString);
+ return aString;
+ }
+
+ private static class XmlConfig {
+ public static XmlCursor setupXmlCursor(XmlCursor cursor) {
+ String uri = "http://www.TianoCore.org/2006/Edk2.0";
+ cursor.push();
+ cursor.toNextToken();
+ cursor.insertNamespace("", uri);
+ cursor.insertNamespace("xsi", "http://www.w3.org/2001/XMLSchema-instance");
+ cursor.pop();
+ return cursor;
+
+ }
+
+ public static XmlOptions setupXmlOptions() {
+ XmlOptions options = new XmlOptions();
+ options.setCharacterEncoding("UTF-8");
+ options.setSavePrettyPrint();
+ options.setSavePrettyPrintIndent(2);
+ return options;
+ }
+
+ }
+}
diff --git a/Tools/Java/Source/Merge/Merge.msa b/Tools/Java/Source/Merge/Merge.msa
index 0920899476..b394d7a90a 100644
--- a/Tools/Java/Source/Merge/Merge.msa
+++ b/Tools/Java/Source/Merge/Merge.msa
@@ -2,18 +2,18 @@
<ModuleSurfaceArea xmlns="http://www.TianoCore.org/2006/Edk2.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<MsaHeader>
<ModuleName>Merge Tool</ModuleName>
- <ModuleType>BASE</ModuleType>
+ <ModuleType>TOOL</ModuleType>
<GuidValue>fbb48848-4776-44a1-8458-1e84701fb62f</GuidValue>
<Version>0.1</Version>
<Abstract>The tool merges multiple MSA files (of the same ModuleType) into a single module</Abstract>
- <Description>Merging multiple modules into a single module is useful for size reduction of the binary images.
-This tool will create an MSA file, based on the content of "leaf" MSA files. It is written so that it can be executed from a command line, or later, incorporated into the Wizard.
-USAGE:
+ <Description>Merging multiple modules into a single module is useful for size reduction of the binary images.
+This tool will create an MSA file, based on the content of "leaf" MSA files. It is written so that it can be executed from a command line, or later, incorporated into the Wizard.
+USAGE:
merge [-v] -t target [-u UiName] [-p PackageFile] [-o OutputFileBasename] dir1\mod1.msa ... dirN\modN.msa</Description>
<Copyright>Copyright (c) 2006, Intel Corporation All rights reserved.</Copyright>
- <License URL="http://opensource.org/licenses/bsd-license.php">This program and the accompanying materials are licensed and made available under the terms and conditions of the BSD License which accompanies this distribution. The full text of the license may be found at http://opensource.org/licenses/bsd-license.php
-
-THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
+ <License URL="http://opensource.org/licenses/bsd-license.php">This program and the accompanying materials are licensed and made available under the terms and conditions of the BSD License which accompanies this distribution. The full text of the license may be found at http://opensource.org/licenses/bsd-license.php
+
+THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.</License>
<Specification>FRAMEWORK_BUILD_PACKAGING_SPECIFICATION 0x00000052</Specification>
</MsaHeader>
@@ -23,10 +23,10 @@ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.</L
<OutputFileBasename>Merge</OutputFileBasename>
</ModuleDefinitions>
<SourceFiles>
- <Filename>src/org/tianocore/Mege/CombineMsa.java</Filename>
+ <Filename>src/org/tianocore/Merge/CombineMsa.java</Filename>
<Filename>src/org/tianocore/Merge/Merge.java</Filename>
<Filename>src/org/tianocore/Merge/MergeCmd.java</Filename>
<Filename>build.xml</Filename>
<Filename>readme.txt</Filename>
</SourceFiles>
-</ModuleSurfaceArea> \ No newline at end of file
+</ModuleSurfaceArea>